友盟多渠道打包 Android Apk
2017-04-14 18:59
756 查看
目前项目中使用到了多渠道打包的功能,首先理解多渠道打包,渠道可理解成安卓apk应用市场平台,所以多渠道打包可以理解成在打包多个应用市场的apk,要在每个应用市场上打包一个安卓Apk,这样好处是可以在查看apk在每个安卓市场的下载量,活跃度,便于公司进行重点运营和推广,因为友盟多渠道统计比较成熟,所以公司采用的是友盟的多渠道打包统计;
点击官网 友盟+ 应用统计
多渠道打包的步骤:
1,首先去到上面官网为自己的应用申请Appkey
2,然后下载集成SDK,本人是使用AndroidStudio集成的,好处是直接在app Module 的build.gradle中添加如下依赖就可以:
3.manifest的配置主要包括添加权限,以下权限缺一不可,填写Appkey和填写渠道id三部分
上面不清楚可以去到官网仔细浏览一遍;
从第三部开始 我自己Module 中 manifest的应用配置如下:
因为我们要在多个应用市场上面打包,所以这里的value的值我们不能写死,比如写huawei,这样只打华为应用市场的apk,而我们是多个市场的,所以这里使用占位符是动态获取;
下面要渠道app build.gradle中进行配置
1.首先要添加一个 渠道号
2.配置打包相关
上面都有注释 打包相关配置buildTypes中分别配置了测试(debug)和发布(release),我们最主要关心的是签名配置 signingConfig 的值,我们都写在了signingConfigs的配置了,而且这个要写在 buildTypes 的上面,不然打包的时候会报如下错误:
至于
是我们申请apk打包的的时候都必须要自己弄得,(没搞过的话,自己随便建个工程打包就知道了)
3.下面就是最关键的部分了
配置多渠道打包:也是我们公司产品要发布的应用市场
解释:productFlavors 支持多渠道打包,使用它的话,可以为下面每一个市场打包一个apk,里面也是用了manifestPlaceholders 使用相关的值替换了UMENG_CHANNEL_VALUE
如果怕麻烦,可以像上面那样写使用
会遍历productFlavors下面所有的名称替换UMENG_CHANNEL_VALUE ;
最后使用gradlew assembleRelease 打生产包 ;gradlew assembleDebug 打测试包
点击此处下载实例Demo
点击官网 友盟+ 应用统计
多渠道打包的步骤:
1,首先去到上面官网为自己的应用申请Appkey
2,然后下载集成SDK,本人是使用AndroidStudio集成的,好处是直接在app Module 的build.gradle中添加如下依赖就可以:
dependencies { compile 'com.umeng.analytics:analytics:latest.integration' }
3.manifest的配置主要包括添加权限,以下权限缺一不可,填写Appkey和填写渠道id三部分
<manifest……> <uses-sdk android:minSdkVersion="8"></uses-sdk> <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/> <uses-permission android:name="android.permission.ACCESS_WIFI_STATE" /> <uses-permission android:name="android.permission.INTERNET"/> <uses-permission android:name="android.permission.READ_PHONE_STATE"/> <application ……> …… <activity ……/> <meta-data android:value="YOUR_APP_KEY" android:name="UMENG_APPKEY"/> <meta-data android:value="Channel ID" android:name="UMENG_CHANNEL"/> </application> </manifest>
上面不清楚可以去到官网仔细浏览一遍;
从第三部开始 我自己Module 中 manifest的应用配置如下:
<application android:allowBackup="true" android:icon="@mipmap/ic_launcher" android:label="@string/app_name" android:supportsRtl="true" android:theme="@style/AppTheme"> <activity android:name=".MainActivity"> <intent-filter> <action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" /> </intent-filter> </activity> <meta-data android:name="UMENG_APPKEY" android:value="4f83c5d852701564c0000011" /><!--友盟 Appkey 自己应用注册申请来的--> <meta-data android:name="UMENG_CHANNEL" android:value="${UMENG_CHANNEL_VALUE}" /> <!--渠道号,多渠道这里使用了占位符$--> </application>
因为我们要在多个应用市场上面打包,所以这里的value的值我们不能写死,比如写huawei,这样只打华为应用市场的apk,而我们是多个市场的,所以这里使用占位符是动态获取;
下面要渠道app build.gradle中进行配置
1.首先要添加一个 渠道号
android { compileSdkVersion 25 buildToolsVersion "25.0.2" defaultConfig { applicationId "multi_channel.shion.com.multichannel" minSdkVersion 9 targetSdkVersion 25 versionCode 1 versionName "1.0" testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner" // AndroidManifest.xml 里面UMENG_CHANNEL的value为 ${UMENG_CHANNEL_VALUE} manifestPlaceholders = [UMENG_CHANNEL_VALUE: "umeng"]//添加一个默认渠道号 }
2.配置打包相关
//添加我们签名文件配置 signingConfigs { debug { storeFile file("liverpool.jks")//key store storePassword "123456" keyAlias "multichannel" keyPassword "123456" } release { storeFile file("liverpool.jks") storePassword "123456" keyAlias "multichannel" keyPassword "123456" } } //打包相关配置 buildTypes { debug { shrinkResources true // 移除无用的resource文件 minifyEnabled false //不启用混淆 proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro', 'proguard-fresco.pro' //签名配置 signingConfig signingConfigs.debug } release { shrinkResources true // 移除无用的resource文件 minifyEnabled false //不启用混淆 proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' //签名配置 signingConfig signingConfigs.release } }
上面都有注释 打包相关配置buildTypes中分别配置了测试(debug)和发布(release),我们最主要关心的是签名配置 signingConfig 的值,我们都写在了signingConfigs的配置了,而且这个要写在 buildTypes 的上面,不然打包的时候会报如下错误:
至于
release { storeFile file("liverpool.jks") storePassword "123456" keyAlias "multichannel" keyPassword "123456" }
是我们申请apk打包的的时候都必须要自己弄得,(没搞过的话,自己随便建个工程打包就知道了)
3.下面就是最关键的部分了
配置多渠道打包:也是我们公司产品要发布的应用市场
//多渠道打包支持 productFlavors { Alpha {//自己打包测试使用 // manifestPlaceholders = [UMENG_CHANNEL_VALUE: Alpha] } Tencent {//投放应用宝市场 // manifestPlaceholders = [UMENG_CHANNEL_VALUE: Tencent] } Baidu {//投放百度市场 // manifestPlaceholders = [UMENG_CHANNEL_VALUE: Baidu] } Wandoujia {//投放豌豆荚市场 // manifestPlaceholders = [UMENG_CHANNEL_VALUE: Wandoujia] } PP {//投放PP助手市场 // manifestPlaceholders = [UMENG_CHANNEL_VALUE: PP] } Qihoo {//投放PP助手市场 // manifestPlaceholders = [UMENG_CHANNEL_VALUE: Qihoo] } Vivo {//投放vivo市场 // manifestPlaceholders = [UMENG_CHANNEL_VALUE: Vivo] } Oppo {//投放oppo市场 // manifestPlaceholders = [UMENG_CHANNEL_VALUE: Oppo] } Xiaomi {//投放小米市场 // manifestPlaceholders = [UMENG_CHANNEL_VALUE: Xiaomi] } Meizu {//投放魅族市场 // manifestPlaceholders = [UMENG_CHANNEL_VALUE: Meizu] } Huawei {//投放华为应用市场 // manifestPlaceholders = [UMENG_CHANNEL_VALUE: Huawei] } Lenovo {//投放联想市场 // manifestPlaceholders = [UMENG_CHANNEL_VALUE: Lenovo] } Letv {//投放乐视市场 // manifestPlaceholders = [UMENG_CHANNEL_VALUE: Letv] } Gionee {//投放金立市场 // manifestPlaceholders = [UMENG_CHANNEL_VALUE: Gionee] } HiMarket {//投放安卓市场 // manifestPlaceholders = [UMENG_CHANNEL_VALUE: HiMarket] } } //注意我注释掉的,可以去掉注释,那样的话,下面这句就可以不用了 productFlavors.all { flavor -> flavor.manifestPlaceholders = [UMENG_CHANNEL_VALUE: name] }
解释:productFlavors 支持多渠道打包,使用它的话,可以为下面每一个市场打包一个apk,里面也是用了manifestPlaceholders 使用相关的值替换了UMENG_CHANNEL_VALUE
如果怕麻烦,可以像上面那样写使用
productFlavors.all { flavor -> flavor.manifestPlaceholders = [UMENG_CHANNEL_VALUE: name] }
会遍历productFlavors下面所有的名称替换UMENG_CHANNEL_VALUE ;
最后使用gradlew assembleRelease 打生产包 ;gradlew assembleDebug 打测试包
点击此处下载实例Demo
相关文章推荐
- 安卓学习笔记---Android 开发技巧-以友盟为例在Android Studio利用gradle进行多渠道打包和apk签名发布
- Android APK签名及友盟多渠道打包
- Android 开发技巧-以友盟为例在Android Studio利用gradle进行多渠道打包和apk签名发布
- Android中apk多渠道打包----友盟打包实现步骤
- windows下Android利用ant自动编译、修改配置文件、批量多渠道,打包生成apk文件
- Android 自动编译、打包生成apk文件 4 - 多渠道批量打包
- linux(以ubuntu为例)下Android利用ant自动编译、修改配置文件、批量多渠道,打包生成apk文件
- Android apk多渠道自动打包 - 不提供工具,只提供源码
- Androidstudio 多渠道打包apk
- Android apk多渠道 打包
- android apk多渠道打包
- Android apk多渠道自动打包 - 不提供工具,只提供源码
- Android多渠道打包APK
- Android多渠道打包apk
- android studio多渠道多包名多apk打包
- windows下Android利用ant自动编译、修改配置文件、批量多渠道,打包生成apk文件
- Android Studio多渠道打包(以友盟为例)
- Android使用Ant进行apk多渠道打包
- windows下Android利用ant自动编译、修改配置文件、批量多渠道,打包生成apk文件
- linux(以ubuntu为例)下Android利用ant自动编译、修改配置文件、批量多渠道,打包生成apk文件