使用NDK开发有件比较麻烦的事情就是编写Application.mk
和Android.mk
的,而Android Studio 的插件gradle-experimental
就是用来解决这个这个问题的。使用gradle-experimental
插件能够不用再编写*.mk
文件的状况下进行NDK开发。gradle-experimental
是Android Studio的一个实验性的项目,是基于gradle的一个插件,主要用来自动化NDK的配置实现,无需本身编写Application.mk
和Android.mk
,对于调试NDK项目也更加的友好,支持对于NDK的Debug。
下面就来尝试下gradle-experimental
的便利吧!javascript
##环境要求:java
##配置gradle-experimentalandroid
添加gradle-experimental
依赖
在项目的主目录下./build.gradle
中替换掉之前的build tools
,使用最新版本的gradle-experimental
c++
buildscript {
repositories {
jcenter()
}
dependencies {
classpath "com.android.tools.build:gradle-experimental:0.7.0"
}
}复制代码
替换插件(plugin)
使用gradle-experimental
就不能再使用com.android.application
了,须要使用com.android.model.application
替代。
在项目主目录下的./app/build.gradle
中更改plugin
git
apply plugin: "com.android.model.application"github
配置model{}api
增长model{}
,android的配置在model{}
中。app
model {
android {
compileSdkVersion 23
buildToolsVersion "25.0.0"
ndk {
moduleName "experiment"
//stl = 'gnustl_static'
//toolchain = 'clang'
//todo 指定cpu
abiFilters.addAll(['armeabi', 'armeabi-v7a']) //this is default
ldLibs.addAll([ 'log']);
}
defaultConfig {
applicationId "com.jjz"
//须要使用.apiLevel
minSdkVersion.apiLevel 15
targetSdkVersion.apiLevel 23
versionCode 1
versionName "1.0"
}
buildTypes {
release {
minifyEnabled false
}
}
}
}复制代码
##配置NDK
在配置NDK以前须要确认:工具
可以正确运行命令:ndk-build
。测试
以上配置完成以后,在./app/build.gradle
中配置要配置android.ndk
的相关内容:
model {
android {
compileSdkVersion 23
buildToolsVersion "23.0.2"
ndk{
moduleName "experiment"
//toolchain = 'clang'
abiFilters.addAll(['armeabi', 'armeabi-v7a']) //this is default
ldLibs.addAll([ 'log']);
}
}
}复制代码
这里定义的moduleName
就是后面生成的NDK的包名。咱们还能够指定其编译成对应的cpu,编译工具,使用的类库等。
##源代码配置
默认状况下,在src/main/jni
下使用的是c/c++文件。也能够在model.android
中指定:
model {
android {
compileSdkVersion 23
buildToolsVersion "23.0.2"
ndk {
moduleName "experiment"
}
sources {
main {
jni {
source {
srcDir "src/main/jni"
}
}
java{
source{
srcDir "src/main/java"
}
}
}
}
}
}复制代码
在sources
分别指定了java
源代码和jni
源代码的目录。
以上的配置完成以后,就可使用gradle experimental
开始NDK开发了。
##使用gradle experimental
在java里面定义一个native
方法,native标识的方法会须要在jni中实现,能够在java中调用,还须要加载NDK生成的.so
类库。
public class NativeUtil {
//加载类库
static {
System.loadLibrary("experiment");
}
public static native String firstNative();
}复制代码
这个时候编译器会出现一个红色的警告,由于定义的native
方法编译器并无找到对应的实现:
可使用alt+enter
键能够自动生成jni文件:
注意这个时候生成直接的是experiment.c
,没有.h
文件,生成的jni文件的内容:
**#include <jni.h>**
JNIEXPORT jstring JNICALL
Java_com_jjz_NativeUtil_firstNative(JNIEnv *env, jclass type) {
// TODO
return (*env)->NewStringUTF(env, returnValue);
}复制代码
自动生成的jni文件并无具体的实现,须要修改jni文件让其返回一段测试内容:
>JNIEXPORT jstring JNICALL
Java_com_jjz_NativeUtil_firstNative(JNIEnv **env, jclass type) {
char chars[] = "i am test";
return (*env)->NewStringUTF(env, chars);
}复制代码
这样就完成了一个JNI开发调用,定义了一个native
方法,在.c
文件中对其进行了实现。若是没有gradle experimental
插件的话,如今就须要使用ndk-build
命令编译成.so
文件,而后在运行Android项目,调用方法看下是否可以调用成功,而如今有了gradle experimental
就变的了如此简单,下一步就须要直接运行
就能够了,对!就是直接运行,省略了中间的ndk-build
环节,就和编写Java代码同样,直接运行
便可。
##直接运行
打开Toolbar
中的运行配置菜单,能够看到:
app
之外,多出了一个
app-native
的菜单,这个选项能够直接编译NDK源码以后再运行
Android
,这样编写完
NDK
以后能够运行了,不须要再进行
ndk-build
:
NativeUtil.firstNative
,会获得jni中写好的返回值:
i am test
,在这个例子中,我让这个这字段显示在主页面上。
能够看到使用gradle-experimental
开发NDK,不须要再作复杂的配置,自动化native方法,不须要自定义.h头文件,对开发更加友好。
文中源代码地址:github.com/jjz/android…
·