组件化SDK

3,179 阅读5分钟

以下是我这个系列的相关文章,有兴趣可以参考一下,可以给个喜欢或者关注我的文章。

[Android]如何做一个崩溃率少于千分之三噶应用app--章节列表


如果一开始关注我的同学,应该有看过这一篇技术[Android]多module合成单一module技巧

为何要使用多module合一呢?

1.如果你使用的是组件化架构

2.你想将你的app封成插件aar(也就是别人说的sdk)。

*arr和jar的区别是,java你要打包将可以把代码打包成jar的包,而Android studio打包可以代码和资源都打包成aar文件,供外部调用

之前我介绍的文章中,说的是用了一个笨拙的使用python脚本合成一个module然后再进行打包。

近来我有同事发现,有一个新的开源库可以达到相同的效果,看来大神还是很多的。

Talk is too cheap,show you the code.

android-fat-aar

说一下重点吧,那个github的地址里面,点进去就会看到解析都是用英文,估计是外国的大神写的,但是木有提供中文讲解,估计会有人没看懂。


重点是fat-aar.gradle这个文件,这里提供两种方式

1.下源码copy到想要生成出aar的module里面的目录,build.gradle一样的层级就可以了

然后在build.gradle里面引用这个


2.或者直接引用


建议还是下载源码放到目录里面,有啥问题,自己也一目了然,不至于一面懵B

下一步就要将相关的功能module作出依赖了,这里需要使用embedded的关键字,为啥是这个关键字等下给大家解析


然后这样就成功了???

如果你在主module这样用估计你就可以看到以下的编译错误了,

到了这里估计你会查看packageReleaseResources这个属性是什么,然而你还是不清楚。

这里踩到的坑,这里是要将编译生成aar的sdk文件,那么我们需要将module从application变更为lib,这样才符合要求


倘若你设置了applicationId,那么也请你注释掉


还有在之前多module合一的文章中有提到过,不能使用swtich case的语句,因为这样会将变量声明会final属性的,aar不支持这样的语句,全部需要改为if else语句


好吧,做完这些之后,你需要跑gradle的命令,只需要跑你那个module里面的命令就可以了。


最终会在outputs文件夹,生成一个aar文件


你们所要的sdk就这样生成了。

相信有很多人已经猜到关键文件是fat-aar.gradle这个文件了,他是使用gradle作为编译脚本。

那么我们还是这个文件里面,究竟写了什么吧

对于我这种gradle小白,也是要认真考究一番才能解析到大家明白。

Gradle对依赖进行分组,允许编译时使用一组依赖,运行时使用另一组依赖。每一组依赖称为一个Configuration,

声明embedded为一类依赖

同时会添加到compile里面


然后定义一些变量,例如jar文件,aar文件夹,还有R文件


然后定义一些生成的文件夹


执行打包前需要运行afterEvaluate,完成一些额外的配置

它先会指定你的aar文件夹的路径,就是引用的lib的路径,

如果生成的是aar会加入到embeddedAarDirs的数组列表,如果是jar会加到embeddedJars的数组列表


然后需要指定一些Assets,资源,JNI,Mainifests,混淆,java文件的依赖和生成方法,需要依赖于Gradle构建app流程里面。

这里需要科普一下基础gradle构建基础

(1) XX.dependsOn YY 意思是 YY运行在XX之前

(2) XX.finalizedBy YY 意思是YY运行在XX之后

下面这些都是gradle的构建的流程

prepareReleaseDependencies 加载 远端的依赖 加载 所有的需要从远端下载的依赖

processReleaseManifest 依赖prepareReleaseDependencies 生成 AndroidManifest文件 在build/incremental/manifest/full/release

processReleaseResources 生成resources-release.ap_在 build/intermediates/resources下

compileReleaseJavaWithJavac 使用Javac编译Java代码


还有更多的构建流程可以查看Gradle 构建流程

遍历数组中各个lib的将srcDirs加入每个的资源Assets目录


都是类似这样的合并module里面的生成。

其实都是通过脚本的思想合并,只是他是通过gradle的构建合并,而我之前是通过python脚本来完成合并,再利用gradle打包。

关于gradle文件Application和Library之间的自由切换,我也写好了封装,想参照的话,请下载我写ModuleBus的gradle文件。

如果踩到坑,可以在留下你的评论,我及时处理。


*****2017.3.1*****

在我的QQ讨论中的同学,的确有人已经踩到坑了。


这里说明一下,如果lib依赖的库也有一样的资源的命名,lib的命名会将库内的资源id号给替换掉,其原来R的索引就不会存在。

(1)如果是一开始构建工程的时候,可以查看我Gradle组件化优化的最后一点处理。

(2)如果是重构工程的,只能使用android stuido将冲突的资源一个一个批量替换了。


我建立了一个关于Android架构学习的群,里面可以进一步进行组件化学习和架构思想的的交流。

群号是316556016,也可以扫码进群。我在这里期待你们的加入!!!