由于国内Android市场众多渠道,为了统计每个渠道的下载及其它数据统计,就需要我们针对每个渠道单独打包,如果让你打几十个市场的包岂不烦死了,不过有了Gradle,这事就简单了。

友盟多渠道打包

废话不多说,以友盟统计为例,在AndroidManifest.xml里面会有这么一段:

  1. <meta-data
  2. android:name="UMENG_CHANNEL"
  3. android:value="Channel_ID" />

里面的 Channel_ID 就是渠道标示。我们的目标就是在编译的时候这个值能够自动变化。



第一步 在 AndroidManifest.xml 里配置 PlaceHolder

  1. <meta-data
  2. android:name="UMENG_CHANNEL"
  3. android:value="${UMENG_CHANNEL_VALUE}" />

第二步 在 build.gradle 设置 ProductFlavors

  1. android {
  2. productFlavors {
  3. xiaomi {
  4. manifestPlaceholders = [UMENG_CHANNEL_VALUE: "xiaomi"]
  5. }
  6. _360 {
  7. manifestPlaceholders = [UMENG_CHANNEL_VALUE: "_360"]
  8. }
  9. baidu {
  10. manifestPlaceholders = [UMENG_CHANNEL_VALUE: "baidu"]
  11. }
  12. wandoujia {
  13. manifestPlaceholders = [UMENG_CHANNEL_VALUE: "wandoujia"]
  14. }
  15. }
  16. }

或者批量修改

  1. android {
  2. productFlavors {
  3. xiaomi {}
  4. _360 {}
  5. baidu {}
  6. wandoujia {}
  7. }
  8. productFlavors.all {
  9. flavor -> flavor.manifestPlaceholders = [UMENG_CHANNEL_VALUE: name]
  10. }
  11. }

很简单,直接执行 ./gradlew assembleRelease , 然后就可以静静的等待打包完成。

assemble结合Build Variants来创建task

assemble 这个命令会结合 Build Type 创建自己的task,如:

  • ./gradlew assembleDebug
  • ./gradlew assembleRelease

除此之外 assemble 还能和 Product Flavor 结合创建新的任务,其实 assemble 是和 Build Variants 一起结合使用的,而 Build Variants = Build Type + Product Flavor 。

如我们想打包wandoujia渠道的release版本,执行如下命令就好了:

./gradlew assembleWandoujiaRelease

如果我们只打wandoujia渠道版本,则:

./gradlew assembleWandoujia

此命令会生成wandoujia渠道的Release和Debug版本



同理我想打全部Release版本:

./gradlew assembleRelease

这条命令会把Product Flavor下的所有渠道的Release版本都打出来。

总之,assemble 命令创建task有如下用法:

**assemble**: 允许直接构建一个Variant版本,例如assembleFlavor1Debug。

**assemble**: 允许构建指定Build Type的所有APK,例如assembleDebug将会构建Flavor1Debug和Flavor2Debug两个Variant版本。

**assemble**: 允许构建指定flavor的所有APK,例如assembleFlavor1将会构建Flavor1Debug和Flavor1Release两个Variant版本。



完整的gradle脚本

最后来一份我在项目中使用的完整的gradle文件配置:

  1. apply plugin: 'com.android.application'
  2. def releaseTime() {
  3. return new Date().format("yyyy-MM-dd", TimeZone.getTimeZone("UTC"))
  4. }
  5. android {
  6. compileSdkVersion 21
  7. buildToolsVersion '21.1.2'
  8. defaultConfig {
  9. applicationId "com.boohee.*"
  10. minSdkVersion 14
  11. targetSdkVersion 21
  12. versionCode 1
  13. versionName "1.0"
  14. // dex突破65535的限制
  15. multiDexEnabled true
  16. // 默认是umeng的渠道
  17. manifestPlaceholders = [UMENG_CHANNEL_VALUE: "umeng"]
  18. }
  19. lintOptions {
  20. abortOnError false
  21. }
  22. signingConfigs {
  23. debug {
  24. // No debug config
  25. }
  26. release {
  27. storeFile file("../yourapp.keystore")
  28. storePassword "your password"
  29. keyAlias "your alias"
  30. keyPassword "your password"
  31. }
  32. }
  33. buildTypes {
  34. debug {
  35. // 显示Log
  36. buildConfigField "boolean", "LOG_DEBUG", "true"
  37. versionNameSuffix "-debug"
  38. minifyEnabled false
  39. zipAlignEnabled false
  40. shrinkResources false
  41. signingConfig signingConfigs.debug
  42. }
  43. release {
  44. // 不显示Log
  45. buildConfigField "boolean", "LOG_DEBUG", "false"
  46. minifyEnabled true
  47. zipAlignEnabled true
  48. // 移除无用的resource文件
  49. shrinkResources true
  50. proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
  51. signingConfig signingConfigs.release
  52. applicationVariants.all { variant ->
  53. variant.outputs.each { output ->
  54. def outputFile = output.outputFile
  55. if (outputFile != null && outputFile.name.endsWith('.apk')) {
  56. // 输出apk名称为boohee_v1.0_2015-01-15_wandoujia.apk
  57. def fileName = "boohee_v${defaultConfig.versionName}_${releaseTime()}_${variant.productFlavors[0].name}.apk"
  58. output.outputFile = new File(outputFile.parent, fileName)
  59. }
  60. }
  61. }
  62. }
  63. }
  64. // 友盟多渠道打包
  65. productFlavors {
  66. wandoujia {}
  67. _360 {}
  68. baidu {}
  69. xiaomi {}
  70. tencent {}
  71. taobao {}
  72. ...
  73. }
  74. productFlavors.all { flavor ->
  75. flavor.manifestPlaceholders = [UMENG_CHANNEL_VALUE: name]
  76. }
  77. }
  78. dependencies {
  79. compile fileTree(dir: 'libs', include: ['*.jar'])
  80. compile 'com.android.support:support-v4:21.0.3'
  81. compile 'com.jakewharton:butterknife:6.0.0'
  82. ...

studio多渠道打包的更多相关文章

  1. [Android Studio] Android studio 多渠道打包(超简洁版)

    [Android Studio] Android studio 多渠道打包(超简洁版) 转载:http://xuyazhou.com/archives/461 http://relex.me/usin ...

  2. Android studio 使用心得(四)—android studio 多渠道打包(二)

    Android studio 使用心得(四)—android studio 多渠道打包 这篇文章讲了一种打包方式.是直接在android studio 里面可视化操作,结合配置文件.我个人觉得严格上来 ...

  3. Android studio 多渠道打包

    一般用渠道的统计无非是用友盟或者其它之类的,今天就以友盟的为例吧. 渠道信息一般在 AndroidManifest.xml中修改以下值: <meta-data android:name=&quo ...

  4. Android Studio多渠道打包(二)

    虽然多渠道打包的方式有很多种,那么今天我要说的通过工具的形式进行多渠道打包 首先,打开Android studio,找到顶部Build,点开 选择红色部分,里面的编辑框可以帮助我们更快的熟悉Gradl ...

  5. Android Studio多渠道打包

    本文所讲述的多渠道打包是基于友盟统计实施的. 多渠道打包的步骤: 1.在AndroidManifest.xml里设置动态渠道变量 <meta-data android:name="UM ...

  6. Android Studio多渠道打包(一)

    1. 多渠道的概念 APP发布到不同的应用平台,监测用户是从哪个平台安装的. 2. 为什么要多渠道打包 统计用户安装APP来源 批量修改生成的apk文件名 可更改包名 生成不同应用名称或图标 3.多渠 ...

  7. Android Studio多渠道打包的使用

    项目地址 https://github.com/mcxiaoke/gradle-packer-plugin 项目介绍 gradle-packer-plugin 是Android多渠道打包工具Gradl ...

  8. 用android studio多渠道打包

    1. 官方教程 https://developer.android.com/studio/build/build-variants.html 2. 设置Build Types参数 打开 Project ...

  9. Android 多渠道打包原理和使用

    每次中午吃饭总会和技术同学聊天.当做 iOS 开发的做安卓开发的人员在一起的时候,他们中间又多了一个话题:iOS 开发难还是安卓开发难. 这个时候做安卓开发的同学最激动说安卓开发要自己画界面.机型复杂 ...

随机推荐

  1. 在Spring Boot框架下使用WebSocket实现聊天功能

    上一篇博客我们介绍了在Spring Boot框架下使用WebSocket实现消息推送,消息推送是一对多,服务器发消息发送给所有的浏览器,这次我们来看看如何使用WebSocket实现消息的一对一发送,模 ...

  2. Vue 踩坑记

    参考: https://forum.vuejs.org/t/unknown-issues-in-change-event-of-radio-in-vue-2-x-webpack-2-x/11034 v ...

  3. 深入Java虚拟机(1)——Java体系结构

    Java体系结构 Java体系结构包括四个独立但相关的技术: 1.Java程序设计语言 2.Java class文件格式 3.Java应用编程接口(API) 4.Java虚拟机 当编写并运行一个Jav ...

  4. linux:cpu 每-CPU 的变量

    每-CPU 的变量 每-CPU 变量是一个有趣的 2.6 内核的特性. 当你创建一个每-CPU变量, 系统中每个处理器获得它自己的这个变量拷贝. 这个可能象一个想做的奇怪的事情, 但是它有自己的优点. ...

  5. Objective-C方法的实现

    Objective-C的方法被两种数据类型描述:一个是选择子(SEL),它用来描述方法的名称;另一个是实现(IMP),它用来描述方法被调用时实际执行的代码(它们基本上只是C函数的指针). 类似于SEL ...

  6. Spring3+Hibernate4连接Oracle11g数据库参数配置

    应用场合:使用SSH框架开发一套应用系统,因为不同的SSH版本+系统架构会导致各种的错误,总结测试了下,成功测试得出本文配置 软件版本:Sping3+Hibernate4+Maven3 主要配置文件内 ...

  7. 24 AIDL案例

    服务端 MainActivity.java package com.qf.day24_aidl_wordserver; import android.app.Activity; import andr ...

  8. sizeof(结构体)和内存对齐以及位域

    Win32平台下的微软C编译器的对齐策略: 1) 结构体变量的首地址能够被其最宽基本类型成员的大小所整除: 备注:编译器在给结构体开辟空间时,首先找到结构体中最宽的基本数据类型,然后寻找内存地址能被该 ...

  9. 在Gazebo中使用DEM構建起伏地形環境

    所需資料下載地址: 1. https://bitbucket.org/osrf/gazebo_tutorials/raw/default/dem/files/ 数字高程模型(致謝谷歌翻譯)概述数字高程 ...

  10. COM原理与实现之二: 聚合

    COM原理与实现之二: 聚合 C++没有同聚合等价的特性.聚合实际上是继承性的一种动态形式.而C++的继承总是静态的,是实现继承.COM是接口继承,通过聚合接口,可以做成动态配置. 研究COM,主要是 ...