[Android]如何做一个崩溃率少于千分之三噶应用app(13)-Activity分发功能module架构...

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

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


近来业务忙得不亦乐乎,因为年底要研发发红包了,哈哈。

相信有关注我的文章的人,已经等了很久了,我也在这一章发我最大的福利。(酝酿了这么久终于要发大招啦)

看完我上一节关于Activity的module间跳转跳转后,是否对大家有一定的启发呢?

**************

如果Android研发已经开发有三五年经验,很多人经历过4.0 Fragment的出现后,就会有人编写到一些关于Fragment的架构,例如单Activity+多Fragment,多Activity+多Fragment的架构。再后来MVP架构的盛行,MVVM架构的提出,然后通过到工具的变迁从Eclipse到Android studio,产生组件化架构开发。

架构的变更,系统代码框架的变化,研发的工具换代,新的架构思想的普及,项目一年一次的大版本的变化。

这些都会让你觉得你重新思考是否需要重构现在的代码,重构代码并不是易事。你需要重新绘制你代码的线路图,和新架构思想的线路图。框架是要规范各种开发,基础在于设计模式,各种设计模式利用的场景。

Android的源码是很好例子,其每年都会有新的变更,更高效更高质量的代码思想,很多时候起源都是对源码的熟读和利用。以前你觉得越来越多程序猿去研究源码,费事费力,做app为何会需要研究这些东西?你觉得设计模式都是从哪里来的,为何需要设计模式,业务只要用好if else已经足够自己饮醉了。

当你经历了这些,你需要用一个全新的思维方式看待那些你认为熟悉的代码。从功能到架构,看到起源点。

组件化模块化架构的,最终还是离不开Activity与Fragment,View之间的关系。Module并不存在与代码层,它应该是一个结构层的概念。架构的魅力在于分而治之,抽象分离。


这期的主题系Activity分发功能Module

我们为何要分发功能module?

如果我们一个Activity的组成非常复杂,非常多内容,例如一个直播间里面,有视频,礼物栏,有发言,有氛围灯非常多得功能模块,那么我们希望将功能分开,而且每一个都有他们独有的层级。那么将这些功能封装到一个Module里面是一个很好的选择。


我们分发功能能module的时候需要一些什么?

(1)传递activity的对象

(2)Activity模块对应的ViewGroup

(3)Activity模块保存全部View数据的Bundle saveInstance

我们使用一个ELModuleContext来保存这些数据

当然一个Module里面,可以占用多个ViewGroup,所以使用了SparseArrayCompat这兼容类


我们如果管理这些Module?它与Activity间如何关联?

当然我们这些module拥有着和Activity一样的生命周期,但是我们不一定全部的生命周期都会用到,那么我就设定一些必要的声明周期调用ModuleManager


modules保存一些Module类名字和它持有Activity的ViewGroup

allModules保存的是Module类名字和其Module类实体

全部的Module类实体需要继承于ELAbsModule抽象类,里面都是需要实现它这些生命周期方法。


这里也提供一个Base的类,用于懒人,我们已经重写过了


然后扩展一个initModule的方法来,保存saveInstance,Activity和modules信息实例


嵌入到一个抽象base的基类,用于回调setContentView和moduleConfig的信息(具体基类的实现也可以用接口的方式组合实现)


那么到只要再继承于这基类的Activity,那么module就可以拥有Activity共享的生命周期了。

抽象的框架,肯定需要更多的范例支持。

在这里ModuleBus将会拥有例子的代码给各位读到这里的同学们参考。

这里使用一个ModuleMainActivity来提供初始的设置,


其里面包含两个Module,page_name和page_body,给page_name分发page_name的RelativeLayout,给page_body分发page_bodyT和page_bodyB两个layout


当然我们需要activity的module需要依赖于这两个次module


这里是使用动态创建的方法来创建出我们想要的module实例


而两个次module的样式如下


以page_name的为例,其继承于ELBasicModule,通过moduleContext来获取activity和layout

然后可以通过layoutInflater来加载module本身的布局page_name_layout


其布局只有一个简单的textview的title


最终page_name和page_body的显示


然后之前有说过提供了一个跨module的通信框架ModuleBus用于module间通信

只要点击change_Name的按钮,立刻可以跨module转变title的文本。

详细可以查看ModuleBus的例子,希望大家觉得有用的话,欢迎给个github的星。

ModuleBus地址

我也会将这个框架封装到ModuleBus里面,让更多的同学感受到它的魅力。

如果有疑问可以在留言区提问。


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

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



这一节就到这里,

下一节是关于Fragment分发功能组件化的内容,将会更精彩!!!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值