Android Studio] Gradle项目中添加JNI生成文件(.so文件)
转:http://blog.csdn.net/qiujuer/article/details/24209457
为了适应潮流使用Android Studio还是有半年多了!
对于从Eclipse迁移项目到Android Studio中添加.jar文件和.so文件无疑是一件很重要也是很头疼的问题!
在最新版本中,默认是自动打包libs下面的所有.jar文件的,所以jar不用多讲了。
加入.SO(这个是要看你的项目Gradle版本)
提示:都是设置build.gradle文件
(1)老版本,好像是指0.5以前的,具体不太记得了,方法如下:
- 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)新版本,具体版本号忘记了,反正如果你下载的是最新的那么自带就是最新的编译器。
这个版本我现在知道的有三种办法做到打包.SO文件
(2.1)打包前先生成.Jar文件后自动解包到apk文件
- 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。可以说多看看官方文档是多么的重要。
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。