Android マルチデバイス マルチモジュール パッケージング (fat-aar)

プロジェクトに複数のモジュールがある場合、fat-aar を使用して複数のモジュールを 1 つの aar にパッケージ化できます。

1. プロジェクトディレクトリ 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
}

2. 最後のモジュールで

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')
    }
}

3. 特定のモジュール内

build.gradle ファイル内

モジュールにリモート依存関係がある場合:

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}"
    }
}

リモート依存関係がない場合は、何も行いません。

4. 異なるデバイスを区別する

各モジュールに複数のデバイスの識別を追加します。モジュールは携帯電話と時計デバイスに分かれています。コンパイルおよびパッケージ化するときに、特定のタイプのデバイスの aar パッケージを手動で選択します。

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

        }
        watch {
    
    

        }
    }
}

各モジュールの src ディレクトリに、対応するデバイスのファイルディレクトリを作成し、メイン main にあるものは各デバイスの共通部分として使用し、異なるデバイスにあるものは各デバイス固有の機能として使用します。
ここに画像の説明を挿入します

5. バージョンを Maven ウェアハウスにアップロードします

プロジェクト ディレクトリに build.gradle を作成し、このファイルを最終的にパッケージ化されたモジュールに適用します

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