轉:http://blog.csdn.net/qiujuer/article/details/24209457android
爲了適應潮流使用Android Studio仍是有半年多了!app
對於從Eclipse遷移項目到Android Studio中添加.jar文件和.so文件無疑是一件很重要也是很頭疼的問題!gradle
在最新版本中,默認是自動打包libs下面的全部.jar文件的,因此jar不用多講了。ui
加入.SO(這個是要看你的項目Gradle版本)spa
提示:都是設置build.gradle文件.net
(1)老版本,好像是指0.5之前的,具體不太記得了,方法以下:code
- task copyNativeLibs(type: Copy) {
- from(new File(project(':MyProject').buildDir, 'native-libs')) { include '**/*.so' }
- into new File(buildDir, 'native-libs')
- }
-
- tasks.withType(Compile) { compileTask -> compileTask.dependsOn copyNativeLibs }
-
- clean.dependsOn 'cleanCopyNativeLibs'
-
- tasks.withType(com.android.build.gradle.PackageApplicationTask) { pkgTask ->
- pkgTask.jniDir new File(buildDir, 'native-libs')
- }
(2)新版本,具體版本號忘記了,反正若是你下載的是最新的那麼自帶就是最新的編譯器。blog
這個版本我如今知道的有三種辦法作到打包.SO文件ip
(2.1)打包前先生成.Jar文件後自動解包到apk文件ci
- task nativeLibsToJar(type: Zip, description: 'create a jar archive of the native libs') {
- destinationDir file("$buildDir/native-libs")
- baseName 'native-libs'
- extension 'jar'
- from fileTree(dir: 'libs', include: '**/*.so')
- into 'lib/'
- }
-
- tasks.withType(Compile) {
- compileTask -> compileTask.dependsOn(nativeLibsToJar)
- }
下面一句話就是打包生成目錄(build\native-libs)中的.jar文件
- compile fileTree(dir: "$buildDir/native-libs", include: 'native-libs.jar')
(2.2)手動生成.Jar文件後自動解包到apk文件
這個方式須要本身手動進行.SO文件壓縮,具體步驟爲:將全部須要使用的.so文件壓縮爲.zip文件(zip中的文件目錄結構爲: lib/armeabi/*.so)而後把zip文件後綴改成.Jar而後放到libs生成apk就ok
默認就是自動打包全部.Jar文件:
- dependencies {
- compile fileTree(dir: 'libs', include: '*.jar')
- }
(2.3)這也就是如今我正在使用的方式(推薦),其實弄了大半天無非就是把.SO文件打包到APK的lib文件夾中,假如仔細閱讀了Gradle的使用方法,天然就知道其實Gradle官方在新版已經自動實現了打包.SO文件的.很簡單級就是在配置的android節點下加入下面的內容就ok:
- sourceSets {
- main {
- jniLibs.srcDirs = ['libs']
- }
- }
其餘地方無需修改,整個項目的配置文件以下:
- apply plugin: 'android'
-
- android {
- compileSdkVersion 19
- buildToolsVersion "19.0.0"
-
- defaultConfig {
- minSdkVersion 16
- targetSdkVersion 19
- versionCode 1
- versionName "1.0"
- }
- buildTypes {
- release {
- runProguard false
- proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.txt'
- }
- }
- sourceSets {
- main {
- jniLibs.srcDirs = ['libs']
- }
- }
- }
-
- dependencies {
- compile fileTree(dir: 'libs', include: ['*.jar'])
- }
這不就是很簡單麼,無需手動打包,也無需很複雜的打包拷貝命令,簡單的操做就ok。能夠說多看看官方文檔是多麼的重要。