您好,登錄后才能下訂單哦!
說到多渠道,這里不得不提一下友盟統計,友盟統計是大家日常開發中常用的渠道統計工具,而我們的打包方法就是基于友盟統計實施的。按照友盟官方文檔說明,渠道信息通常需要在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"] } qh460 { manifestPlaceholders = [UMENG_CHANNEL_VALUE: "qh460"] } baidu { manifestPlaceholders = [UMENG_CHANNEL_VALUE: "baidu"] } wandoujia { manifestPlaceholders = [UMENG_CHANNEL_VALUE: "wandoujia"] } } }
或者批量修改
android { productFlavors { xiaomi {} qh460 {} 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圖形打包操作以外,我們也可以使用命令行進行打包操作,具體步驟如下:
注意,此時這里的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 {} qh460 {} 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' }
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對億速云的支持。如果你想了解更多相關內容請查看下面相關鏈接
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。