Android组件化retrofit,从零开始搭建Android组件化框架

本文介绍了组件化开发中的路由实现,如使用阿里巴巴的Arouter进行页面跳转和参数传递。同时,提到了在组件化环境中ButterKnife的使用技巧,需要注意避免使用最新版本并提供配置步骤。对于混淆方案,建议在app壳工程中集中混淆,以方便管理和调试。此外,文章还提及了Retrofit2和GreenDao的使用,以及未来将不断更新更多知识点。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

api rootProject.ext.dependencies["appcompat_v7"]

api rootProject.ext.dependencies["constraint_layout"]

api rootProject.ext.dependencies["cardview-v7"]

api rootProject.ext.dependencies["design"]

testApi rootProject.ext.dependencies["junit"]

androidTestApi rootProject.ext.dependencies["runner"]

androidTestApi rootProject.ext.dependencies["espresso_core"]

}

6 组件之间调用和通信

在组件化开发的时候,组件之间是没有依赖关系,我们不能在使用显示调用来跳转页面了,因为我们组件化的目的之一就是解决模块间的强依赖问题,假如现在要从A业务组件跳转到业务B组件,并且要携带参数跳转,这时候就需要引入“路由”的概念了.目前项目使用了阿里巴巴的Arouter路由,有兴趣的童鞋也可以去了解其他的"路由"框架,比如开源库的ActivityRouter, LiteRouter 路由框架 , AndRouter 路由框架 等.

7 组件化中的butterKnife的坑特别注意不要使用最新的8.8.1版本,而应该使用8.4.0 ,因为最新的版本好像不兼容组件化模式.按照8.4.0版本的方式依赖.

第一步:

在项目的buid.gradle中添加这两个依赖.buildscript {

dependencies {

classpath 'com.jakewharton:butterknife-gradle-plugin:8.4.0'

classpath 'com.neenbedankt.gradle.plugins:android-apt:1.8'

}

}

第二步:

在module的build.gredle 文件中的dependencies标签中添加annotationProcessor 'com.jakewharton:butterknife-compiler:8.4.0',

implementation 'com.jakewharton:butterknife:8.4.0',

第三步:

在module的build.gredle 文件中添加apply plugin: 'com.jakewharton.butterknife'

这三步就完成了butterKnife的接入了,如果你的Android studio 3.x 还没安装butterKnife的插件的,就先安装一下插件.组件化中的butterKnife的使用

1、用R2代替R findviewid@BindView(R2.id.view_pager)

ViewPager mViewPager;

@BindView(R2.id.bottom_navigation_view)

BottomNavigationView mBottomNavigationView;

@BindView(R2.id.nav_view)

NavigationView mNavView;

每次都要syn一下,才会生效的.

2、在click方法中同样使用R2,但是找id的时候使用R。@OnClick({R2.id.textView, R2.id.button1})    public void onViewClicked(View view) {        switch (view.getId()) {            case R.id.textView:                break;            case R.id.button1:                break;

}

}

3、特别注意library中switch-case的使用,在library中是不能使用switch- case 找id的,解决方法就是用if-else代替。@OnClick({R2.id.textView, R2.id.button1, R2.id.button2})    public void onViewClicked(View view) {        int i = view.getId();        if (i == R.id.textView) {

} else if (i == R.id.button1) {

} else if (i == R.id.button2) {

}

就这样通过几个简单的步骤基本就完成了组件化的配置了. 具体可以运行项目查看.

组件化项目的混淆方案

组件化项目的Java代码混淆方案采用在集成模式下集中在app壳工程中混淆,各个业务组件不配置混淆文件。集成开发模式下在app壳工程中build.gradle文件的release构建类型中开启混淆属性,其他buildTypes配置方案跟普通项目保持一致,Java混淆配置文件也放置在app壳工程中,各个业务组件的混淆配置规则都应该在app壳工程中的混淆配置文件中添加和修改。

之所以不采用在每个业务组件中开启混淆的方案,是因为 组件在集成模式下都被 Gradle 构建成了 release 类型的arr包,一旦业务组件的代码被混淆,而这时候代码中又出现了bug,将很难根据日志找出导致bug的原因;另外每个业务组件中都保留一份混淆配置文件非常不便于修改和管理,这也是不推荐在业务组件的 build.gradle 文件中配置 buildTypes (构建类型)的原因。

四,知识点汇总

1) Retrofit2 的封装

2) Greendao 的使用

...

该demo会持续优化更新,把知识点及工具类都汇总于该demo中,便于学习及日后查找.

** 如果你觉得这篇文章对你有帮助或启发,请点下关注,谢谢 _ **

感谢以下文章提供的帮助:

作者:tome869535144

链接:https://www.jianshu.com/p/ba32488f9555

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值