一、打包 aar
1、单个模块打包
打开
Gradle
工具窗口,找到Android Library
模块. 在build
任务中双击assemble
.执行成功后,在
mylibrary/build/outputs/aar
目录下找到aar
包.
默认 Debug
和 Release
的 AAR
包都会打出来,当然你也可以选择只打 Debug
的包,双击 assembleDebug
任务就可以了. 只打 Release
的包同理.
2、多个模块打包
当要打包的模块又依赖了其它几个模块时,常常需要把它们打包成一个 aar
。多模块打包使用 fat-aar,打包关键步骤如下:
将下载好的
fat-aar.gradle
文件添加到对应的模块目录中,并在build.gradle
中引入apply from: 'fat-aar.gradle'
。或直接引用apply from: 'https://raw.githubusercontent.com/adwiv/android-fat-aar/master/fat-aar.gradle'
添加要打包的工程,使用
embedded
关键字。示例代码如下:apply from: 'fat-aar.gradle' dependencies { ... embedded project(':DynamicPageLibrary') embedded project(':VideoPlayerLib') embedded project(':AudioPlayLibrary') embedded project(':BaseCloudMusicResource') }
步骤同上《单个模块打包》一致。
二、引入 aar
方法一、通过 libs 引入到 app 中
把
aar
文件放在libs
目录下-
repositories { flatDir { dirs 'libs' } }
之后通过如下方式引入
dependencies { compile(name:'test',ext:'aar') }
Rebuild project
如果发现引入后无法使用,重启 Android studio
方法二、把 aar
作为一个库工程的方式引入
当项目中库工程较多且依赖关系比较复杂时,最好采用这一种方式。如:某一个库工程也要引入这个 aar
时。
菜单栏
-> File
-> New
-> New Module
-> Import .Jar/.AAR Package
-> Next
-> 选择 File name
的文件 -> Subproject name
命名工程
-> Finish
创建完成后是一个工程,工程中包括 aar
文件和 build.gradle
文件。build.gradle
文件内容如下:
configurations.create("default")
artifacts.add("default",file('musiclibrary_20170622.aar'))
三,遇到的问题
Non-constant Fields in Case Labels
原因:在 Android Library 中不能使用
switch case
解决:改成用
else if
,如下图:java.lang.IllegalArgumentException: No view found for id 0x7f0d013d () for fragment TestFragment
描述:在项目中引用了库里的
fragment
,在运行后抛出了找不到view
的异常。但是在 Demo 项目中运行是没有问题的。原因:库里
fragment
的layoutID
与项目中另外一个Fragment
的layoutID
名字相同,导致项目中的布局会覆盖库中的布局。。解决:修改为不同的名称。在库中要注意资源名称可能与项目同名的问题,比如在库中的资源文件都添加前缀或后缀,或较长不容易重复的名字。同名的资源文件只会存在一个,根据库的嵌套关系,外层会覆盖内层的资源文件。