两种方式:
1. gradle配置多渠道打包(在不做APK资源压缩和加固的情况下才可以用)
2. 执行脚本命令多渠道打包 简单方便(个人比较推荐)公司每次使用Android Studio gradle打包,面对那么多渠道包整个流程下来会让人怀疑人生,然后在网上找了一圈,有巨人已经解决整个问题了,今天我就站在巨人的肩膀上(20多个渠道包2分钟搞定)。
-
废话不多说 来看看如何使用吧:
在工程的 gradle下 引入:
classpath 'com.mcxiaoke.gradle:packer-ng:1.0.8'
在module中的 gradle中引入:
apply plugin: 'packer'
android{signingConfigs{ /*正式环境*/ release { assert localProps['keystore.props.file'] storeFile file(keyProps["store"]) keyAlias keyProps["alias"] storePassword keyProps["storepass"] keyPassword keyProps["pass"] // 满足下面两个条件时需要此配置 // 1. Gradle版本 >= 2.14.1 // 2. Android Gradle Plugin 版本 >= 2.2.0 // 作用是只使用旧版签名,禁用V2版签名模式 v2SigningEnabled false } } buildTypes { release { signingConfig signingConfigs.release//签名 shrinkResources true//移除无用的resource文件 minifyEnabled true zipAlignEnabled true proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' } debug { minifyEnabled false zipAlignEnabled false } } } packer { //指定渠道打包输出目录 archiveOutput = file(new File(project.rootProject.buildDir.path,"archives")) //指定渠道打包输出文件名格式 默认是 '${appPkg}-${flavorName}-${buildType}-v${versionName}-${versionCode}' archiveNameFormat = '' // 是否检查>Gradle配置中的signingConfig,默认不检查 checkSigningConfig = >false // 是否检查Gradle配置中的zipAlignEnabled,默认不检查 checkZipAlign = false } dependencies { compile 'com.mcxiaoke.gradle:packer-helper:1.0.8' }
注意packer-ng的版本要和packer-helper的版本保持一致性(1.0.8)
-
如果项目中有相关渠道统计的话只能在代码中去实现:
友盟:
//获取渠道包名
String market = PackerNg.getMarket(getApplicationContext());
//第二个参数为 友盟key,第三个参数为:渠道名,第四个参数为统计格式(具体参照友盟官方文档)
MobclickAgent.startWithConfigure(new MobclickAgent.UMAnalyticsConfig(getApplicationContext(), BaseKeyConstants.APP_KAY, market, MobclickAgent.EScenarioType.E_UM_NORMAL, true));TalkingData:
//渠道(默认)
String market = Constant.CHANNELS;
if (!Constant.IS_DEBUG) {
market = PackerNg.getMarket(UJiPin.mAppContext);
ULog.e(TAG,"渠道名:"+market);
}
//TalkingData初始(第二个参数为 TalkingData申请的KEY)
TCAgent.init(UJiPin.mAppContext,Constant.TALKINGDATA_KEY, market)**以上为常用的渠道统计,其他渠道统计请参照官方文档**
2.在工程的根目录下创建.txt文本文件 也就是你的渠道名列表文件
每行一个渠道号 渠道名和注释之间用 # 号分割开 可以没有注释
- 在gradle.porperties中引用你的渠道文件列表
- 如果你的module中没有配置 productFlavors等相关属性的话这时只要执行命令就可以打包了(在项目根目录执行):
./gradlew -Pmarket=markets.txt clean apkRelease
- 缺点
1.不支持修改AndroidManifest
如果有用到第三方需要配置修改AndroidManifest.xml
<meta-data name="xxxx" value="NAME_VALUE"></meta-data>
那么您在gradle的配置将会无效(切记)
defaultConfig {
manifestPlaceholders[NAME_VALUE :xxxxxxxxxx]
}
2.不支持productFlavors中定义的条件编译变量
如果你的项目有多个productFlavors,默认只会用第一个flavor生成的APK文件作为
打包工具的输入参数,忽略其它flavor生成的apk,代码里用的是
theVariant.outputs[0].outputFile。如果你想指定使用某个flavor来生成渠道包,
可以用 apkFlavor1Release,apkFlavor2Beta这样的名字,示例
productFlavors {
tdebug {}
Intel { }
.....
}./gradlew -Pmarket=markets.txt clean apkIntelRelease
或者
./gradlew -Pmarket=markets.txt clean apktdebugRelease
若你的apk需要进行资源压缩或者加固处理 那么多渠道打包必须放到最后一步 并且以上所说的所有配置可以完全忽略(使用脚本来进行打包)
** 优点:**
不参与Gradle构建过程,所以不会影响你在 build.gradle 中的配置,且方便快捷,一句命令就生成你需要的渠道包。
- 再来说说用该作者的提供的脚本打包方式
- 首先去github下载工程
- 将工程中的tools文件夹复制到工程根目录中
- 再将helper包里的 PackerNg.java
到项目
- 先用Android Studio 的 Build -->Generate Signed APK --> 选择release 打出一个正式包
- 拿到这个正式包做资源压缩或者加固操作(若没有这些需求 可以忽略这一步)
- 执行java命令
java -jar ../tools/PackerNg-x.x.x.jar apkFile marketFile outputDir
**apkFile 为你压缩加固完成后的apk路径**
**marketFile 你的渠道文件列表的路径**
**outputDir 你需要将你apk追加渠道后输出路径**
- Python脚本
python PackerNg-x.x.x.py [file] [market] [output] [-h] [-s] [-t TEST]
前面3个参数与java脚本的一致,至于后面3个参数什么意思 希望有懂Python小伙伴给提示下(PS:真的对python不太了解)
以上就是对多渠道打包方式的详细解释(若对哪里有疑问欢迎提出)