packer-ng-plugin(快速打包神器)初略使用
来源:互联网 发布:mac重置 编辑:程序博客网 时间:2024/06/08 12:06
由于是刚入Android的新手 尤其对Android Studio 的Gradle语法完全陌生,所以对一些功能的实现只能依壶画瓢的看别人怎么写我就怎么写。
首先感谢“非著名程序员”推荐的一篇文章:
地址:https://mp.weixin.qq.com/s?__biz=MjM5NDkxMTgyNw==&mid=2653057951&idx=1&sn=411620547e5ae32df9abec54ed8db5c4&scene=0&pass_ticket=a%2BbxYNOdsqo%2Bd7gNiKieind1OaLKjnKioZYnJXx57cwYEl3OwKj8%2BpycU4MGZHaE
github:https://github.com/mcxiaoke/packer-ng-plugin
我们都知道用Androdi Studio来进行多渠道打包 是非常慢的,于是就有不少的大神出来解决这些问题 ,而我们也受益于这些大神的开源成果结晶,在此特别感谢那些开源开拓者们。
好了 !废话不多说 这是一篇关于对packer-ng-plugin(快速多渠道打包)的初略使用,还有一些强大的功能还在研究中,直接看代码:
apply plugin: 'com.android.application'apply plugin: 'packer'android { compileSdkVersion 23 buildToolsVersion "23.0.3" compileOptions.encoding = "UTF-8" defaultConfig { applicationId "com.example.administrator.material_design" minSdkVersion 19 targetSdkVersion 23 versionCode 1 versionName "1.0" } //程序在buid的时候,会执行lint检查,有任何的错误或者警告提示,都会终止构建,我们可以将其关掉 lintOptions { abortOnError false htmlReport true } packagingOptions { exclude 'LICENSE.txt' } signingConfigs { debug { storeFile file("debug.keystore") } release { storeFile file("android_design.jks") storePassword "xxxxxx" keyAlias "design" keyPassword "xxxxxx" // 同时满足下面两个条件才需要此配置 // 1. Gradle版本 >= 2.14.1 // 2. Android Gradle Plugin 版本 >= 2.2.0 // 作用是只使用旧版签名,禁用V2版签名模式 //v2SigningEnabled false } } buildTypes { buildTypes { release { signingConfig signingConfigs.release//签名 minifyEnabled true //开启代码混淆 zipAlignEnabled true shrinkResources true // 移除无用的resource文件 signingConfig signingConfigs.release proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' } beta { signingConfig signingConfigs.release//签名 minifyEnabled false debuggable true shrinkResources true proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' } } } 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'] } allprojects { repositories { mavenCentral() } } } dependencies { compile fileTree(dir: 'libs', include: ['*.jar']) testCompile 'junit:junit:4.12' compile 'com.android.support:appcompat-v7:23.4.0' compile 'com.android.support:design:23.4.0' compile 'com.umeng.analytics:analytics:latest.integration' compile 'com.android.support:cardview-v7:23.2.1' compile 'com.android.support:support-v4:23.1.0' compile 'com.facebook.rebound:rebound:0.3.8' compile 'com.facebook.fresco:fresco:0.12.0' compile 'com.github.bumptech.glide:glide:3.7.0' compile 'com.mcxiaoke.gradle:packer-helper:1.0.7' }使用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
:渠道文件的路径。
第三步(编写渠道文件如上图的: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了
速度可不是一般的快!
- packer-ng-plugin(快速打包神器)初略使用
- packer-ng-plugin(快速打包神器)初略使用
- Android packer-ng-plugin 多渠道快速打包
- packer-ng多渠道打包工具的使用
- Android中快速打包神器
- Sprite打包工具(Sprite Packer)
- 新一代打包神器Walle(瓦力)使用小结
- Spine 的纹理打包器(texture packer)
- Demo打包尝试以及初略步骤
- Demo打包尝试以及初略步骤
- 用Texture Packer打包数据
- Packer-ng 打渠道包乱码解决方案
- 使用assembly plugin实现自定义打包
- 使用maven-assembly-plugin打包zip工程
- 使用maven-assembly-plugin打包dubbo接口
- UGUI 图集打包工具Sprite Packer
- angular js+gulp+jenkins打包(略git)
- 使用Packer制作vagrant box
- TCP backlog packet in the path
- AsyncTask源码解析二-----工作线程
- [设计模式]原型模式
- 使用CoGetClassObject而不使用CoCreateInstance的情况
- Chapter1_基本数据类型之整型(int)
- packer-ng-plugin(快速打包神器)初略使用
- Java中的文件下载
- 初学者怎么理解集成开发环境,编译与链接(四)
- win10安装SQL12时,出现[错误消息] 为 SQL Server 代理服务提供的凭据无效。若要继续操作,请为 SQL Serve
- unity3d 29
- 51nod oj 1088 1089 最长回文子串 【Manacher算法】
- 对overflow与zoom”清除浮动”的一些认识 张鑫旭博客笔记
- 周记(From 2016/08/09 to 2016/08/16)
- 机器学习(周志华) 参考答案 第七章 贝叶斯分类器 7.6