全局設置
如果有很多項目,可以設置全局來統一管理版本號或依賴庫,根目錄下build.gradle下:
ext { compileSdkVersion = 23 buildToolsVersion = "23.0.2" minSdkVersion = 14 targetSdkVersion = 23 }
app/build.gradle
android { compileSdkVersion rootProject.ext.compileSdkVersion buildToolsVersion rootProject.ext.buildToolsVersion defaultConfig { applicationId "com.example.android" minSdkVersion rootProject.ext.minSdkVersion targetSdkVersion rootProject.ext.targetSdkVersion versionCode 1 versionName "1.0" }
可以在根目錄下建個config.gradle,然后只需在根目錄下build.gradle最頂部加上下面一行代碼,然后同步下,意思就是所有的子項目或者所有的modules都可以從這個配置文件里讀取內容。
apply from: "config.gradle"
config.gradle
ext { android = [ compileSdkVersion: 23, buildToolsVersion: "23.0.2", minSdkVersion : 14, targetSdkVersion : 22, ] dependencies = [ appcompatV7': 'com.android.support:appcompat-v7:23.2.1', design : 'com.android.support:design:23.2.1' ] }
app/build.gradle
android { compileSdkVersion rootProject.ext.android.compileSdkVersion buildToolsVersion rootProject.ext.buildToolsVersion defaultConfig { applicationId "com.example.android" minSdkVersion rootProject.ext.android.minSdkVersion targetSdkVersion rootProject.ext.android.targetSdkVersion versionCode 1 versionName "1.0" } ... dependencies { compile fileTree(dir: 'libs', include: ['*.jar']) testCompile 'junit:junit:4.12' compile rootProject.ext.dependencies.appcompatV7 compile rootProject.ext.dependencies.design }
自定義BuildConfig
實際開發中服務器可能有正式環境和測試環境,gradle可以通過buildConfigField來配置。
defaultConfig { buildConfigField 'String','API_SERVER_URL','"http://url/"' }
buildConfigField 一共有3個參數,第一個是數據類型,和Java的類型是對等的;第二個參數是常量名,這里是API_SERVER_URL;第三個參數就是你要配置的值。
如圖路徑下就有個常量API_SERVER_URL,如何在代碼取得這個常量值:
Log.d("wxl", "API_SERVER_URL=" + BuildConfig.API_SERVER_URL);
啟用proguard混淆
一般release發布版本是需要啟用混淆的,這樣別人反編譯之后就很難分析你的代碼,而我們自己開發調試的時候是不需要混淆的,所以debug不啟用混淆。對release啟用混淆的配置如下:
android { buildTypes { release { minifyEnabled true//是否啟動混淆 proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' } } }
minifyEnabled為true表示啟用混淆,proguardFile是混淆使用的配置文件,這里是module根目錄下的proguard-rules.pro文件