在根目錄創(chuàng)建config.gradle,并把公用的字段定義好
// 添加多個(gè)自定義屬性,可以通過ext代碼塊
ext {
username = "simon"
// 生產(chǎn)/開發(fā)環(huán)境(正式/測(cè)試)
isRelease = true
// 建立Map存儲(chǔ),對(duì)象名锐秦、key都可以自定義,groovy糖果語法内舟,非常靈活
androidId = [
compileSdkVersion: 28,
buildToolsVersion: "29.0.0",
minSdkVersion : 19,
targetSdkVersion : 28,
versionCode : 1,
versionName : "1.0"
]
appId = [
app : "com.netease.modular.gradle",
library: "com.netease.modular.library"
]
// 生產(chǎn)/開發(fā)環(huán)境URL
url = [
"debug" : "https://11.22.33.44/debug",
"release": "https://11.22.33.44/release"
]
supportLibrary = "28.0.0" // ${xxx}
// 第三方庫
dependencies = [
"appcompat" : "com.android.support:appcompat-v7:${supportLibrary}",
"recyclerview" : "com.android.support:recyclerview-v7:${supportLibrary}",
"constraint" : "com.android.support.constraint:constraint-layout:1.1.3"
]
}
接下來看app中的build.gradle
如果要在build.gradle中打印墓塌,可以使用
println("hello gradle")
println "hello gradle"
要訪問config.gradle中定義的字段羹铅,首先要在根目錄的build.gradle中加入一條語句apply from: "config.gradle",相當(dāng)于include坐漏。這樣薄疚,所有的module都可以訪問這個(gè)config.gradle
如果把字段直接放到根目錄的build.gradle里面,也是可以的仙畦,不需要apply from输涕,可以直接訪問
訪問自定義的字段
使用"${xxxxxxx}"
比如說訪問config.gradle中的username,可以使用println "${username}"
如果要修改變量的值慨畸,那就要使用全路徑:rootProject.ext.username = 163
賦值與引用
def androidId = rootProject.ext.androidId
def appId = rootProject.ext.appId
def support = rootProject.ext.dependencies
def url = rootProject.ext.url
//使用
compileSdkVersion androidId.compileSdkVersion
遍歷map
dependencies {
implementation fileTree(dir: 'libs', include: ['*.jar'])
// 標(biāo)準(zhǔn)寫法
// implementation group: 'com.android.support', name:'appcompat-v7', version:'28.0.0'
// 簡(jiǎn)寫
// implementation 'com.android.support:appcompat-v7:28.0.0'
// 依賴library庫
implementation project(":library")
// implementation support.appcompat
// implementation support.recyclerview
// implementation support.constraint
// 依賴第三方庫最簡(jiǎn)潔的方式:
support.each { k, v -> implementation v }
}
另一種寫法
在gradle.properties中定義字段莱坎,比如:
MIN_SDK_VERSION = 15
TAR_SDK_VERSION = 28
COMPILER_SDK_VESION = 28
LOGIN_IS_APPLICATION = false
MEMBER_IS_APPLICATION = false
在build.gradle中這樣使用
minSdkVersion MIN_SDK_VERSION.toInteger()
targetSdkVersion TAR_SDK_VERSION.toInteger()
if(!LOGIN_IS_APPLICATION.toBoolean()){
}
代碼中使用自定義的字段
// 簽名配置(必須寫在buildTypes之前)
signingConfigs {
debug {
storeFile file('C:/Users/Administrator/.android/debug.keystore')
storePassword "android"
keyAlias "androiddebugkey"
keyPassword "android"
}
release {
// 簽名證書文件
storeFile file('D:/NetEase/netease.jks')
// 簽名證書的類型
storeType "netease"
// 簽名證書文件的密碼
storePassword "net163"
// 簽名證書中密鑰別名
keyAlias "netease"
// 簽名證書中該密鑰的密碼
keyPassword "net163"
// 是否開啟V2打包
v2SigningEnabled true
}
}
buildTypes {
debug {
// 對(duì)構(gòu)建類型設(shè)置簽名信息
signingConfig signingConfigs.debug
buildConfigField("String", "debug", "\"${url.debug}\"")
}
release {
minifyEnabled false
// 對(duì)構(gòu)建類型設(shè)置簽名信息
signingConfig signingConfigs.release
buildConfigField("String", "debug", "\"${url.release}\"")
proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
}
}
注意看這一句buildConfigField("String", "debug", ""${url.debug}"")
這個(gè)加上之后,重新build一下工程寸士,就會(huì)在BuildConfig.java中生成自定義的字段檐什,代碼中可以通過BuildConfig.debug去訪問
我們可以看到debug和release是不一樣的
app\build\generated\source\buildConfig\debug\com\netease\modular\gradle\BuildConfig.java
public final class BuildConfig {
public static final boolean DEBUG = Boolean.parseBoolean("true");
public static final String APPLICATION_ID = "com.netease.modular.gradle";
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";
// Fields from build type: debug
public static final String debug = "https://11.22.33.44/debug";
}
app\build\generated\source\buildConfig\release\com\netease\modular\gradle\BuildConfig.java
public final class BuildConfig {
public static final boolean DEBUG = false;
public static final String APPLICATION_ID = "com.netease.modular.gradle";
public static final String BUILD_TYPE = "release";
public static final String FLAVOR = "";
public static final int VERSION_CODE = 1;
public static final String VERSION_NAME = "1.0";
// Fields from build type: release
public static final String debug = "https://11.22.33.44/release";
}
一些其他配置
// 將svg圖片生成 指定維度的png圖片
// vectorDrawables.generatedDensities('xhdpi','xxhdpi')
// 使用support-v7兼容(5.0版本以上)
vectorDrawables.useSupportLibrary = true
// 只保留指定和默認(rèn)資源
resConfigs('zh-rCN')
// 配置so庫CPU架構(gòu)(真機(jī):arm,模擬器:x86)
// x86 x86_64 mips mips64
ndk {
//abiFilters('armeabi', 'armeabi-v7a')
// 為了模擬器啟動(dòng)
abiFilters('x86', 'x86_64')
}
// 源集 - 設(shè)置源集的屬性弱卡,更改源集的 Java 目錄或者自由目錄等
sourceSets {
main {
if (!isRelease) {
// 如果是組件化模式乃正,需要單獨(dú)運(yùn)行時(shí)
manifest.srcFile 'src/main/AndroidManifest.xml'
java.srcDirs = ['src/main/java']
res.srcDirs = ['src/main/res']
resources.srcDirs = ['src/main/resources']
aidl.srcDirs = ['src/main/aidl']
assets.srcDirs = ['src/main/assets']
} else {
// 集成化模式,整個(gè)項(xiàng)目打包
manifest.srcFile 'src/main/AndroidManifest.xml'
}
}
}