a亚洲精品_精品国产91乱码一区二区三区_亚洲精品在线免费观看视频_欧美日韩亚洲国产综合_久久久久久久久久久成人_在线区

首頁 > 系統 > Android > 正文

Android Studio多渠道打包的配置方法

2019-10-21 21:33:55
字體:
來源:轉載
供稿:網友

說到多渠道,這里不得不提一下友盟統計,友盟統計是大家日常開發中常用的渠道統計工具,而我們的打包方法就是基于友盟統計實施的。按照友盟官方文檔說明,渠道信息通常需要在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 {    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 {    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,并輸入密碼 

Android,Studio,多渠道,打包

然后下一步,選擇打包渠道

Android,Studio,多渠道,打包

最后點擊完成按鈕,我們已經成功的將五個渠道包打好。

(四)執行打包命令 ./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 "your password"      keyAlias "your alias"      keyPassword "your password" //簽名密碼    }  }

然后再次執行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名稱為frank_v1.0_wandoujia.apk            def fileName = "frank_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版本都打出來。

下面是我個人的build.gradle配置文件,分享給大家,以作參考

apply plugin: 'com.android.application'android {  compileSdkVersion 23  buildToolsVersion "23.0.2"  defaultConfig {    applicationId "com.frank.example"    minSdkVersion 15    targetSdkVersion 23    versionCode 1    versionName "1.0"  }   //簽名  signingConfigs {    debugConfig {      storeFile file("../frank_keystore")   //簽名文件      storePassword "your password"      keyAlias "your alias"      keyPassword "your password" //簽名密碼    }    release{      storeFile file("../wooyun_keystore")   //簽名文件      storePassword "your password"      keyAlias "your alias"      keyPassword "your password" //簽名密碼    }  }  buildTypes {    release {      minifyEnabled false      proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'      // 自定義輸出配置      applicationVariants.all { variant ->        variant.outputs.each { output ->          def outputFile = output.outputFile          if (outputFile != null && outputFile.name.endsWith('.apk')) {            // 輸出apk名稱為frank_v1.0_wandoujia.apk            def fileName = "frank_v${defaultConfig.versionName}_${variant.productFlavors[0].name}.apk"            output.outputFile = new File(outputFile.parent, fileName)          }        }      }    }  }  productFlavors {    xiaomi {}    qh360 {}    baidu {}    wandoujia {}  }  productFlavors.all {    flavor -> flavor.manifestPlaceholders = [UMENG_CHANNEL_VALUE: name]  }}dependencies {  compile fileTree(dir: 'libs', include: ['*.jar'])  testCompile 'junit:junit:4.12'  compile 'com.android.support:appcompat-v7:23.3.0'}

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對VEVB武林網的支持。


注:相關教程知識閱讀請移步到Android開發頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 国内福利视频 | 伊人狠狠干 | 欧美在线观看一区 | 情趣视频在线免费观看 | 日韩午夜影院 | 国产精品九九九 | 黄色影视片 | 中文字幕一区二区三区四区 | 噜噜噜在线视频 | 国产精品美女视频网站 | 国产福利精品一区二区三区 | 国产精品久久久久久久久久久久久久 | 九色在线| www国产一区 | 九九在线视频 | 1区2区视频| 国产亚洲精品成人av久久ww | av在线成人 | 亚洲蜜臀av乱码久久精品蜜桃 | 免费观看一区二区三区毛片 | 欧美大片免费高清观看 | 欧美精品久久久久久久监狱 | 热久久这里只有精品 | 亚洲一区二区三区免费在线观看 | 日本激情视频 | 色婷婷综合在线 | 国产电影精品久久 | 精品国产91久久 | 国产精品成av人在线视午夜片 | 日韩欧美亚洲 | 日操 | 欧美综合一区 | 国产视频欧美视频 | 欧美成人区 | av中文字幕网 | 欧洲亚洲一区 | 国产91在线免费观看 | 精品久久影院 | 精品国产欧美一区二区三区成人 | 国产天堂一区二区 | 精品欧美一区二区三区精品久久 |