转: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。能够说多看看官方文档是多么的重要。