Android studio中正確引入so檔案的方法
阿新 • • 發佈:2019-02-17
相信很多朋友在使用Android studio開發中,遇到過如何引入第三方so檔案的問題,然而第三方官方僅僅給出了ADT環境下的整合方式。
Android studio中預設使用的是gradle編譯方式,與ADT編輯方式不一樣,那麼so檔案應當如何引入呢?
其實很簡單。這裡以整合JPUSH為例,看一下so檔案如何引入到編譯環境,最終到JNI直接可以呼叫該so檔案。
首先,在我們的Module的根目錄中建立libs目錄,將jpush整合SDK中的so檔案分別拷入,截圖如下:
然後就是編寫我們的build.gradle檔案。
關於so檔案引入的配置很簡單,程式碼配置如下:
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檔案如下:
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。