轉載自<a >
Android Studio 使用Gradle多渠道打包
Android
java
loonggg 2016年05月13日發布
第一步:配置AndroidManifest.xml***
以友盟渠道為例,渠道信息一般都是寫在 AndroidManifest.xml文件中,大約如下:
<meta-data android:name="UMENG_CHANNEL" android:value="xiaomi" />
如果不使用多渠道打包方法,那就需要我們手動一個一個去修改value中的值,xiaomi,360,qq,wandoujia等等。使用多渠道打包的方式,就需要把上面的value配置成下面的方式:
<meta-data android:name="UMENG_CHANNEL" android:value="${UMENG_CHANNEL_VALUE}" />
其中${UMENG_CHANNEL_VALUE}中的值就是你在gradle中自定義配置的值.
</br>
第二步: 在build.gradle設置productFlavors
productFlavors {
wandoujia {
manifestPlaceholders = [UMENG_CHANNEL_VALUE: "wandoujia"]
}
xiaomi{
manifestPlaceholders = [UMENG_CHANNEL_VALUE: "xiaomi"]
}
qq {
manifestPlaceholders = [UMENG_CHANNEL_VALUE: "qq"]
}
_360 {
manifestPlaceholders = [UMENG_CHANNEL_VALUE: "360"]
}
}
其中[UMENG_CHANNEL_VALUE: "wandoujia"]就是對應${UMENG_CHANNEL_VALUE}的值。我們可以發現,按照上面的方式寫,比較繁瑣,其實還有更簡潔的方式去寫,方法如下:
android {
productFlavors {
wandoujia{}
xiaomi{}
qq{}
_360 {}
}
productFlavors.all {
flavor -> flavor.manifestPlaceholders = [UMENG_CHANNEL_VALUE: name]
}
}
其中name的值對相對應各個productFlavors的選項值,這樣就達到自動替換渠道值的目的了。這樣生成apk時,選擇相應的Flavors來生成指定渠道的包就可以了,而且生成的apk會自動幫你加上相應渠道的后綴,非常方便和直觀。大家可以自己反編譯驗證。
</br>
如果要帶簽名的話,就得在build.gradle進行相關簽名的配置
//簽名
signingConfigs{
release {
storeFile file("keystore路徑")
storePassword "***"
keyAlias "***"
keyPassword "***"
}
}
buildTypes {
release {
runProguard false
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
signingConfig signingConfigs.release
}
}
</br>
修改導出包的apk名稱
android {
applicationVariants.all { variant ->
variant.outputs.each { output ->
output.outputFile = new File(
output.outputFile.parent,
"xxxx(apk的名字)-${variant.buildType.name}-${defaultConfig.versionName}-${variant.productFlavors[0].name}.apk".toLowerCase())
}
}
}