Andorid Studio NDK 開發 - NDK 開發利器 gradle-experimental

使用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的便利吧!

##環境要求:

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之前需要確認:

NDK包是否下載

NDK的環境變量是否配置

能夠正確運行命令:ndk-build。

以上配置完成之后,在./app/build.gradle中配置要配置android.ndk的相關內容:

model {

android {

compileSdkVersion23buildToolsVersion"23.0.2"ndk{

moduleName"experiment"http://toolchain = 'clang'abiFilters.addAll(['armeabi','armeabi-v7a'])//this is defaultldLibs.addAll(['log']);

}

}

}

這里定義的moduleName就是后面生成的NDK的包名。我們還可以指定其編譯成對應的cpu,編譯工具,使用的類庫等。

##源代碼配置

默認情況下,在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開發了。

##使用gradle experimental

在java里面定義一個native方法,native標識的方法會需要在jni中實現,可以在java中調用,還需要加載NDK生成的.so類庫。

publicclassNativeUtil{//加載類庫static{

System.loadLibrary("experiment");

}

publicstaticnativeStringfirstNative();

}

這個時候編譯器會出現一個紅色的警告,因為定義的native方法編譯器并沒有找到對應的實現:

編譯器警告沒有實現native方法

可以使用alt+enter鍵可以自動生成jni文件:

生成jni文件

注意這個時候生成直接的是experiment.c,沒有.h文件,生成的jni文件的內容:

**#include **

JNIEXPORT jstring JNICALL

Java_com_jjz_NativeUtil_firstNative(JNIEnv *env, jclass type) {

// TODO

return (*env)->NewStringUTF(env, returnValue);

}

自動生成的jni文件并沒有具體的實現,需要修改jni文件讓其返回一段測試內容:

>JNIEXPORT jstring JNICALLJava_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-native

除了app以外,多出了一個app-native的菜單,這個選項可以直接編譯NDK源碼之后再運行Android,這樣編寫完NDK之后可以運行了,不需要再進行ndk-build:

在Java中調用NativeUtil.firstNative,會得到jni中寫好的返回值:i am test,在這個例子中,我讓這個這字段顯示在主頁面上。

可以看到使用gradle-experimental開發NDK,不需要再做復雜的配置,自動化native方法,不需要自定義.h頭文件,對開發更加友好。

文中源代碼地址:https://github.com/jjz/android/tree/master/experimental

from:https://juejin.im/post/58d997dd44d90400694754d2

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容