Android 工程组件化实践

本文记录将一个新工程按组件化配置的过程及过程中遇到的问题。

一、工程最终结构

首先看下工程的最终结构,其中包括主模块、组件模块(也就是可以单独打包的子模块)、 lib 模块(又包括:基础lib,普通lib)。
如图:


工程结构

各个模块的详细介绍:

  • app:入口作用,最终发版打包的模块;
  • common:包括组件模块中共用的依赖、activity、工具类等其他可能会共用的,比如 ARouter 的依赖、登录activity 等可以放到该模块中,注意:主模块及组件模块要分别依赖该模块;
  • easyvideoplayer:就是普通的lib模块,哪儿个模块需要就去哪儿个模块添加依赖,下文中不再说这个模块相关的配置;
  • usercenter:用户中心组件模块。

二、创建工程及模块

创建工程其中包含主模块 app,并新建模块(正常应用模块,非 Android Library 类型):common、usercenter。

1. 在工程 build.gradle 中添加:

ext {
    // 定义版本号,模块中版本号保持一致
    compileSdkVersion = 29
    buildToolsVersion = '29.0.2'
    minSdkVersion = 18
    targetSdkVersion = 29
    
    // 定义 applicationId
    applicationId = 'com.hyh.trytodo'

    // 控制组件化是否可以打组件包,想打组件包时改为:true
    isRunModule = false
}

2. app 模块需要配置:

  • 文件 build.gradle 中:
api project(':common')
// 非组件化打包时添加模块依赖
if (!rootProject.ext.isRunModule) {
    implementation project(':usercenter')
}

3. common 模块中需要修改文件:

  • 文件 build.gradle 中:
    apply plugin: 'com.android.application' 改为 apply plugin: 'com.android.library'
    版本号使用工程 build.gradle 文件中定义的
    compileSdkVersion rootProject.ext.compileSdkVersion
    buildToolsVersion rootProject.ext.buildToolsVersion
    删除 applicationId xxx
  • AndroidManifest.xml 中:删除 <application> 中的所有属性,添加 activity 中也要在该文件中添加声明。

4. usercenter 模块中需要修改文件:

  • 在目录 main/ 下创建 degub/ 目录,并将该模块中的 AndroidManifest.xml 复制到该目录,之后新建的 activity 要在该文件中声明。
  • AndroidManifest.xml 中:删除 <application> 中的所有属性。
  • 文件 build.gradle 中:
if (rootProject.ext.isRunModule) {
   apply plugin: 'com.android.application'
} else {
   apply plugin: 'com.android.library'
}

android {
   compileSdkVersion rootProject.ext.compileSdkVersion
   buildToolsVersion rootProject.ext.buildToolsVersion

   defaultConfig {
       if (isRunModule) {
           applicationId rootProject.ext.applicationId
       }
       minSdkVersion rootProject.ext.minSdkVersion
       targetSdkVersion rootProject.ext.targetSdkVersion
   }
   ....
   sourceSets {
       main {
           if (isRunModule) {
               manifest.srcFile 'src/main/debug/AndroidManifest.xml'
           } else {
               manifest.srcFile 'src/main/AndroidManifest.xml'
               java {
                   exclude '**/debug/**'
               }
           }
       }
   }
}

到此工程及模块配置已经完成,接下来就是添加代码。

4. ARouter 配置及使用参考官方文件,不在赘述。

过程中遇到的问题:

1. 明明在 common 中添加了RxJava 的依赖,在 app 中也添加了 common 的依赖,但是在 app 中还是不能使用 RxJava 相关的方法。

出现该问题:需要看下依赖 RxJava 的语句是使用的 api 还是 implementation。只有使用 api 时,app 中才能正常使用。出现同样问题可以先排查这离

2. ARouter 提示:"W/ARouter::: ARouter::There is no route match the path [/xxx/xxx], in group [xxx][ ]"

ARouter 的主要配置是在 common 的 build.gradle 文件中配置,然后各个需要使用 ARouter 的模块去依赖 common,但是光这样是不行的,还需要添加下面的配置:

android {
    defaultConfig {
        .....
        javaCompileOptions {
            annotationProcessorOptions {
                arguments = [AROUTER_MODULE_NAME: project.getName()]
            }
        }
    }
}

dependencies {
    annotationProcessor 'com.alibaba:arouter-compiler:1.2.2'
}
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 不怕跌倒,所以飞翔 组件化开发 参考资源 Android组件化方案 为什么要组件化开发 解决问题 实际业务变化非常...
    笔墨Android阅读 3,021评论 0 0
  • 一个软件系统的开发可能只需要2到3个月就能完成,而这个系统的迭代和维护时间可能达2到3年之久——《不记得哪本书上说...
    DoneWillianm阅读 1,810评论 4 10
  • 每当开始做一个新的APP , 都是喜忧参半 。喜得是对新的APP充满期待,希望小成就感。忧的是没有一款好的开发框架...
    六桥明月夜阅读 391评论 0 3
  • 1. App项目组件化 做移动开发的同学都会发现这两年在移动开发圈子里最火的就是组件化了,组件化不同的实现方案也引...
    monkey01阅读 10,705评论 6 56
  • 每个人都有自己想要的生活,也都想成为想要的自己,可却很少有人真正的想一想,在想要成为理想中的自己之前,我要做一些什...
    子豪同学c阅读 1,134评论 1 3