首页 > 学院 > 开发设计 > 正文

packer-ng-plugin(快速打包神器)初略使用

2019-11-09 15:05:10
字体:
来源:转载
供稿:网友
使用packer-ng-plugin 第一步:

  在整个工程的build.gradle中配置:

 dependencies {    classpath 'com.mcxiaoke.gradle:packer-ng:1.0.7'    // NOTE: Do not place your application dependencies here; they belong    // in the individual module build.gradle files}然后在 Module的build.gradle中配置

    

apply plugin: 'packer'
dependencies {
compile 'com.mcxiaoke.gradle:packer-helper:1.0.7'
 }     第二步:

      1. 在 gradle.PRoperties 里加入 market=yourMarketFilePath

             market代表渠道名列表文件,基于项目根目录的 相对路径(假设你的项目位于 ~/github/myapp 你的market文件位于 ~/github/myapp/config/markets.txt 那么参数应该是 -Pmarket=config/markets.txt

            yourMarketFilePath:渠道文件的路径。

     

如果你执行了这一步,则之后打包时可以直接使用gradlew (clean) apkRelease命令打多渠道包,其中clean可有可无;

如果你没有在gradle.properties 里加入 market=yourMarketFilePath,则之后打包时要用gradlew -Pmarket=market.txt (clean) apkRelease命令打多渠道包。

  第三步(编写渠道文件如上图的:markets.text):

       渠道名和注释之间用 # 号分割开,可以没有注释,示例

      yingyongso_market#应用搜      3G_market#3G安卓市场      WanDouJia_Parter#豌豆荚商店      Baidu_Market#百度应用中心      360手机助手#360手机助手      Nduo_Market#N多市场

注意:

    1. packer-ng:1.0.7 要和 packer-helper:1.0.7的版本一致

    2 同时满足下面两个条件才需要此配置:      // 1. Gradle版本 >= 2.14.1      // 2. Android Gradle Plugin 版本 >= 2.2.0      // 作用是只使用旧版签名,禁用V2版签名模式         v2SigningEnabled false如果项目集成了友盟 就在程序的入口处这样写(动态的设置友盟渠道名):
// 如果没有使用PackerNg打包添加渠道,默认返回的是""// com.mcxiaoke.packer.helper.PackerNgString market = PackerNg.getMarket(this);// 或者使用 PackerNg.getMarket(Context,defaultValue)// 之后就可以使用了,比如友盟可以这样设置MobclickAgent. startWithConfigure( new MobclickAgent.UMAnalyticsConfig(this, APP_KAY, market, MobclickAgent.EScenarioType.E_UM_NORMAL,true));参考友盟集成文档:

可选项(具体看注释):

packer {    // 是否检查Gradle配置中的signingConfig,默认不检查    checkSigningConfig = true    // 是否检查Gradle配置中的zipAlignEnabled,默认不检查    checkZipAlign = true    // 指定渠道打包输出文件名格式    //包名-渠道名-正式环境(release-版本名称-版本号-最终APK文件的md5哈希值    archiveNameFormat = '${appPkg}-${flavorName}-${buildType}-v${versionName}-${versionCode}-${fileMD5}'    // 指定渠道打包输出目录    archiveOutput = file(new File(project.rootProject.buildDir.path, "easyto_apks"))   /* // 指定渠道打包需要修改的AndroidManifest文件项    manifestMatcher = ['UMENG_CHANNEL', 'Promotion_Market']*/    // 指定是否使用build版本号自增    buildNumberAuto = true    // 指定使用版本号自增的buildType,默认是全部    buildNumberTypeMatcher = ['release', 'beta']}最后(在项目根目录执行):

      

gradlew -Pmarket=markets.txt clean apkRelease如图:

执行完后就可以在根目录的build文件夹中看到打包完毕的apk了

速度可不是一般的快!


发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表