为了适应潮流使用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。可以说多看看官方文档是多么的重要。

原创作品,转载请注明出处!

    QIUJUER([email protected])


更多相关文章

  1. 没有一行代码,「2020 新冠肺炎记忆」这个项目却登上了 GitHub 中
  2. 一款常用的 Squid 日志分析工具
  3. GitHub 标星 8K+!一款开源替代 ls 的工具你值得拥有!
  4. RHEL 6 下 DHCP+TFTP+FTP+PXE+Kickstart 实现无人值守安装
  5. Linux 环境下实战 Rsync 备份工具及配置 rsync+inotify 实时同步
  6. 不吹不黑!GitHub 上帮助人们学习编码的 12 个资源,错过血亏...
  7. 《Android(安卓)Studio开发实战 从零基础到App上线》第一版的资
  8. eclipse android 迁移到android studio3.21 升级过程中这样操作(
  9. Android的dex热修复的实现基本原理

随机推荐

  1. Android View添加 Listener 小技巧示例
  2. Flutter 与 Android
  3. Android Jni示例
  4. Android studio 连接数据库小经历遇到的
  5. Android studio添加第三方类库时出现的版
  6. android编译错误,Android requires compil
  7. 安卓开发38:安卓的滚动条相关属性
  8. RelativeLayout的16种特有属性
  9. Android中使用Universal-Image-Loader图
  10. Android 5.1系统禁止通知状态栏下拉