下一代Android渠道打包工具Gradle插件

  • 这里先给上地址:
    https://github.com/mcxiaoke/packer-ng-plugin

  • 两种方式:
    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文本文件 也就是你的渠道名列表文件

下一代Android渠道打包工具Gradle插件_第1张图片
Paste_Image.png

每行一个渠道号 渠道名和注释之间用 # 号分割开 可以没有注释

  1. 在gradle.porperties中引用你的渠道文件列表
下一代Android渠道打包工具Gradle插件_第2张图片
Paste_Image.png
  • 如果你的module中没有配置 productFlavors等相关属性的话这时只要执行命令就可以打包了(在项目根目录执行):

    ./gradlew -Pmarket=markets.txt clean apkRelease

  • 缺点
    1.不支持修改AndroidManifest
    如果有用到第三方需要配置修改AndroidManifest.xml

    那么您在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 中的配置,且方便快捷,一句命令就生成你需要的渠道包。

  • 再来说说用该作者的提供的脚本打包方式
    1. 首先去github下载工程
    2. 将工程中的tools文件夹复制到工程根目录中
    3. 再将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不太了解)

以上就是对多渠道打包方式的详细解释(若对哪里有疑问欢迎提出)

你可能感兴趣的:(下一代Android渠道打包工具Gradle插件)