//聲明是Android應(yīng)用程序
apply plugin: 'com.android.application'
android {
compileSdkVersion 23 //編譯SDK的版本
buildToolsVersion "23.0.3"http://SDK目錄下build-tools目錄下可以查找位衩,包括打包常用的appt,dx工具
defaultConfig {
applicationId "gradle.mine.com"http://應(yīng)用程序的唯一識別糠聪,和packagename有所區(qū)別
minSdkVersion 15 //最小SDK,如果Android設(shè)備的系統(tǒng)小于這個版本將無法安裝
targetSdkVersion 23 //目標(biāo)SDK声旺,如果系統(tǒng)剛好是這個sdk就不進行兼容性檢查笔链,運行效率加快
versionCode 1 //版本號
versionName "1.0"http://版本名稱
}
signingConfigs {
release {
storeFile file('demo.keystore')
storePassword 'demo'
keyAlias 'demo'
keyPassword 'demo'
}
}
buildTypes {
release { //release版本的配置
zipAlignEnabled true //zip壓縮
shrinkResources true // 移除無用的resource文件
minifyEnabled true //是否進行混淆
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
//release的Proguard默認(rèn)為Module下的proguard-rules.pro文件.
debuggable false //是否支持調(diào)試
//采用動態(tài)替換字符串的方式生成不同的release.apk
applicationVariants.all { variant ->
variant.outputs.each { output ->
def outputFile = output.outputFile
if (outputFile != null && outputFile.name.endsWith('release.apk')) {
def timeStamp = new Date().format('yyyyMMddHH');
def fileName = "demo-${defaultConfig.versionName}" + "-" + timeStamp + "-lj-" + ".apk";
output.outputFile = file("${outputFile.parent}/${fileName}")
}
}
}
jniDebuggable false //關(guān)閉jni調(diào)試
}
debug {//debug版本的配置
minifyEnabled false
zipAlignEnabled true
shrinkResources true // 移除無用的resource文件
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
debuggable true
jniDebuggable true
}
}
//默認(rèn)的一些文件路徑的配置
sourceSets {
main {
assets.srcDirs = ['assets'] //資源文件
jni.srcDirs 'src/main/jni' //jni文件
jniLibs.srcDir 'src/main/jniLibs' //jni庫
aidl.srcDirs = ['src']
}
}
//程序在編譯的時候會檢查lint,有任何錯誤提示會停止build腮猖,我們可以關(guān)閉這個開關(guān)
lintOptions {
abortOnError false //即使報錯也不會停止打包
checkReleaseBuilds false //打包release版本的時候進行檢測
}
compileOptions {
sourceCompatibility JavaVersion.VERSION_1_7 //JDK的配置
targetCompatibility JavaVersion.VERSION_1_7
}
productFlavors {
//在這里你可以設(shè)置你的產(chǎn)品發(fā)布的一些東西鉴扫,
//比如你現(xiàn)在一共軟件需要發(fā)布到不同渠道,
//且不同渠道中的包名不同澈缺,那么可以在此進行配置坪创;
//甚至可以設(shè)置不同的 AndroidManifest.xml 文件。
flavor1 {
packageName='gradle.mine.com01'
manifest.srcFile 'GradleDemo/AndroidManifest1.xml'
}
flavor2 {
packageName='gradle.mine.com02'
manifest.srcFile 'GradleDemo/AndroidManifest2.xml'
}
googlePlay {
}
}
productFlavors.all {
flavor -> flavor.manifestPlaceholders = [UMENG_CHANNEL_VALUE: name]
}
//所謂ProductFlavors其實就是可定義的產(chǎn)品特性姐赡,
//配合 manifest merger 使用的時候就可以達成在一次編譯
//過程中產(chǎn)生多個具有自己特性配置的版本莱预。
//上面這個配置的作用就是,為每個渠道包產(chǎn)生不同的 UMENG_CHANNEL_VALUE 的值项滑。
}
dependencies {
compile fileTree(dir: 'libs', include: ['*.jar'])//這句話也就是說編譯時依賴 libs 文件夾下的所有 jar 文件
// compile project(':library') //依賴本地library庫
testCompile 'junit:junit:4.12'
compile 'com.android.support:appcompat-v7:23.3.0'//依賴遠(yuǎn)程庫
}
buildConfigField的妙用
在gradle中默認(rèn)會生成一個BuildConfig.java文件依沮,該文件的路徑為app\build\generated\source\buildConfig\debug\packagename\BuildConfig.java
,打開該文件枪狂,默認(rèn)代碼如下:
/**
* Automatically generated file. DO NOT MODIFY
* 該頁面是自動生成危喉,開發(fā)者不需要手動改動
*/
package com.gome.h5.h5demo;
public final class BuildConfig {
public static final boolean DEBUG = Boolean.parseBoolean("true");
public static final String APPLICATION_ID = "com.gome.h5.h5demo";
public static final String BUILD_TYPE = "debug";
public static final String FLAVOR = "";
public static final int VERSION_CODE = 1;
public static final String VERSION_NAME = "1.0";
}
在app/build.gradle下android-buildTypes--debug/release添加buildConfigField方法即可buildConfigField(String type, String name, String value)
,我的調(diào)用格式如下:
android {
……
defaultConfig {
……
}
buildTypes {
debug {
buildConfigField("String","baseUrl","\"https://www.baidu.com\"")
}
release {
buildConfigField("String","baseUrl","\"https://www.baidu.com\"")
}
}
}
在BuildConfig
中就會生成baseUrl
這個常量摘完,可以直接在代碼里面調(diào)用即可BuildConfig.baseUrl
姥饰。
總結(jié)一下就是:這個屬性就是充當(dāng)配置文件的作用。所有聲明的屬性孝治,都會在BuildConfig中生成相應(yīng)的常量列粪。