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