Android 配置gradle實現(xiàn)VersionCode自增實例
我是因為構(gòu)建多渠道包的時候有這個需求,平常工作多個渠道包頻繁的打包,總會忘記versioncode提高一下,從而打包出來的apk無法覆蓋原先的安裝包,這里只介紹了自增VersionCode,網(wǎng)上還有動態(tài)設置versionName,有需要也可以看看其他人的實現(xiàn)。
以下介紹下配置Gradle自動增加versionCode的值
一、項目的根目錄新建一個文件version.properties
二、文件內(nèi)容寫上初始的versioncode
三、主gradle配置
def getVersionCode() { def versionFile = file('version.properties') if (versionFile.canRead()) { def Properties versionProps = new Properties() versionProps.load(new FileInputStream(versionFile)) def versionCode = versionProps['VERSION_CODE'].toInteger() def runTasks = gradle.startParameter.taskNames //僅在assembleRelease任務是增加版本號,其他渠道包在此分別配置 if ('assembleInsectRelease' in runTasks) { versionProps['VERSION_CODE'] = (++versionCode).toString() versionProps.store(versionFile.newWriter(), null) } return versionCode } else { throw new GradleException("Could not find version.properties!") } } android { .... }
只在release模式下才自增,保證測試的時候versionCode不增加
四、調(diào)用
def currentVersionCode = getVersionCode() defaultConfig { applicationId 'com.chongzzz.texas' minSdkVersion 15 targetSdkVersion 25 multiDexEnabled true versionCode currentVersionCode versionName "1.0.1.21" }
補充知識:Android 動態(tài)替換 Manifest.xml中的值
根據(jù)情況替換 Manifest.xml 中的值
android 中有很多個渠道,每個渠道都有 debug 和 release 版本, 如果Manifest.xml 中每個版本有不同的值
一般的可以用 manifestPlaceholders = [APP_KEY : '對應的值'] 來替換,在 debug和 release 的時候也可以,但是多渠道的時候可能就會有些問題了
解決方式
1、簡單
兩個渠道
flavorDimensions 'defaultDimension' productFlavors { alibaba { } tencent { } }
每個渠道的版本的不同的值
ext { alibabaDebug = 'alibabaDebug' alibabaRelease = 'alibabaRelease' tencentDebug = 'tencentDebug' tencentRelease = 'tencentRelease' }
替換值
afterEvaluate { project.android.applicationVariants.all { variant -> // 最簡單的方法 variant.mergedFlavor.manifestPlaceholders = [APP_KEY: project."${variant.name}"] } }
2、自定義任務,和上面的其實差不多
兩個渠道
flavorDimensions 'defaultDimension' productFlavors { alibaba { } tencent { } }
每個渠道的版本的不同的值
ext { alibabaDebug = 'alibabaDebug' alibabaRelease = 'alibabaRelease' tencentDebug = 'tencentDebug' tencentRelease = 'tencentRelease' }
替換值
afterEvaluate { project.android.applicationVariants.all { variant -> // 自定義任務 tasks.create("${variant.name}ManifestPlaceHolder", ManifestPlaceHolder) { current = variant } variant.outputs.first().processManifest.dependsOn "${variant.name}ManifestPlaceHolder" } } class ManifestPlaceHolder extends DefaultTask { @Input def current @TaskAction def changeManifestPlaceHolder() { current.mergedFlavor.manifestPlaceholders = [APP_KEY: project."${current.name}"] } }
以上這篇Android 配置gradle實現(xiàn)VersionCode自增實例就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
Android實現(xiàn)將View保存成Bitmap的方法
這篇文章主要介紹了Android實現(xiàn)將View保存成Bitmap的方法,涉及Android畫布Canvas、位圖bitmap及View的相關使用技巧,需要的朋友可以參考下2016-06-06Android onCreateOptionsMenu的使用方法總結(jié)
這篇文章主要介紹了Android onCreateOptionsMenu的使用方法總結(jié)的相關資料,在Android下,每一個activity都捆綁了一個Menu,要想定義和使用菜單,都必須在Activity下進行操作,需要的朋友可以參考下2017-08-08Android 超詳細講解fitsSystemWindows屬性的使用
fitsSystemWindows屬性可以讓view根據(jù)系統(tǒng)窗口來調(diào)整自己的布局;簡單點說就是我們在設置應用布局時是否考慮系統(tǒng)窗口布局,這里系統(tǒng)窗口包括系統(tǒng)狀態(tài)欄、導航欄、輸入法等,包括一些手機系統(tǒng)帶有的底部虛擬按鍵2022-03-03Android自定義View實現(xiàn)帶4圓角或者2圓角的效果
這篇文章主要介紹了Android自定義View實現(xiàn)帶4圓角或者2圓角的效果,本文通過實例代碼截圖給大家展示的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-03-03解析Android開發(fā)優(yōu)化之:對界面UI的優(yōu)化詳解(二)
在一個應用程序中,一般都會存在多個Activity,每個Activity對應著一個UI布局文件。一般來說,為了保持不同窗口之間的風格統(tǒng)一,在這些UI布局文件中,幾乎肯定會用到很多相同的布局2013-05-05Android pdf viewer在android studio應用問題說明詳解
這篇文章主要介紹了Android pdf viewer在android studio應用問題說明的相關資料,本文介紹的非常詳細,具有參考借鑒價值,需要的朋友可以參考下2016-09-09