Android Studio多渠道打包的配置方法
說(shuō)到多渠道,這里不得不提一下友盟統(tǒng)計(jì),友盟統(tǒng)計(jì)是大家日常開(kāi)發(fā)中常用的渠道統(tǒng)計(jì)工具,而我們的打包方法就是基于友盟統(tǒng)計(jì)實(shí)施的。按照友盟官方文檔說(shuō)明,渠道信息通常需要在AndroidManifest.xml中配置如下值:
<meta-data android:value="Channel ID" android:name="UMENG_CHANNEL"/>
上面的value值Channel_ID就是渠道標(biāo)識(shí)。我們的期望的就是在編譯時(shí)候這個(gè)值能夠自動(dòng)變化以滿足區(qū)分多渠道的需求。
(一)在AndroidManifest.xml里設(shè)置動(dòng)態(tài)渠道變量
<meta-data android:name="UMENG_CHANNEL" android:value="${UMENG_CHANNEL_VALUE}" />
(二)在build.gradle設(shè)置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其實(shí)就是可定義的產(chǎn)品特性,配合 manifest merger 使用的時(shí)候就可以達(dá)成在一次編譯過(guò)程中產(chǎn)生多個(gè)具有自己特性配置的版本。上面這個(gè)配置的作用就是,為每個(gè)渠道包產(chǎn)生不同的 UMENG_CHANNEL_VALUE 的值。
(三)執(zhí)行打包操作
在AndroidStudio菜單欄點(diǎn)擊Build菜單–>Generate signed APK–>選擇key,并輸入密碼
然后下一步,選擇打包渠道
最后點(diǎn)擊完成按鈕,我們已經(jīng)成功的將五個(gè)渠道包打好。
(四)執(zhí)行打包命令 ./gradlew assembleRelease
除了使用AndroidStudio圖形打包操作以外,我們也可以使用命令行進(jìn)行打包操作,具體步驟如下:
- 在AndroidStudio窗口左下角打開(kāi)Terminal面板,輸入gradlew assembleRelease命令
- 如果系統(tǒng)中沒(méi)有安裝Gradle,則會(huì)自動(dòng)下載完成安裝及初始化
- 打包成功后控制臺(tái)會(huì)提示BUILD SUCCESSRUL
- 在app–>build–>outputs–>apk路徑中就可以看到打包成功后的APK
注意,此時(shí)這里的APK包名顯示為unsigned,也就是說(shuō)未簽名,我們可以繼續(xù)在build.gradle文件中配置簽名信息
signingConfigs { release{ storeFile file("../wooyun_keystore") //簽名文件路徑 storePassword "your password" keyAlias "your alias" keyPassword "your password" //簽名密碼 } }
然后再次執(zhí)行g(shù)radlew assembleRelease命令
這次生成的就是含有簽名的渠道包。
當(dāng)我們的渠道包版本比較多時(shí),可以自定義所打APK包名稱,用以區(qū)分
// 自定義輸出配置,這里我們加上APK版本號(hào)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版本,執(zhí)行如下命令就好了:
gradlew assembleWandoujiaRelease
如果我們想打包wandoujia渠道的debug版本,執(zhí)行如下命令就好了:
gradlew assembleWandoujiaDebug
如果我們只打wandoujia渠道版本,則:
gradlew assembleWandoujia
此命令會(huì)生成wandoujia渠道的Release和Debug版本
同理我想打全部Release版本:
gradlew assembleRelease
這條命令會(huì)把Product Flavor下的所有渠道的Release版本都打出來(lái)。
下面是我個(gè)人的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' }
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接
- Android Gradle多渠道打包的實(shí)現(xiàn)方法
- Android Studio中一套代碼多渠道打包的實(shí)現(xiàn)方法
- Android 多渠道(友盟)打包教程分享
- Android多渠道打包時(shí)獲取當(dāng)前渠道的方法
- Android使用美團(tuán)多渠道打包方案詳解
- Android幾種多渠道打包的步驟詳解
- Android多渠道打包總結(jié)(推薦)
- 使用Android Studio Gradle實(shí)現(xiàn)友盟多渠道打包
- Android Studio多渠道打包、自定義打包APK名稱
- Android Studio多渠道打包套路
- Android使用Walle實(shí)現(xiàn)多渠道打包功能的實(shí)現(xiàn)示例
相關(guān)文章
android開(kāi)發(fā)中使用java觀察者模式
遇到android程序中后入棧的一個(gè)Activity需要更新之前一個(gè)或者兩個(gè)以上Activity中的數(shù)據(jù)時(shí)使用,或者需要在adapter中修改Activity或者fragment的數(shù)據(jù)和ui等2014-02-02Android之使用Android-query框架開(kāi)發(fā)實(shí)戰(zhàn)(二)
這篇文章主要介紹了Android之使用Android-query框架開(kāi)發(fā)實(shí)戰(zhàn)(二)的相關(guān)資料,需要的朋友可以參考下2015-10-10Android Service服務(wù)詳細(xì)介紹及使用總結(jié)
這篇文章主要介紹了Android Service 服務(wù)的詳細(xì)資料,網(wǎng)上關(guān)于Android Service 服務(wù)的文章比較多,但是不是很全面,不夠細(xì)致,畢竟是Android 四大組件之一,重要性不用說(shuō),這里總結(jié)下,需要的朋友可以參考下2016-12-12Android設(shè)備獲取掃碼槍掃描的內(nèi)容與可能遇到的問(wèn)題解決
這篇文章主要給大家介紹了關(guān)于Android設(shè)備獲取掃碼槍掃描內(nèi)容的方法,以及在開(kāi)發(fā)中可能會(huì)遇到的問(wèn)題的解決方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。2017-11-11Android開(kāi)發(fā)之搜索框SearchView用法示例
這篇文章主要介紹了Android開(kāi)發(fā)之搜索框SearchView用法,結(jié)合實(shí)例形式分析了Android搜索框SearchView的基本功能、用法及相關(guān)操作注意事項(xiàng),需要的朋友可以參考下2019-03-03Android中判斷手機(jī)是否聯(lián)網(wǎng)實(shí)例
這篇文章主要介紹了Android中判斷手機(jī)是否聯(lián)網(wǎng)實(shí)例,包括xml配置文件及功能代碼的實(shí)現(xiàn),需要的朋友可以參考下2014-10-10android listview 水平滾動(dòng)和垂直滾動(dòng)的小例子
android listview 水平滾動(dòng)和垂直滾動(dòng)的小例子,需要的朋友可以參考一下2013-05-05