使用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…
·