期待已久的android studio 2.2正式版本终于发布了,as新增了对NDK的支持,在以前的版本对NDK的支持一直是as的一个短板,现在代码关联、提示、打包都没问题,以后再也不用eclipse和as之间来回切换了。
一、NDK环境配置
- 下载最新的2.2版本 ,或者直接升级
- gradle classpath 'com.android.tools.build:gradle:2.2.0'
新建一个工程->File->project structure 配置你的ndk路径
在local.propertise里面:
ndk.dir=$you sdk path$\sdk\ndk-bundle(注意这里是双斜杠,网页自动转换显示不出来)
在main下新建一个jni文件夹
新建一个类,声明native方法:
在项目的gradle中添加
android {
...
ndk {
moduleName "jni_test" //编译生成so库的名字,注意不要lib,和.so加进来 ,而且要和上面loadLibrary里面的参数一致
abiFilters "armeabi","armeabi-v7a"//编译支持的平台
}
}
生成.h头文件
然后clean project 再rebuild project 生成class文件,这时候打开如下图的文件夹看是否生成了classes文件夹,没有生成请重新来过。
再打开Terminal输入指令
cd app/build/intermediates/classes/debug
然后再输入指令
javah -jni xxxxx.JniUtils
注意 这里javah -jni后面跟的是JniUtils类的全路径,如果javah报不存在之类的,是你的java环境没有配置好。
这时候打开classes/debug下面的文件发现多了一个文件xxxx.h,把生成的.h文件复制或者剪切到jni文件夹下面去,新建一个c类随便取一个名字,添加代码如下
include "jni_test.h"
Java_xc_com_ndk_1accessjavafield_JniTest_accessMethod
(JNIEnv *env, jobject jobj){
return (*env)->NewStringUTF(env,"hello world form c");
}
这里发现头文件#include <jni.h>报红色,这是因为没有关联源码,需要在工程的gradle里面配置如下:
android {
...
externalNativeBuild {
ndkBuild {
path 'src/main/jni/Android.mk'
}
}
sourceSets.main {
jni.srcDirs = []
// jniLibs.srcDirs = ['libs']
jniLibs.srcDirs = ['src/main/jniLibs']//设置目标的so存放路径
}
}
这是你还需要在jni里面建一个.mk文件来配置编译你的c代码
然后好像在gradle.propertise里面的android.useDeprecatedNdk=true属性貌似也不用加了,为了保险还是加上吧(o(╯□╰)o)
然后使用:
String str = new JniTest().accessMethod();
TextView tv = (TextView) findViewById(R.id.tv);
tv.setText(str);
这里改动比较大的是编译生成的so库在这里:
[10.24跟新:貌似2.2.2这个文件换到了app\build\intermediates\ndkBuild]
然后在main新建jniLibs文件夹,拷贝so文件
然后注释掉这里删掉编译生成的so库看能不能运行,因为.externalxxx文件夹就是mk文件配置成的:
二、
好了,最后有点小技巧也分享个大家:
大家有没有感到每次生成.h文件和去找方法签名的时候感觉到特别的麻烦,还要找class文件啊指令什么的,从此之后让大家解放双手:
一、打开as设置界面,进入External Tools
参数
Program: $JDKPath$/bin/javah
Parameters: -classpath . -jni -o $ModuleFileDir$\src\main\jni\$Prompt$ $FileClass$
Working directory: $ModuleFileDir$/src/main/java
还有一种写法:-classpath . -jni -d $ModuleFileDir$/src/main/jni $FileClass$
然后使用:
是不是很酷!!
二.自动生成签名:
套路都是一样的其他的不在赘述
----end-----