基本介绍
Gradle 是一个基于 Ant 和 Maven 概念的项目自动化建构工具。它使用一种基于 Groovy 的特定领域语言 (DSL) 来声明项目设置,这比我们的 ANT 使用 XML 构建配置要灵活的多。在编写配置时,你可以像编程一样灵活,Gradle 是基于 Groovy 的 DSL 语言,完全兼容 JAVA 。
Android Gradle 基本配置
apply plugin: 'com.android.application'
android {
compileSdkVersion 25
buildToolsVersion "26.0.0"
defaultConfig {
applicationId "com.ahui.gradleconfig"
minSdkVersion 14
targetSdkVersion 25
versionCode 1
versionName "1.0"
}
buildTypes {
release {
minifyEnabled false
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
}
}
}
dependencies {
compile fileTree(dir: 'libs', include: ['*.jar'])
compile 'com.android.support:appcompat-v7:25.3.1'
compile 'com.android.support.constraint:constraint-layout:1.0.0-alpha8'
testCompile 'junit:junit:4.12'
}
上面是 android 默认创建的 gradle 文件,在项目的开发过程中。我们会不断的对这个 gradle 文件进行操作。具体一些常用操作下面介绍。
- 引入第三方库。
compile 'me.drakeet.multitype:multitype:3.0.0'
- 当第三方的库中引入的库,不是你想要的库的话,可以使用 exclude 将它排除掉。
dependencies {
compile('me.drakeet.multitype:multitype:3.0.0', {
exclude group: 'com.android.support'
})
compile 'com.android.support:recyclerview-v7:你选择的版本'
}
- 配置构建类型
buildTypes {
release {
minifyEnabled false
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
}
}
可以往 buildTypes 里面添加新的构建类型。一般都会配置一个 bug 和 release 这两种类型来区分测试环境下的和生产环境下。不同环境下可能需要的签名文件和签名文件的信息可能不同。所以需要用 signingConfig 来描述签名信息
signingConfigs {
release {
storeFile file("lhl.jks")
storePassword "1111"
keyAlias "111"
keyPassword "1111"
}
}
buildTypes {
release {
minifyEnabled false
signingConfig signingConfigs.release
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
}
debug {
minifyEnabled false
signingConfig signingConfigs.release
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
}
}
- 设备安装多个版本的Apk
对于Android App 来讲,相同包名的 apk 在同一个设备上只能存在一个。所以我们无法做到在同一个设备上同时安装生产环境和测试环境的安装包,这对于日常的开发工作和测试人员的测试工作极不方便。 常规的解决方式,要么是修改包名,重新打一个包出来。现在我们利用 gradle 可以轻松的做到。
buildTypes {
release {
minifyEnabled false
signingConfig signingConfigs.release
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
}
debug {
minifyEnabled false
signingConfig signingConfigs.release
applicationIdSuffix '.debug'
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
}
}
其实上面的配置就是更改 applicationId 的值,让 debug 中的 applicationId 的值=applicationId+applicationIdSuffix 。这个时候,你可能会想,如何去配置测试包和生产包的域名,名字,icon呢?
- 更改生产包和测试包的 AppName
- 借鉴多渠道打包占位符
buildTypes {
release {
minifyEnabled false
signingConfig signingConfigs.release
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
manifestPlaceholders = [
app_name: "我是正式版的名字",
app_icon: "@mipmap/ic_launcher_2"
]
}
debug {
minifyEnabled false
signingConfig signingConfigs.release
applicationIdSuffix '.debug'
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
manifestPlaceholders = [
app_name: "我是测试版的名字",
app_icon: "@mipmap/ic_launcher"
]
}
}
2. 直接使用resValue
buildTypes {
release {
minifyEnabled false
signingConfig signingConfigs.release
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
resValue "string", "app_name", "我是正式版的名字"
}
debug {
minifyEnabled false
signingConfig signingConfigs.release
applicationIdSuffix '.debug'
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
resValue "string", "app_name", "我是测试版的名字"
}
}
- 配置测试环境的域名和生产环境的域名
BuildConfig 是 Android Gradle 自动生成的一个 Java 类文件,无法手动编译,但是可以通过Gradle 控制,我们可以利用这个来进行定义一些有关于环境的一些参数。类如生产环境和预发环境。控制 Log 的开关等等。
buildTypes {
release {
minifyEnabled false
signingConfig signingConfigs.release
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
manifestPlaceholders = [
app_name: "我是正式版的名字",
app_icon: "@mipmap/ic_launcher_2"
]
buildConfigField "String", "URL", '"http://www.taobao.com"'
}
debug {
minifyEnabled false
signingConfig signingConfigs.release
applicationIdSuffix '.debug'
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
manifestPlaceholders = [
app_name: "我是测试版的名字",
app_icon: "@mipmap/ic_launcher"
]
buildConfigField "String", "URL", '"http://www.baidu.com"'
}
- 控制全局的版本信息 。首先在项目根目录创建一个version.gradle来控制版本信息,在需要的地方引入即可。
ext {
android = [
compileSdkVersion: 26,
buildToolsVersion: "26.0.1",
minSdkVersion : 14,
targetSdkVersion : 26,
versionCode : 1,
versionName : "1.0"
]
dependencies = [
"appcompat" : 'com.android.support:appcompat-v7:26.+',
"logger" : 'com.orhanobut:logger:2.1.1',
"gson" : "com.google.code.gson:gson:2.6.2",
"eventbus" : 'org.greenrobot:eventbus:3.0.0',
"butterknife" : 'com.jakewharton:butterknife:7.0.1',
"support-design" : 'com.android.support:design:24.1.1',
"support-percent" : 'com.android.support:percent:24.1.1',
"support-multidex": 'com.android.support:multidex:1.0.1',
"glide" : 'com.github.bumptech.glide:glide:3.7.0',
"support-v4" : 'com.android.support:support-v4:24.1.1',
"okhttp3" : 'com.squareup.okhttp3:okhttp:3.3.1',
"nineoldandroids" : 'com.nineoldandroids:library:2.4.0'
]
}
引入
apply plugin: 'com.android.library'
def androidConfig = rootProject.ext.android
def compileConfig = rootProject.ext.dependencies
android {
compileSdkVersion androidConfig.compileSdkVersion
buildToolsVersion androidConfig.buildToolsVersion
defaultConfig {
minSdkVersion androidConfig.minSdkVersion
targetSdkVersion androidConfig.targetSdkVersion
versionCode androidConfig.versionCode
versionName androidConfig.versionName
}
}
dependencies {
compile fileTree(dir: 'libs', include: ['*.jar'])
compile compileConfig.appcompat
compile compileConfig.logger
testCompile 'junit:junit:4.12'
}