close
当前位置: 物联网在线 > 技术文库 > android >

手把手教你AndroidStudio多渠道打包

最近不断有朋友向我咨询AndroidStudio多渠道的打包方法,今天整理一下之前积累的打包套路,写一篇文章,手把手的教给大家。
       说到多渠道,这里不得不提一下友盟统计,友盟统计是大家日常开发中常用的渠道统计工具,而我们的打包方法就是基于友盟统计实施的。按照友盟官方文档说明,渠道信息通常需要在AndroidManifest.xml中配置如下值:

<meta-data android:value="Channel ID" android:name="UMENG_CHANNEL"/>

上面的value值Channel_ID就是渠道标识。我们的期望的就是在编译时候这个值能够自动变化以满足区分多渠道的需求。

(一)在AndroidManifest.xml里设置动态渠道变量 <meta-data android:name="UMENG_CHANNEL" android:value="${UMENG_CHANNEL_VALUE}" /> (二)在build.gradle设置productFlavors 这里假定我们需要打包的渠道为酷安市场、360、小米、百度、豌豆荚 android { productFlavors { kuan { manifestPlaceholders = [UMENG_CHANNEL_VALUE: "kuan"] } xiaomi { manifestPlaceholders = [UMENG_CHANNEL_VALUE: "xiaomi"] } qh360 { manifestPlaceholders = [UMENG_CHANNEL_VALUE: "qh360"] } baidu { manifestPlaceholders = [UMENG_CHANNEL_VALUE: "baidu"] } wandoujia { manifestPlaceholders = [UMENG_CHANNEL_VALUE: "wandoujia"] } } }

或者批量修改

android { productFlavors { kuan {} xiaomi {} qh360 {} baidu {} wandoujia {} } productFlavors.all { flavor -> flavor.manifestPlaceholders = [UMENG_CHANNEL_VALUE: name] } }

所谓ProductFlavors其实就是可定义的产品特性,配合 manifest merger 使用的时候就可以达成在一次编译过程中产生多个具有自己特性配置的版本。上面这个配置的作用就是,为每个渠道包产生不同的 UMENG_CHANNEL_VALUE 的值。

(三)执行打包操作

在AndroidStudio菜单栏点击Build菜单–>Generate signed APK–>选择key,并输入密码

输入密码

然后下一步,选择打包渠道

选择打包渠道

最后点击完成按钮

这里写图片描述

上图可以看到,我们已经成功的将五个渠道包打好。

(四)执行打包命令 ./gradlew assembleRelease

除了使用AndroidStudio图形打包操作以外,我们也可以使用命令行进行打包操作,具体步骤如下:

在AndroidStudio窗口左下角打开Terminal面板,输入gradlew assembleRelease命令

这里写图片描述

如果系统中没有安装Gradle,则会自动下载完成安装及初始化

这里写图片描述

打包成功后会提示BUILD SUCCESSRUL

这里写图片描述

在app–>build–>outputs–>apk路径中就可以看到打包成功后的APK

这里写图片描述

注意,此时这里的APK包名显示为unsigned,也就是说未签名,我们可以继续在build.gradle文件中配置签名信息

signingConfigs { release{ storeFile file("../wooyun_keystore") //签名文件路径 storePassword "123456" keyAlias "123456" keyPassword "123456" //签名密码 } }

然后再次执行gradlew assembleRelease命令

这里写图片描述

这次生成的就是含有签名的渠道包。

当我们的渠道包版本比较多时,可以自定义所打APK包名称,用以区分

// 自定义输出配置,这里我们加上APK版本号1.0 applicationVariants.all { variant -> variant.outputs.each { output -> def outputFile = output.outputFile if (outputFile != null && outputFile.name.endsWith('.apk')) { // 输出apk名称为wooyun_v1.0_wandoujia.apk def fileName = "wooyun_v${defaultConfig.versionName}_${variant.productFlavors[0].name}.apk" output.outputFile = new File(outputFile.parent, fileName) } } }

这里写图片描述

assemble是Gradle中的编译打包命令,有如下用法:

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

gradlew assembleWandoujiaRelease

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

gradlew assembleWandoujiaDebug

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

gradlew assembleWandoujia

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

同理我想打全部Release版本:

gradlew assembleRelease

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


(责任编辑:ioter)

用户喜欢...

用AndroidStudio开发自定义 Gradle plugin

利用AndroidStudio,编写自定义Gradle plugin MavenDeployer 发布plugin 使用Gradle plugin 简介 项目中引入自定义Gradle plugin一般有三种方法: 直接写在 build.gradle中. plugin源码放到rootProjectDir/buildSrc/src/main/groo...


AndroidStudio之如何使用aar

aar 是一个类似于 jar 的文件格式。但是他们之间是有区别的。 jar :仅仅包含class和清单文件,没有资源文件。 aar :包含了class文件和资源文件。说白了就是Android的专属“jar” 将代码打包成...


AndroidStudio的Gradle插件版本更新简介

Android构建系统使用Android的Gradle插件通过Gradle的构建工具来支持构建Android程序。Android的Gradle插件独立于AndroidStudio运行,所以该插件和Gradle构建系统需要独立更新。 更新Android的Gradle插件 自动...


打造酷炫AndroidStudio插件

前面几篇文章学习了AndroidStudio插件的基础后,这篇文章打算开发一个酷炫一点的插件。因为会用到前面的基础,所以如果没有看前面系列文章的话,请先返回。当然,如果有基础的可以忽略...


手把手图文并茂教你用Android Studio编译FFmpeg库并移植

今天就用 Android Studio编译FFmpeg库并移植,并附上调用ffmpeg简单示例,看下Agenda如下: 下载FFmpeg 3.1.3 下载NDK 配置ndk环境 编译FFmpeg 移植到Android平台 调用编译的so示例 下载FFmpeg 3.1.3 网址: 双击解...


AndroidStudio模版

AndroidStudio模版可以很快捷的开发项目,增加开发效率,也能对项目的规范有一定的限制,也不用每次都写一些重复的代码,也能避免一些不必要的Bug出现,只需要注重具体代码实现就好. 二、...