组件化、模块化、Composing Builds

Android架构设计

从实践中摸索一套Android项目开发架构,目前已从底层设计完成以下功能点:
项目地址 : 代码

模块化,组件化

Composing Build构建,统一管理依赖

业务模块可插拔使用Application的共享环境

业务模块可独立监听回调Activity,包括第三库产生的Activity

模块化独立编译打包可使用隔离代码,集成模式下就忽略

腾讯x5 多进程启动,文件阅读器,pdf/txt/docx/xls。

代码提交时赏心悦目
git commit时的提交代码
整个项目的架构精致无暇

项目架构分包

解释下结构:

  • coreLib文件夹下全是基础功能组件lib,业务模块module按需引入即可,开发时我们关注的是模块不想lib所以放到2层目录,我见过10万级的app放到外面的lib真的是一个屏幕都不够用;
  • 每个模块下有独立的module文件夹里面放的是独立编译时所用代码,集成模式在gradle脚本已忽略这的代码;
  • 我这里把项目的路由表全放到route库中,到时每个开发创建页面要被其他module访问就要去里面添加路径,如果有朋友有更好的路由表维护方式可以推荐,不能全都自己写在自己的module里 >-<。
  • Composing builds的构建插件在/buildplugin,修改里面的DepManager.isDebug可以调整集成模式,//true=各模块单独运行,false=app集成所有模块 //手动调整集成模式,需要修改isDebug的值,还要Invalidate Caches全√才能变换成功。因为项目是研究性质,某些踩坑代码我注释掉不删除,某些其他使用方法也注释,目前注意根/build.gradle文件,每增加一个lib或module都要去修改,里面是整个架构的groovy的脚步构建的关键,基本是最新的语法使用》_《,settings.gradle的写法请看注释,巨详细。
  • 这里说下个bug,在search模块引入lite,lite只引入了个android.work,能单独编译运行search,但是一启动页面就闪退,还是没有报太多信息,后面查了一遍有个信息//Project directory ‘E:\jason_android\work_space\ComposingBuild2\composingDemo\buildplugin’ is not part of the build defined by settings file 。我是真的服了以为插件有问题一直清理invalidate,重启,都无解,后面尝试把work库注释掉可以启动,后面接着把报错信息和 androidx.work一起关键字用百度搜,外网看的了sdk32低版本有bug,要换高2.7,我之前2.3.4,服气。。。。。。这里引出几个关键是sdk一直更新,依赖库也必须跟着更新,不然真的无法兼容,类似Android广告id,还有就是处理不明显报错的方法,要多动手,我看好多人都喜欢冥想,思考后的多动手才是王道。

实现图样

左右联动列表
mmkv多进程数据访问

后续功能

以下功能都被单独调试过,但未被整合到一起,整合可能存在各种问题,用时间换空间。
路由表、Hilt依赖注入、Jetpack业务架构mmvm、kotlin单元测试、页面预加载数据、页面预加载view、
worker/room、责任链可插拔构建业务功能、三方库初始化优化、协程的统一封装/Flow的背压调度/嵌套GLoading,无限刷新的surfaceView,高频低即时性的先缓存后网络。

更新记录 :(代码提交记录有大致说明)
2022/12/5 : 适配Android13,加入路由导航,新权限适配,极光推送组件。
2022/12/7 : 接入x5 tbs,完成文件预览功能,已成功 xls/docx/txt/pdf。后面结合文件预览功能要x5和原生view一起保证能用。
2022/12/9 :适配Android12 的网络、存储,完成本地拷贝手机,完成预览文件功能,commit中注明3个bug,都是高版本12才有。
2022/12/12:修复bug,高版本手机可用。
2022/12/13:模拟各类型异常情景,设计各种方案解决,保持app在首次安装后就能正常阅读文件。
2022/12/14:新增组件bridge,主要处理模块间数据通信,减少耦合易于维护;后面解决数据库如何分开调试,数据实体类是否以全局对外暴露。
2023/1/12:新增左右联动列表设计,用的最新列表版本库4.0.0-beta04,所以很多设计跟原来有差别,有用google新的concatAdapter方式实现,但是目前无法直接用适配器找到position,我是外部根据源数据回溯,目前尝试得到都是绑定的position,不是整体数据中的根据holder获取反而会错乱,有知道concatAdapter如何获取布局position的可以交流下。
2023/1/17:修复多进程数据访问问题,组件化后多个apk的数据是隔离缓存的,要获取其他业务module的本地数据,要先切换对应的moduleId,拿到数据后再切回本moduleId再重新设置mmkv,保证数据存储到对应业务文件夹下,还有要注意获取读写权限后才初始化mmkv,因为自定义目录我这是在sd卡下见公共文件夹,然后每个业务module设置对应的moduleId生成对应的缓存文件,不给权限会崩溃的,MMKVUtils是可以自动初始化默认路径,单进程的太简单直接用,但是数据被放到黑箱子。代码测试在 LoginActivity/SearchActivity)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Spanned.SPAN_COMPOSING 是一个常量,用于表示一个跨度对象(Span)正在处于组合文本输入的状态。它是用于处理复杂文本输入和编辑的 Android 文本样式类 Spanned 的一个标记常量。 当用户正在进行组合文本输入(如中文输入法的拼音输入)时,输入的文本可能会被拆分成多个部分,并且在用户最终确定输入之前,这些部分可能会不断变。SPAN_COMPOSING 被用于标记这些处于组合输入状态的文本部分,以便在显示和处理这些文本时进行特殊处理。 在使用 Spanned 接口及其实现类(如 SpannableString 或 SpannableStringBuilder)处理文本时,可以使用 Spanned.SPAN_COMPOSING 来标记处于组合输入状态的文本部分。例如,你可以使用 setSpan() 方法将 Spanned.SPAN_COMPOSING 应用于文本的特定范围,以便在显示或处理文本时对这些部分进行特殊处理。 以下是一个使用 Spanned.SPAN_COMPOSING 的示例: ```java SpannableString spannableString = new SpannableString("Hello World"); spannableString.setSpan(new ForegroundColorSpan(Color.RED), 0, 5, Spanned.SPAN_COMPOSING); textView.setText(spannableString); ``` 在上面的示例中,"Hello" 这个单词将被标记为处于组合输入状态,并且会应用红色前景色。这样,当用户在输入过程中修改或删除这部分文本时,可以对其进行特殊处理,以提供更好的用户体验。 希望这个解释对你有所帮助!如果还有其他问题,请随时提问。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值