使用NDK開發(fā)有件比較麻煩的事情就是編寫Application.mk和Android.mk的,而Android Studio 的插件gradle-experimental就是用來解決這個這個問題的。使用gradle-experimental插件可以不用再編寫*.mk文件的情況下進(jìn)行NDK開發(fā)徘钥。
gradle-experimental是Android Studio的一個實驗性的項目呈础,是基于gradle的一個插件,主要用來自動化NDK的配置實現(xiàn)而钞,無需自己編寫Application.mk和Android.mk,對于調(diào)試NDK項目也更加的友好蓝仲,支持對于NDK的Debug。
下面就來嘗試下gradle-experimental的便利吧!
##環(huán)境要求:
Android Studio > 2.0
gradle>2.10
Android NDK r10e
Build Tools > 19.0.0
##配置gradle-experimental
添加gradle-experimental依賴
在項目的主目錄下./build.gradle中替換掉以前的build tools,使用最新版本的gradle-experimental
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
apply plugin: "com.android.model.application"
配置model{}
增加model{},android的配置在model{}中果元。
model {
android {
compileSdkVersion23buildToolsVersion"25.0.0"ndk {
moduleName"experiment"http://stl = 'gnustl_static'//toolchain = 'clang'//todo 指定cpuabiFilters.addAll(['armeabi','armeabi-v7a'])//this is defaultldLibs.addAll(['log']);
}
defaultConfig {
applicationId"com.jjz"http://需要使用.apiLevelminSdkVersion.apiLevel15targetSdkVersion.apiLevel23versionCode1versionName"1.0"}
buildTypes {
release {
minifyEnabledfalse}
}
}
}
##配置NDK
在配置NDK之前需要確認(rèn):
NDK包是否下載
NDK的環(huán)境變量是否配置
能夠正確運行命令:ndk-build而晒。
以上配置完成之后阅畴,在./app/build.gradle中配置要配置android.ndk的相關(guān)內(nèi)容:
model {
android {
compileSdkVersion23buildToolsVersion"23.0.2"ndk{
moduleName"experiment"http://toolchain = 'clang'abiFilters.addAll(['armeabi','armeabi-v7a'])//this is defaultldLibs.addAll(['log']);
}
}
}
這里定義的moduleName就是后面生成的NDK的包名。我們還可以指定其編譯成對應(yīng)的cpu贱枣,編譯工具,使用的類庫等钠乏。
##源代碼配置
默認(rèn)情況下春塌,在src/main/jni下使用的是c/c++文件。也可以在model.android中指定:
model {
android {
compileSdkVersion23buildToolsVersion"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開發(fā)了。
##使用gradle experimental
在java里面定義一個native方法,native標(biāo)識的方法會需要在jni中實現(xiàn)命辖,可以在java中調(diào)用,還需要加載NDK生成的.so類庫。
publicclassNativeUtil{//加載類庫static{
System.loadLibrary("experiment");
}
publicstaticnativeStringfirstNative();
}
這個時候編譯器會出現(xiàn)一個紅色的警告尔许,因為定義的native方法編譯器并沒有找到對應(yīng)的實現(xiàn):
編譯器警告沒有實現(xiàn)native方法
可以使用alt+enter鍵可以自動生成jni文件:
生成jni文件
注意這個時候生成直接的是experiment.c,沒有.h文件味廊,生成的jni文件的內(nèi)容:
**#include **
JNIEXPORT jstring JNICALL
Java_com_jjz_NativeUtil_firstNative(JNIEnv *env, jclass type) {
// TODO
return (*env)->NewStringUTF(env, returnValue);
}
自動生成的jni文件并沒有具體的實現(xiàn)棠耕,需要修改jni文件讓其返回一段測試內(nèi)容:
>JNIEXPORT jstring JNICALLJava_com_jjz_NativeUtil_firstNative(JNIEnv **env, jclass type) {? ? char chars[] ="i am test";return(*env)->NewStringUTF(env, chars);}
這樣就完成了一個JNI開發(fā)調(diào)用,定義了一個native方法辉巡,在.c文件中對其進(jìn)行了實現(xiàn)蕊退。如果沒有g(shù)radle experimental插件的話憔恳,現(xiàn)在就需要使用ndk-build命令編譯成.so文件净蚤,然后在運行Android項目,調(diào)用方法看下是否能夠調(diào)用成功,而現(xiàn)在有了gradle experimental就變的了如此簡單今瀑,下一步就需要直接運行就可以了放椰,對!就是直接運行砾医,省略了中間的ndk-build環(huán)節(jié),就和編寫Java代碼一樣压恒,直接運行即可错邦。
##直接運行
打開Toolbar中的運行配置菜單,可以看到:
app-native
除了app以外伦吠,多出了一個app-native的菜單魂拦,這個選項可以直接編譯NDK源碼之后再運行Android,這樣編寫完NDK之后可以運行了芯勘,不需要再進(jìn)行ndk-build:
在Java中調(diào)用NativeUtil.firstNative,會得到j(luò)ni中寫好的返回值:i am test,在這個例子中,我讓這個這字段顯示在主頁面上衡怀。
可以看到使用gradle-experimental開發(fā)NDK,不需要再做復(fù)雜的配置安疗,自動化native方法,不需要自定義.h頭文件荐类,對開發(fā)更加友好掉冶。
文中源代碼地址:https://github.com/jjz/android/tree/master/experimental
from:https://juejin.im/post/58d997dd44d90400694754d2