android的JNI配置
阿新 • • 發佈:2018-12-21
忙了一整天,才整了出來。
android 正確引入SO庫的方法
相信很多朋友在使用Android studio開發中,遇到過如何引入第三方so檔案的問題,然而第三方官方僅僅給出了ADT環境下的整合方式。
Android studio中預設使用的是gradle編譯方式,與ADT編輯方式不一樣,那麼so檔案應當如何引入呢?
其實很簡單。這裡以整合JPUSH為例,看一下so檔案如何引入到編譯環境,最終到JNI直接可以呼叫該so檔案。
首先,在我們的Module的根目錄中建立libs目錄,將jpush整合SDK中的so檔案分別拷入,截圖如下:
然後就是編寫我們的build.gradle檔案。
關於so檔案引入的配置很簡單,程式碼配置如下:
[html] view plain copy print ?
- task nativeLibsToJar(type: Zip, description: "create a jar archive of the native libs") {
- destinationDir file("$projectDir/libs")
- baseName "Native_Libs2"
- extension "jar"
- from fileTree(dir: "libs", include: "**/*.so")
- into "lib"
- }
- tasks.withType(JavaCompile) {
- compileTask -> compileTask.dependsOn(nativeLibsToJar)
- }
自定義一個任務,在其中指定專案所依賴的so檔案的目錄,這裡用了**/*.so來寫,為了省事,指定需要拷入的目錄 into "lib",那麼動態執行庫就被拷入到lib目錄中。
完整的build.gradle檔案如下:
[html] view plain copy print ?
- apply plugin: 'com.android.application'
- android {
- compileSdkVersion 21
- buildToolsVersion "21.1.0"
- defaultConfig {
- applicationId "com.wujay.footerballstar"
- minSdkVersion 8
- targetSdkVersion 21
- versionCode 1
- versionName "1.0"
- }
- buildTypes {
- release {
- runProguard false
- proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
- }
- }
- task nativeLibsToJar(type: Zip, description: "create a jar archive of the native libs") {
- destinationDir file("$projectDir/libs")
- baseName "Native_Libs2"
- extension "jar"
- from fileTree(dir: "libs", include: "**/*.so")
- into "lib"
- }
- tasks.withType(JavaCompile) {
- compileTask -> compileTask.dependsOn(nativeLibsToJar)
- }
- }
- dependencies {
- compile fileTree(dir: 'libs', include: ['*.jar'])
- compile 'com.android.support:appcompat-v7:21.0.0'
- compile files('libs/jpush-sdk-release1.7.2.jar')
- compile files('libs/umeng_sdk.jar')
- compile files('libs/libammsdk.jar')
- }
基於有人在評論區提問,這裡補充一下,有一個更為快捷輕快的配置方法
那就是在build.gradle配置中,配置如下的資訊:
sourceSets { main { jniLibs.srcDirs = ['libs'] } }
你的so包可以放在lib目錄下,跟jar包放在同樣的目錄,如lib/armeabi/libjpush172.so。