Android多设备多module打包(fat-aar)

当一个工程项目中存在多个module时,可使用fat-aar将多个module打包成一个aar;

一、工程目录build.gradle

依赖相应的的fat-aar版本

dependencies {
    
    //根据gradle plugin version版本选择其一即可
    classpath "com.github.kezong:fat-aar:1.3.8"//gradle plugin version 7.2.2
    classpath 'com.github.AndreasBoehm:fat-aar-android:da3ac00990'//gradle plugin version 7.3.1
}

二、最终的Module内

build.gradle文件内:

//enable_packed_aar在gradle.properties内定义,来动态选择是否需要合并打包
//eg:enable_packed_aar=false
if (enable_packed_aar.equalsIgnoreCase("true")) {
    
    
    apply plugin: 'com.kezong.fat-aar'
}

dependencies {
    
    
	...
    if (enable_packed_aar.equalsIgnoreCase("true")) {
    
    
        //embed project(path: ':路径')
        embed project(path: ':framework:components')//某个要合并打包的Module
        implementation "com.deepthinker:sdk:${
      
      rootProject.DeepThinkerVersion}"//远程依赖
    } else {
    
    
        implementation project(path: ':framework:common')
    }
}

三、某个Module内

build.gradle文件内

当某个Module内有远程依赖时:

if (enable_packed_aar.equalsIgnoreCase("true")) {
    
    
    apply plugin: 'com.kezong.fat-aar'
}
//新aar包中包含远程的仓库的aar包
dependencies {
    
    
    if (enable_packed_aar.equalsIgnoreCase("true")) {
    
    
        embed "com.deepthinker:sdk:${
      
      rootProject.DeepThinkerVersion}"//此方法会将远程依赖的包文件一同打包到新生成的aar包中
    } else {
    
    
        implementation "com.deepthinker:sdk:${
      
      rootProject.DeepThinkerVersion}"
    }
}
//新aar包含有远程依赖的链接,在使用新aar包时自动下载,此方法需要在最终的module内也implementation
dependencies {
    
    
	if (enable_packed_aar.equalsIgnoreCase("false")) {
    
    
    	implementation "com.deepthinker:sdk:${
      
      rootProject.DeepThinkerVersion}"
    }
}

没有远程依赖时可不做任何操作

四、区分不同设备

在每个Module内添加多种设备的标识,此处分为手机和手表设备。在编译打包时手动选择打包某个类型设备的aar包

android {
    
    
	...
	defaultConfig {
    
    
		...
		flavorDimensions "name"
	}
    productFlavors {
    
    
        phone {
    
    

        }
        watch {
    
    

        }
    }
}

在每个Module的src目录下建立对应设备的文件目录Directory,主main内的作为不同设备共有部分,不同设备内的作为各自设备特有的功能
在这里插入图片描述

五、将版本上传到maven仓库

在项目目录下创建一个build.gradle,在最终打包的Module内应用该文件

apply from: '../../sdk_build.gradle'

sdk_build.gradle文件:

apply plugin: 'maven-publish'

afterEvaluate {
    
    
    publishing {
    
    
        publications {
    
    
            phoneSnapshot(MavenPublication) {
    
    
                from components.phoneRelease
                groupId = prop_groupId//自行设置
                artifactId = prop_artifactId//自行设置
                version = "${
      
      MultiModule_sdk_version}-beta-SNAPSHOT"//aar包名,别人依赖时使用名字依赖,MultiModule_sdk_version版本号
            }
        }
        repositories {
    
    
            maven {
    
    
                name = 'snapshot'
                url = prop_oppoMavenUrl_snapshot//仓库地址
                allowInsecureProtocol = true
                credentials {
    
    
                    username = sonatypeUsername//用户名
                    password = sonatypePassword//密码
                }
            }
        }
    }
}

猜你喜欢

转载自blog.csdn.net/ppss177/article/details/129692888
今日推荐