Gradle是一个基于Apache Ant和Apache Maven概念的项目自动化建构工具。它使用一种基于Groovy的特定领域语言(DSL)来声明项目设置,抛弃了基于XML的各种繁琐配置。
-
构建工具包括 make,Ant,Maven,Lvy和现在的Gradle,差不多是一步步进化而来,前面几种都是基于XML,不擅长if这类逻辑判断,而Gradle基于Groovy有自己的语法。
Gradle与Android本身没有任何关系,Gradle主要用于Java项目,不过还支持Android,C,C++。Gradle官方文档:https://docs.gradle.org/current/release-notes
Google选用Gradle作为AS的构建工具,集成了一套插件叫Android Gradle Plugin,Gradle Plugin官方文档:http://tools.android.com/tech-docs/new-build-system/user-guide#TOC-Why-Gradle-
1.布局文件分包
将res文集爱你下的layout修改为layouts,然后新建layout->activity,新建layout->adapter,新建layout->fragment
新建layout->fragment,新建layout->content等等,然后在你的build.gradle下配置代码:
main {
res.srcDirs = [
'src/main/res/layouts/activity',
'src/main/res/layouts/adapter',
'src/main/res/layouts/content',
'src/main/res/layouts/fragment',
'src/main/res/layouts',
'src/main/res'.
]
}
}
2.配置签名信息
- 新建签名信息
signingConfigs {
config {
storeFile file('xxx.jks')
storePassword '123456'
keyAlias 'meibaa'
keyPassword '123456'
}
}
-在buildTypes里面添加配置信息
buildTypes {
release {
signingConfig signingConfigs.config
}
}
3.为生成的apk添加代码混淆,去除未用资源
shrinkResources true
zipAlignEnabled true
minifyEnabled true
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
当然在生成apk的过程在可能会出现一些未知error
可以添加忽略
lintOptions {
checkReleaseBuilds false
abortOnError false
}
4.在debug测试过程和relaese过程中配置不同信息
buildTypes {
release {
buildConfigField("boolean", "isDebug", "false")
buildConfigField("String", "coder", "\"ZABone\"") //
buildConfigField("int", "age", "26")
}
debug {
applicationIdSuffix ".debug"
buildConfigField("boolean", "isDebug", "true")
buildConfigField("String", "coder", "\"ZABone\"") //
buildConfigField("int", "age", "26")
resValue("bool", "test_is_debug", "true")
resValue("string", "testCoder", "\"ZABone\"")
resValue("integer", "test_age", "26")
}
}
1.修改debug版本的包名
applicationIdSuffix ".debug"//表示在当前包名后面增加.debug也可以自定义
- 为debug和relaease版本配置不同信息:
-在java代码里面生成
//添加了boolean类型的参数
buildConfigField("boolean", "isDebug", "true")
// 添加了String类型的参数
buildConfigField("String", "coder", "\"ZABone\"") //
// 添加了int类型的参数
buildConfigField("int", "age", "26")
//获取方式 BuildConfig.isDebug BuildConfig.coder BuildConfig.age
- 在res文件下面生成xml
resValue("bool", "test_is_debug", "true")
resValue("string", "testCoder", "\"ZABone\"")
resValue("integer", "test_age", "26")
//获取方式 getString(R.string.coder);
5. 设置渠道包(一般使用第三方例如umeng,当然也可以自定义)
-在manifest里面添加渠道包名称占位符
-在build.gradle里面设置渠道信息
productFlavors {
xiaomi { manifestPlaceholders = [CHANNEL_VALUE: "XIAO_MI"] }
c360 { manifestPlaceholders = [CHANNEL_VALUE: "C360"] }
}
当然在AS 3.0以后可能编译不通过,添加如下代码于defaultConfig 下的versionCode下面即可
flavorDimensions "versionCode"
表示当前渠道版本信息
6. 设置打包生成时间
-在defaultConfig中添加
buildConfigField("String", "buildTime", "\"" + getDate() + "\"")
-在build.gradle中的android包体之外添加
def getDate() {
return new Date().format("yyyy-MM-dd HH:mm:ss")
}
通过 BuildConfig.buildTime即可获取build时间
7. 为jar包远程依赖设置代理
由于公司不能访问外网,而AS每次启动需要连接远程依赖,可按照如下实现
-在app的build.gradle中添加远程依赖仓库
repositories {
google()
jcenter()
//公司仓库地址
maven{ url 'http://xxxx.yyy.com:8081/repository/android-public/'}
}
然后在所有的项目依赖中也添加
allprojects {
repositories {
google()
jcenter()
maven { url 'https://jitpack.io' }
//公司仓库地址
maven{ url 'http://xxxx.yyy.com:8081/repository/android-public/'
credentials{
username '张三'
password '123456'
}
}
}
}
或许,或出现305.jar包错误
在build.gradle中的android包体内添加即可解决
configurations.all {
resolutionStrategy.force 'com.google.code.findbugs:jsr305:1.3.9'
}