Gradle实用技巧
Gradle依赖树查询
1.查看依赖树命令
gradlew app:dependencies
2.生成依赖分析文件
gradle build --scan
在项目根目录位置下运行gradle build --scan即可,然后会生成 HTML 格式的分析文件的分析文件。
分析文件会直接上传到Scan官网,命令行最后会给出远程地址。
使用循环优化Gradle依赖管理
首先添加config.gradle(就是将不同的依赖关键字区分开)
ext{
dependencies = [
// base
"appcompat-v7": "com.android.support:appcompat-v7:${version["supportLibraryVersion"]}",
...
]
annotationProcessor = [
"glide_compiler": "com.github.bumptech.glide:compiler:${version["glideVersion"]}",
...
]
apiFileDependencies = [
"launchstarter" :"libs/launchstarter-release-1.0.0.aar"
]
debugImplementationDependencies = [
"MethodTraceMan": "com.github.zhengcx:MethodTraceMan:1.0.7"
]
...
implementationExcludes = [
"com.android.support.test.espresso:espresso-idling-resource:3.0.2" : [
'com.android.support' : 'support-annotations'
]
]
...
}
然后在build.gradle中配置如下:
apply from config.gradle
...
def implementationDependencies = project.ext.dependencies
def processors = project.ext.annotationProcesso
def implementationExcludes = project.ext.implementationExcludes
dependencies{
// 处理所有的 xxximplementation 依赖
implementationDependencies.each { k, v -> implementation v }
// 处理 annotationProcessor 依赖
processors.each { k, v -> annotationProcessor v }
// 处理所有包含 exclude 的依赖
implementationExcludes.each { entry ->
implementation(entry.key) {
entry.value.each { childEntry ->
exclude(group: childEntry)
}
}
}
...
}
支持代码提示的Gradle依赖管理
Kotlin + buildSrc:更好的管理Gadle依赖
Gradle模块化
例如在使用greendao数据库时,需要在build.gradle中指定版本。
这种时候应该新建一个greendao-config.gradle。
apply plugin: 'org.greenrobot.greendao'
//greenDao指定版本和路径等
greendao {
//数据库的schema版本,也可以理解为数据库版本号
schemaVersion 1
//设置DaoMaster、DaoSession、Dao包名,也就是要放置这些类的包的全路径。
daoPackage 'com.example.ausu.big_progect.dao'
//设置DaoMaster、DaoSession、Dao目录
targetGenDir 'src/main/java'
}
然后再在build.gradle中引入。
apply from 'greendao-config.gradle'
Library模块Gradle代码引用
做一个 basic 抽取,同样将共有参数/信息提取到 basic.gradle 中,每个 module apply
apply plugin: 'com.android.library'
apply plugin: 'kotlin-android'
apply plugin: 'kotlin-android-extensions'
apply plugin: 'kotlin-kapt'
android {
// 指定用于编译项目的 API 级别
compileSdkVersion Versions.compileSDK
// 指定在生成项目时要使用的 SDK 工具的版本,Android Studio 3.0 后不需要手动配置。
buildToolsVersion Versions.buildTools
// 指定 Android 插件适用于所有构建版本的版本属性的默认值
defaultConfig {
minSdkVersion Versions.minSDK
targetSdkVersion Versions.targetSDK
versionCode 1
versionName "1.0"
}
// 配置 Java 编译(编码格式、编译级别、生成字节码版本)
compileOptions {
encoding = 'utf-8'
sourceCompatibility JavaVersion.VERSION_1_8
targetCompatibility JavaVersion.VERSION_1_8
}
kotlinOptions {
jvmTarget = JavaVersion.VERSION_1_8.toString()
}
lintOptions {
// lint 异常后继续执行
abortOnError false
}
}
dependencies {
implementation fileTree(dir: 'libs', include: ['*.jar'])
...
}
然后在相应的模块的build.gradle中引入即可。
apply from:"../basic.gradle"
dependencies {
api Deps.constraintLayout
api Deps.retrofit
}
资源文件分包
1.新建res_xxx目录 。
在 main 目录下新建 res_core, res_feed(根据业务模块命名)等目录,在res_core中新建res目录中相同的文件夹如:layout、drawable-xxhdpi、values等。
2.在gradle中配置res_xx目录。
1.新建res_xxx目录 。
在 main 目录下新建 res_core, res_feed(根据业务模块命名)等目录,在res_core中新建res目录中相同的文件夹如:layout、drawable-xxhdpi、values等。
2.在gradle中配置res_xx目录。
AAR依赖与源码依赖快速切换
当我们的项目中Module越来越多,为了加快编译速度,常常把Module发布成AAR,然后在项目中直接依赖AAR。
但是我们有时候又需要修改AAR,就需要依赖于源码。
所以我们需要一个可以快速地切换依赖AAR与依赖源码的方式。
以 retrofit 源码依赖为例:
1.首先下载retrofit,可以放到和项目同级的目录,并修改目录名为retrofit-source,以便区分。
2.在settings.gradle文件中添加需要修改的aar库的源码project。
include ':retrofit-source'
project(':retrofit-source').projectDir = new File("../retrofit-source")
3.替换aar为源码。
build.gradle(android) 脚本中添加替换策略。
allprojects {
repositories {
...
}
configurations.all {
resolutionStrategy {
dependencySubstitution {
substitute module( "com.squareup.retrofit2:retrofit") with project(':retofit-source')
}
}
}
}
参考资料
网友评论