正文
aar打包
在cpp中编译的so不会被打包到aar中,这时候需要把编译出来的so,拷贝到jniLibs中,并配置不编译cmakelist,直接从src/main/jniLibs中找
sourceSets {
main {
jniLibs.srcDirs = ['libs','src/main/jniLibs']
}
}
/*externalNativeBuild {
cmake {
path file('src/main/cpp/CMakeLists.txt')
version '3.10.2'
}
}*/
在android中引入aar
1)在app/libs目录下导入aar
- 在module的build.gradle中配置
repositories {
flatDir {
dir 'libs'
}
}
dependencies {
implementation(name:'lib-hw-ffmpeg', ext:'aar')
...
}
不同module依赖多个aar问题解决方案
在Android Studio的使用过程中,发现这么一个问题:
创建项目后,会生成第一个module:app。
module:app 依赖了 module:b
module:b 依赖了 module:c
如果没有特殊依赖,此时编译是不会产生任何问题的。
接着,module:b 依赖 b/libs/xxx.aar。按常规处理,在b的build.gradle文件中应该添加
dependencies {
compile(name: ‘xxx’, ext: ‘aar’)
}
repositories {
flatDir {
dirs ‘libs’
}
}
此时b可以正确依赖xxx.aar
此时编译,发现报错,提示:app的build.gradle中木有找到xxx.aar
(因为app依赖了b,所以对于b中的依赖得完全能找到,所以此时要在app的build.gradle中添加依赖)
dependencies {
compile(name: ‘xxx’, ext: ‘aar’)
}
repositories {
flatDir {
dirs ‘libs’
}
}
此时编译,发现仍然报错,提示:app的build.gradle中木有找到xxx.aar 并没有什么卵用啊
(在网上一篇文章的帮助下发现,那是因为flatDir指定的路径是libs,只会在app本身的libs中查找,为了找到b中的xxx.aar,得提供正确路径)
理所当然的采用相对路径
dirs ‘…/b/libs’
再次编译,成功执行
如果此时c中又有aar需要依赖肿么办?或者app本身有aar肿么办?那就是同时指定不同的查找路径
repositories {
flatDir {
dirs ‘libs’,‘…/b/libs’,‘…/c/libs’
}
}
over~~