项目简介
- 项目整体架构模式采用:组件化+MVP+Rx+Retrofit
- 项目构成:app壳工程 ,一个业务组件,一个公共基础组件
- 组件化基础架构实例工程
项目运行
- 运行环境要求
- Android studio 版本需要在3.4之上,compileSdkVersion是29,gradle版本是3.2.1,gradle-wrapper是5.4.1,jdk是1.8(支持Lambda表达式) ,androidx 开发
- 组件模式和集成模式如何切换
- 默认模式下,都是属于library形式的组件【app作为空壳主工程依赖所有的组件】,如果想把某一个library形式的组件切换成一个独立可以run的application,通过修改hhe.gradle
isBusinessApplication = true //业务测试组件,false:作为Lib组件存在, true:作为application存在
项目架构及新增组件
- 主工程:
- 除了一些全局配置和主 Activity 之外,不包含任何业务代码。有的也叫做空壳app
- 业务组件:
最上层的业务,每个组件表示一条完整的业务线,彼此之间互相独立。
项目写了个测试组件,以后根据计划业务组件可以新增进来,这个目前拟定的业务组件 - 功能组件:
功能组件目前的拟定:分享组件,支付组件,ui快速开发组件等等。同时注意,可能会涉及多个业务组件对某个功能组件进行依赖!
基础组件: - 支撑上层业务组件运行的基础业务服务。
在基础组件库中主要有,网络请求,图片加载,通信机制,工具类,UI快速开发组件,等等。一些公共第三方库放到了这个基础组件。
- 如何新增组件:
- 组件名称:hhe-业务名称 (如:支付组件 hhe-pay),布局文件:业务名称+布局名称 (pay_activity_center),资源文件:业务名称+图片名称 (pay_icon_submit)
- 在Android Studio中新建module
二选一:Phone & Tablet Module 或 Android Library
- 配置基础依赖 ARouter路由 ,公共基础模块
android {
defaultConfig {
javaCompileOptions {
annotationProcessorOptions {
arguments = [AROUTER_MODULE_NAME: project.getName()]
}
}
compileOptions {
sourceCompatibility JavaVersion.VERSION_1_8
targetCompatibility JavaVersion.VERSION_1_8
}
}
dependencies {
implementation fileTree(dir: 'libs', include: ['*.jar'])
implementation project(path: ':hhe-common-library')
annotationProcessor rootProject.ext.dependencies["router-compiler"]
annotationProcessor rootProject.ext.dependencies["butterknifecompiler"]
}
- 在hhe.gradle 文件新增组件开关,用于组件模式和集成模式切换
如果不需要单独运行 可以跳过以下步骤
isBusinessApplication = true //业务测试组件,false:作为Lib组件存在, true:作为application存在
- 修改业务组件的gradle
if (rootProject.ext.isBusinessApplication) {
apply plugin: 'com.android.application'
} else {
apply plugin: 'com.android.library'
}
android {
defaultConfig {
if (rootProject.ext.isBusinessApplication){
applicationId "com.hhe.business"
}
}
- 新增AndroidManifest
将Android Studio的导航切换到"Project"模式
在module/src/main文件夹上点右键 -> 新建Directory,并命名为module
把business里androidManifest 复制进来 ,配置需要注册文件
在业务的gradle 添加
android{
sourceSets {
main {
if (rootProject.ext.isBusinessApplication) {
manifest.srcFile 'src/main/module/AndroidManifest.xml'
} else {
manifest.srcFile 'src/main/AndroidManifest.xml'
}
}
}