Android library 發佈多渠道 AAR

1、 在項目多渠道開發時,除了對不一樣的渠道除了作統計外,還能夠對不一樣的渠道加載不一樣的代碼及資源,具體的部署能夠參考 Android studio gradle中分渠道加載res、libraries及Class ;在模塊化拆分後,若剛好在模塊內部的代碼及資源也要根據不一樣的渠道發佈不一樣的aar包到nexus倉庫,該怎麼配置呢?android

2、思路:通常單獨拆分出的library基本都是將代碼及資源打包成aar包並上傳,爲了使用方便,最好是在uploadArchives時就上傳到不一樣的artifact下。固然也能夠傳到不 的group下,但若在一個項目中有多個library時,只須要對其中的某個子庫(如core-ui分離下的ui庫)進行上傳時最好上傳不一樣的artifact下,通常只須要在手動選擇Build Variants後就動態修改要上傳的POM_ARTIFACT_ID便可。bash

  1. 將POM_ARTIFACT_ID定義在library項目下的gradle.properties文件中,如:
POM_ARTIFACT_ID=account
複製代碼

2.若library開發的項目有用於測試的demo app,須要在app gradle下配置:app

// 在dependencies下正常引入
    implementation project(':account')

//須要與library庫建立對應的productFlavors
android{
    …
    flavorDimensions "mode"
    publishNonDefault true
    productFlavors {
        official {}
        mi {}
    }
}
//須要指定編譯配置
configurations {
    officialDebug
    miDebug
    officialRelease
    miRelease
}
複製代碼

3.在library的build.gradle文件中建立不一樣的變體,並在選擇不一樣的Build Variants後更新發布時使用的POM_ARTIFACT_ID:模塊化

// 在dependencies下正常引入
android{
    flavorDimensions "mode"
    productFlavors {
        official {}
        mi {}
    }
    
    // 取出當前選擇的渠道名
    def currentFlavor = getCurrentFlavor()
    println "---> currentFlavor = $currentFlavor"
    if ("mi".equalsIgnoreCase(currentFlavor)) {
        // 取要指定默認發佈要使用的configuration
        defaultPublishConfig 「miRelease」
        // 在取出渠道名判斷後更新POM_ARTIFACT_ID
        replacePropertiesValue('POM_ARTIFACT_ID', 'account-mi')
    } else {
        defaultPublishConfig "officialRelease"
        replacePropertiesValue('POM_ARTIFACT_ID', 'account')
    }

}


 // 取出當前選擇的渠道名
def getCurrentFlavor() {
    Gradle gradle = getGradle()
    String taskStr = gradle.getStartParameter().getTaskRequests().toString()
    println("taskStr:" + taskStr)
    Pattern pattern
    if (taskStr.contains("assemble")) {
        pattern = Pattern.compile("assemble(\\w+)(Release|Debug)")
    } else {
        pattern = Pattern.compile("generate(\\w+)(Release|Debug)")
    }
    Matcher matcher = pattern.matcher(taskStr)
    if (matcher.find()) {
        return matcher.group(1)
    }
    return ""
}

 // 替換library項目下的gradle.properties中的key-value值,key下value不一樣時才替換
def replacePropertiesValue(key, replaceValue) {
    if (project.hasProperty(key)) {
        def value = project.properties.get(key)
        if (!replaceValue.equalsIgnoreCase(value)) {
            ant.replace(file: "gradle.properties", token: "$key=$value", value: "$key=$replaceValue")
        }
    }
}

複製代碼

至此就能成功的將aar包發佈到遠程nuxus倉庫,若在demo工程裏跑起來了。但在主項目裏同樣須要判斷配置。函數

3、主項目工程配置測試

  1. 在主工程中配置的渠道須要包含library中包含的渠道:
productFlavors {
        official {}
        mi {}
        Baidu{}
    }
複製代碼
  1. 須要使用上面的currentFlavor()函數獲取當前編譯的flavor再選擇依賴的庫:
dependencies{
    def currentFlavor = getCurrentFlavor()
    println "---> currentFlavor = $currentFlavor"
    if ("mi".equalsIgnoreCase(currentFlavor)) {
      // implementation mi版本庫
    } else {
         //  implementation official版本庫
    }
}
複製代碼
相關文章
相關標籤/搜索