欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Android幾種多渠道打包的步驟詳解

 更新時間:2019年09月04日 14:02:04   作者:終于等到Ni  
在不同的應(yīng)用市場可能有不同的統(tǒng)計需求,需要為每個應(yīng)用市場發(fā)布一個安裝包,這里就引出了Android的多渠道打包。這篇文章主要介紹了Android幾種多渠道打包,需要的朋友可以參考下

1、什么是多渠道打包

  在不同的應(yīng)用市場可能有不同的統(tǒng)計需求,需要為每個應(yīng)用市場發(fā)布一個安裝包,這里就引出了Android的多渠道打包。在安裝包中添加不同的標(biāo)識,以此區(qū)分各個渠道,方便統(tǒng)計app在市場的各種。

2、幾種打包方式

  • 友盟 UMeng
  • Android Studio自帶
  • 美團 Walle

3、開始使用

  3.1 友盟UMeng

  第一步:在AndroidManifest中添加

<meta-data 
 android:name="UMENG_CHANNEL" 
 android:value="${channel}" />

  第二步:在build.gradle中添加,baidu {}為指定渠道名稱簡寫

build {
 ......
 productFlavors {
 baidu {}
 xiaomi {}
 qihu360 {}
 yingyongbao {}
 huawei {}
 }
 productFlavors.all {
 flavor -> flavor.manifestPlaceholders = [UMENG_CHANNEL: name]
 } 
}

  第三步:設(shè)置輸出APK名稱

  Android Studio 2.3版本:

build {
 ......
 applicationVariants.all { variant ->
 variant.outputs.each { output ->
 def outputFile = output.outputFile
 if (outputFile != null && outputFile.name.endsWith('.apk')) {
  def fileName = "driver_${variant.productFlavors[0].name}_v${defaultConfig.versionName}.apk"
  output.outputFile = new File(outputFile.parent, fileName)
 }
 }
 }
}

  Android Studio 3.0版本:

build {
 ......
 applicationVariants.all { variant ->
 variant.outputs.all {
 outputFileName = "driver_${variant.productFlavors[0].name}_v${variant.versionName}.apk"
 }
 }
}

  Gradle后如果出現(xiàn)如下報錯

  則需要配置flavor dimension的維度是該版本號,這樣維度就是都是統(tǒng)一的了

build {
 ......
 defaultConfig {
 ......
 flavorDimensions "versionCode"
 }
}

  第四步:編譯打包

  Build - Generate Signed Bundle or APK - 選擇Release或Debug

  3.2 Android Studio自帶

  Android Studio多形態(tài)打包與友盟打包方式相同,但是標(biāo)簽<meta-data>中name可自行定義,不限制為"UMENG_CHANNEL"

<meta-data 
 android:name="UMENG_CHANNEL" //可以隨意定義
 android:value="${channel}" />

  3.3 美團 Walle

  第一步:配置根build.gradle

buildscript {
 dependencies {
 classpath 'com.mcxiaoke.packer-ng:plugin:2.0.1'
 }
}

  第二步:配置App build.gradle

apply plugin: 'packer'
dependencies {
 ......
 implementation 'com.mcxiaoke.packer-ng:helper:2.0.1'
}

  第三步:插件配置

build {
 ......
 packer {
 archiveNameFormat = '${buildType}-v${versionName}-${channel}' // 定義輸出APK名稱
 archiveOutput = new File(project.rootProject.buildDir, "apks") // 設(shè)置APK輸出目錄
 channelFile = new File(project.rootDir, "channel.txt") // 添加渠道配置文件
 }
}

  第四步:新建渠道配置文件channel.txt

  在工程根目錄下新建channel.txt文件,如圖

  文件內(nèi)容為渠道名稱,要求:必須每一行一個渠道

  第五步:編譯打包

  使用Terminal命令:

gradlew clean apkRelease

可參考:[美團多渠道打包官方文檔](https://github.com/mcxiaoke/packer-ng-plugin)

4、獲取渠道信息

  1、友盟 和 Android Studio獲取方式

  通過讀取AndroidManifest中<meta-data>標(biāo)簽

private String getChannel() {
 try { 
   PackageManager pm = getPackageManager(); 
   ApplicationInfo appInfo = pm.getApplicationInfo(getPackageName(), PackageManager.GET_META_DATA); 
   String channel = appInfo.metaData.getString(key); // key為<meta-data>標(biāo)簽中的name 
   if (!TextUtils.isEmpty(channel)) {  
   return channel;
   }
  } catch (Exception e) { 
   e.printStackTrace();
  }
  return null;
}

  2、美團 Walle獲取方式

  美團集成自帶獲取方法

private String getChannel() {
 try { 
   PackageManager pm = getPackageManager(); 
   ApplicationInfo appInfo = pm.getApplicationInfo(getPackageName(), PackageManager.GET_META_DATA); 
   String channel = appInfo.metaData.getString(key); // key為<meta-data>標(biāo)簽中的name 
   if (!TextUtils.isEmpty(channel)) {  
   return channel;
   }
  } catch (Exception e) { 
   e.printStackTrace();
  }
  return null;
}

總結(jié)

以上所述是小編給大家介紹的Android幾種多渠道打包的步驟詳解,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!

相關(guān)文章

最新評論