1.环境介绍
Android Studio 2.0
jdk 1.7
正题开始
创建工程我就不说了,大家都会
工程创建完在app的build.gradle中添加代码
defaultConfig {
........
ndk {
moduleName "JniTest"//这是要生成的.so的文件名
abiFilters "armeabi", "armeabi-v7a", "x86"//这个就是各个平台了
ldLibs "log"//打log需要这个
}
}
这里注意一下ndk这一段代码要加到defaultConfig 这一段里
报下面这个的时候点那些蓝色的字就OK了,会自动帮我们完成
没有报错的在项目的gradle.properties最下面加上 android.useDeprecatedNdk=true
接下来,我们创建一个类,用来承接jni的关系,例如我创建的类叫HelliJni
public class HelloJni {
static {
System.loadLibrary("JniTest");//这里加载的库名当然和我们刚在build.gradle中配置的一样
}
public static native String testString();//这是我们JNI的方法
}
好了,接下来我们Make Project来生成.class文件
class文件生成后可以在下面路径找到
好了,有了class文件,我们就可以来真正的jni了,生成头文件,点击AS左下角的Terminal
依次输入下面的代码
cd app
cd src
cd main
进入到main目录下
javah -d jni -classpath '你的SDK目录';..\..\build\intermediates\classes\debug ‘你的包名和类名’
例如我的是这样:
敲完回车没报什么错的话就恭喜你了,如果报错了自行检查NDK环境
这样头文件就生成了
接下来,我们在创建一个main.c,然后把那个头文件的东西复制到main.c里,实现方法返回一个字符串
/* DO NOT EDIT THIS FILE - it is machine generated */
#include
/* Header for class cn_bertsir_jnitest2_HelloJni */
#ifndef _Included_cn_bertsir_jnitest2_HelloJni
#define _Included_cn_bertsir_jnitest2_HelloJni
#ifdef __cplusplus
extern "C" {
#endif
/*
* Class: cn_bertsir_jnitest2_HelloJni
* Method: getString
* Signature: ()Ljava/lang/String;
*/
JNIEXPORT jstring JNICALL Java_cn_bertsir_jnitest2_HelloJni_testString
(JNIEnv *env, jclass jobj){
return (*env)->NewStringUTF(env,"JNI test");
}
#ifdef __cplusplus
}
#endif
#endif
完成时候,我们Rebuild Project,就可以在如下路径看到我们亲切的.so文件了
怎么使用这些.so文件这里也提一下,在app的build.gradle文件中指定路径
sourceSets {
main {
jniLibs.srcDirs = ['libs']
}
}
这一段写在android{}里面,写完这个,我们可以把我们刚才生成的那个so复制到和src同级的libs目录里,好了,大功告成,下来就是调用了,我在我的MainActivity中低矮用那个jni的方法
好了,运行,大功告成!