为了充分利用Android Plugin for Gradle 3.0+的优势,将Android项目拆分红多个module的作法愈来愈常见。然而,随着module数量的增多,咱们很快就会遇到依赖管理的混乱问题。html
这是一种大多数人在采用的管理依赖的方法,但每次升级依赖库时都须要作大量的手动更改。java
module_a/build.gradlereact
implementation "com.android.support:support-annotations:27.0.2"
implementation "com.android.support:appcompat-v7:27.0.2"
implementation "com.squareup.retrofit2:retrofit:2.3.0"
implementation "com.squareup.retrofit2:adapter-rxjava2:2.3.0"
implementation "io.reactivex.rxjava2:rxjava:2.1.9"
复制代码
module_b/build.gradleandroid
implementation "com.android.support:support-annotations:27.0.2"
implementation "com.android.support:appcompat-v7:27.0.2"
implementation "com.squareup.retrofit2:retrofit:2.3.0"
implementation "com.squareup.retrofit2:adapter-rxjava2:2.3.0"
implementation "io.reactivex.rxjava2:rxjava:2.1.9"
复制代码
这里存在许多重复的配置,并且当你的项目有不少module时很难管理依赖库的版本更新。bash
Google在Android官方文档中推荐这种管理依赖的方法。许多项目例如ButterKnife、Picasso等都在使用这种方法。app
此方法很是适用于更新support library的版本,由于每一个support library都具备相同的版本号,你只须要在一个地方更改它就好了。 Retrofit等其它第三方库也是如此。ide
Root-level build.gradle测试
ext {
versions = [
support_lib: "27.0.2",
retrofit: "2.3.0",
rxjava: "2.1.9"
]
libs = [
support_annotations: "com.android.support:support-annotations:${versions.support_lib}",
support_appcompat_v7: "com.android.support:appcompat-v7:${versions.support_lib}",
retrofit :"com.squareup.retrofit2:retrofit:${versions.retrofit}",
retrofit_rxjava_adapter: "com.squareup.retrofit2:adapter-rxjava2:${versions.retrofit}",
rxjava: "io.reactivex.rxjava2:rxjava:${versions.rxjava}"
]
}
复制代码
module_a/build.gradlegradle
implementation libs.support_annotations
implementation libs.support_appcompat_v7
implementation libs.retrofit
implementation libs.retrofit_rxjava_adapter
implementation libs.rxjava
复制代码
module_b/build.gradleui
implementation libs.support_annotations
implementation libs.support_appcompat_v7
implementation libs.retrofit
implementation libs.retrofit_rxjava_adapter
implementation libs.rxjava
复制代码
这种方法是手动管理的一大进步,可是缺乏IDE的支持,更准确的说是在更新依赖库的时候IDE不能自动补全。
您须要在您的项目里建立一个buildSrc模块,而后编写kotlin代码来管理依赖库,使得IDE支持自动补全。
当你运行Gradle时,它会检查项目中是否存在一个名为
buildSrc
的目录。而后Gradle会自动编译并测试这段代码,并将其放入构建脚本的类路径中。您不须要提供任何进一步的操做提示。
Dependencies.kt
)plugins {
`kotlin-dsl`
}
复制代码
object Versions {
val support_lib = "27.0.2"
val retrofit = "2.3.0"
val rxjava = "2.1.9"
}
object Libs {
val support_annotations = "com.android.support:support-annotations:${Versions.support_lib}"
val support_appcompat_v7 = "com.android.support:appcompat-v7:${Versions.support_lib}"
val retrofit = "com.squareup.retrofit2:retrofit:${Versions.retrofit}"
val retrofit_rxjava_adapter = "com.squareup.retrofit2:adapter-rxjava2:${Versions.retrofit}"
val rxjava = "io.reactivex.rxjava2:rxjava:${Versions.rxjava}"
}
复制代码
通过上面两个步骤后,执行一次Gradle Sync任务,如今咱们能够在Android Studio中访问Dependencies.kt中任何值了。
看起来结果与“ext”很是类似,可是它支持自动补全和单击跳转。
module_a/build.gradle
implementation Libs.support_annotations
implementation Libs.support_appcompat_v7
implementation Libs.retrofit
implementation Libs.retrofit_rxjava_adapter
implementation Libs.rxjava
复制代码
module_a/build.gradle
implementation Libs.support_annotations
implementation Libs.support_appcompat_v7
implementation Libs.retrofit
implementation Libs.retrofit_rxjava_adapter
implementation Libs.rxjava
复制代码
我强烈推荐您使用“Kotlin + buildSrc”的方法。它支持自动补全和单击跳转,使得您无需在文件之间手动来回切换,方便你更好的管理Gradle依赖。
新建的module名称必须为buildSrc
一开始我按照做者原文的描述,在Android Studio里右键单击项目,New 出一个名为buildSrc的Android Library,试了好几遍都提示“Gradle sync failed: Plugin with id 'com.android.library' not found”的错误。
后来我参考这里的作法,手动建立了buildSrc这个模块。步骤以下: