0:前言
1:本文主要作为丙方android公司的身份来写
2:作者有不对的地方,请指出,谢谢
[第一篇:android利用jni调用第三方库——编写库libhello.so]
[第二篇:android利用jni调用第三方库——编写库android程序直接调用第三方库libhello.so]
[第三篇:android利用jni调用第三方库——编写库android程序整合第三方库libhello.so到自己的库libhelloword.so]
1:场景:公司接到任务,说配合乙方C++公司开发android识别程序,项目布置到项目经理,然后经理把任务交给你来做,你自然是先抱怨一番,活多钱少让我这新人来干,哎没办法啊,干吧!
2:东西:乙方C++公司交给我的东西有
libhello.so库文件 com_hello_hello_HelloActivity.h头文件(有可能没有这个,我是死命要来的) 库的接口说明文档
3:搞起:
- 看了看给的接口说明文档,哎呦,不错哦,文档说明很详细,里面的函数接口定义的完美,而且他的库定义符合jni的规范,不需要在添加什么东西了,直接在android程序中调用就行,good啊
- 新建项目helloword2,在根目录下新建libs/armeabi文件夹,然后把库libhello.so放进去,然后重头戏来了-》新建包com.hello.hello,原来的包叫com.hello.word,之所以这样做,是我经历了一个痛苦的过程总结出来的,他给的头文件
com_hello_hello_HelloActivity.h //符合jni的规范,前面com_hello_hello是包名,后面HelloActivity是类名,注意在丙方这里叫类名,在乙方那里叫Activity的名字
能够看出来他的包结构,然后就建立一个和他一样的包,在这个包中新建一个和他一样的类,类中的方法按照jni规范能够得出来是什么,比如JNIEXPORT jstring JNICALL Java_com_hello_hello_HelloActivity_sayHello(JNIEnv *, jclass);//其中有一个方法是无参数函数sayHello
结构如图 - 类HelloActiviry.java的代码
package com.hello.hello; import android.app.Activity; import android.app.AlertDialog; import android.os.Bundle; public class HelloActivity { // static // { // System.loadLibrary("hello"); //实验证明在这里不需要引入包名也是可以的 // } public static native String sayHello(); // 第三方库函数 }
- android主程序Helloword2Acitiviry.java的代码
package com.hello.word; import com.hello.hello.HelloActivity; import android.app.Activity; import android.app.AlertDialog; import android.os.Bundle; public class Helloword2Activity extends Activity { static { System.loadLibrary("hello"); //引入包名 } @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); new AlertDialog.Builder( this ).setMessage(new HelloActivity().sayHello()).show();//实例化类方法直接调用 } }
- 运行android程序,注意你写的是android程序,不需要修改编译选项,运行如图,实验证明,利用android直接调用库是可以的
- 但是这种直接调用也是有弊端的,在第三篇中会介绍-》》》[第三篇:android利用jni调用第三方库——编写库android程序整合第三方库libhello.so到自己的库libhelloword.so]
4:下载demo[猛戳这里下载demo]