组件化开发的主要步骤:
一、新建Modules
1、新建Project,作为应用的主Module。
2、新建Module:"Common",类型选择"Android Library",作为所有其它Module的基础依赖库。
3、新建Module:"Home",类型选择"Android Library",依赖"Common"。
4、新建Module:"Project",类型选择"Android Library",依赖"Common"。
5、新建Module:"User",类型选择"Android Library",依赖"Common"。
具体新建怎样的Module,可以根据实际业务来调整。这里选择新建"Home"、"Project"、"User"来模拟业务。
二、增加Flag以便在release和debug模式下切换
1、在gradle.properties文件中增加一个变量
isDebug = false
当isDebug为true时,为Debug模式,其它的Module可以作为单独的App运行。当isDebug为false时,为Release模式,其它的Module为Library模式,不能单独运行,此时只有主App可以运行。
2、修改app的build.gradle文件
implementation project(':common')
if (!isDebug.toBoolean()) {
implementation project(':home')
implementation project(':project')
implementation project(':user')
}
3、修改home的build.gradle文件
if (isDebug.toBoolean()) {
apply plugin: 'com.android.application'
} else {
apply plugin: 'com.android.library'
}
4、修改project的build.gradle文件
if (isDebug.toBoolean()) {
apply plugin: 'com.android.application'
} else {
apply plugin: 'com.android.library'
}
5、修改user的build.gradle文件
if (isDebug.toBoolean()) {
apply plugin: 'com.android.application'
} else {
apply plugin: 'com.android.library'
}
为便于各Module单独调试开发,可以在各Module下根据isDebug的变量区分模式。
切换工程到Project模式下,将原来的AndroidManifest.xml文件移除,在Module的src/main目录下新建debug和release目录,在新建的两个目录下,分别新建AndroidManifest.xml文件。以Home模块为例:
Debug模式下的AndroidManifest.xml
Release模式下的AndroidManifest.mxl
在Home下的build.gradle文件中配置AndroidManifest.xml
sourceSets {
main {
if (isDebug.toBoolean()) {
manifest.srcFile 'src/main/debug/AndroidManifest.xml'
} else {
manifest.srcFile 'src/main/release/AndroidManifest.xml'
java { exclude 'debug/**' }
}
}
}
其它Module也是相似的处理。
三、统一管理Module版本号
1、为便于统一管理版本号,在项目的根目录下的build.gradle文件中增加统一的版本号:
ext {
compileSdkVersion = 28
minSdkVersion = 21
targetSdkVersion = 28
versionCode = 1
versionName = "1.0"
}
2、在其它Module下相应修改
App模块:
Common模块:
Home模块:
Project模块:
User模块:
四、各Module间通信
为解决各Module间通信的问题,引入ARouter框架。GitHub地址:ARouter
为避免各Module重复引用,在Common中引用一次,其它Module复用即可。
注意:由于其它依赖Common的Module也需要使用Arouter,因此在引入时,需要把implementation改为api。如果使用implementation,其它Module会无法使用Arouter。
其它Module中使用:
不需要再次implementation,但是还是需要在dependencies增加
annotationProcessor 'com.alibaba:arouter-compiler:1.2.2'
以及在android-defaultConfig中增加:
javaCompileOptions {
annotationProcessorOptions {
arguments = [AROUTER_MODULE_NAME: project.getName()]
}
}
注意:"AROUTER_MODULE_NAME"这个名称,不可以改为其它字符串,否则会编译报错。
在Common模块下增加BaseApplication,对ARouter进行初始化。
public class BaseApplication extends Application {
private boolean isDebugARouter = true;
@Override
public void onCreate() {
super.onCreate();
if (isDebugARouter) {
ARouter.openLog();
ARouter.openDebug();
}
ARouter.init(this);
}
}
在主Module:App中增加App,继承自BaseApplication,然后在AndroidManifefst.xml中引用。
public class App extends BaseApplication {}
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
package="com.wan