前言
在Android开发中,不免会遇到引入第三方libary的情况,因此,对不同的module进行统一化管理显得迫在眉睫,今天就来讲讲build.gradle的统一画管理。
本篇文章参考以下链接
Android Studio 中 Gradle 依赖的统一管理
在此表示感谢
一. 先看看一般的项目中build.gradle结构
---------------root
--------module1
----build.gradle1
--------module2
----build.gradle2
--------build.gradle
然后我们会在项目的project目录下建一个config.gradle文件用于全程配置所有model的公用属性,最后在各个mudule中引用,这样处理完后build.gradle结构将变成下面这样
---------------root
--------module1
----build.gradle1
--------module2
----build.gradle2
--------build.gradle
--------config.gradle
二.新建config.gradle文件
将项目调成project标签,然后选中项目最外层文件夹,右键,New----File
,新建config.gradle文件,如下图
1.png
建成后文件目录类似这样:
2.png
三.config.gradle中代码内容如下
config.gradle放一些通用的引用数据
/**
* 在主项目的根目录下创建config.gradle文件
* 在这里单独处理统一依赖问题
* 注意需要在根目录的build.gradle中进行引入
*/
ext {
android = [
//编译的SDK版本
compileSdkVersion: 26,
//编译的Tools版本
buildToolsVersion: "25.0.3",
//项目id
applicationId:"com.android.configdemo",
//支持SDK的最低版本
minSdkVersion : 17,
//支持SDK的目标版本
targetSdkVersion : 26,
//版本号
versionCode:1,
//版本名称
versionName:"1.0.0",
testInstrumentationRunner:"android.support.test.runner.AndroidJUnitRunner"
]
//依赖库版本
supportLibrary = "26.1.0"
//库依赖
supportDependencies = [
//基础库
implementation_support_appcompat: "com.android.support:appcompat-v7:${supportLibrary}",
compile_support_v4 : "com.android.support:support-v4:${supportLibrary}",
compile_suppout_design : "com.android.support:design:${supportLibrary}",
implementation_constraint_layout:"com.android.support.constraint:constraint-layout:1.0.2",
testImplementation_test_junit:"junit:junit:4.12",
androidTestImplementation_support_runner:"com.android.support.test:runner:1.0.1",
androidTestImplementation_support_espresso:"com.android.support.test.espresso:espresso-core:3.0.1",
//bugly,其中latest.release指代最新Bugly SDK版本号,也可以指定明确的版本号,例如2.2.0
compile_bugly:"com.tencent.bugly:crashreport:latest.release",
//jpush
compile_jiguang_jpush: "cn.jiguang.sdk:jpush:3.1.0",
compile_jiguang_janalytics: "cn.jiguang.sdk:janalytics:1.1.1",
compile_jiguang_jcore: "cn.jiguang.sdk:jcore:1.1.8",
//butterKnife
compile_butterknife : "com.jakewharton:butterknife:8.5.1",
//这条千万不能忘记!!,引用方式:annotationProcessor librarys.butterknifeCompiler
annotationProcessor_butterknife_compiler:"com.jakewharton:butterknife-compiler:8.5.1",
//PermissionGen
compile_permissionenGen:"com.lovedise:permissiongen:0.0.6",
//loadingdialog,网络加载对话框
compile_loading_dialog:"com.github.d-max:spots-dialog:0.7@aar",
//retroefit2.0
compile_retrofit2:"com.squareup.retrofit2:retrofit:2.3.0",
//retrofit2.0对gson支持
compile_retrofit2_converter_gson:"com.squareup.retrofit2:converter-gson:2.2.0",
//retrofit2.0支持内置log打印
compile_logging_interceptor:"com.squareup.okhttp3:logging-interceptor:3.4.1",
//添加Retrofit2.0对Rx的支持(RxJava2.x时使用,RxJava1.x时不支持)
compile_retrofit2_adapter_rxjava2:"com.squareup.retrofit2:adapter-rxjava2:2.3.0",
//rxjava2.x
compile_rx_android2:"io.reactivex.rxjava2:rxandroid:2.0.1",
compile_rx_java2:"io.reactivex.rxjava2:rxjava:2.1.0",
//RecycleView万能适配器
compile_base_rvadapter:"com.zhy:base-rvadapter:3.0.3",
//Glide
compile_glide4:"com.github.bumptech.glide:glide:4.0.0",
annotationProcessor_glide4_compiler:"com.github.bumptech.glide:compiler:4.0.0",
//ZXing二维码
compile_zxing_core:"com.google.zxing:core:3.3.0"
]
}
注意config.gradle文件中库依赖的命名:引用关键字_自定义名称
举个例子:
implementation_support_appcompat 表示在mudle中引用时为类似下面的:
implementation rootProject.ext.supportDependencies.implementation_support_appcompat
而 compile_support_v4 表示在引用时 关键字为:compile,类似下面这样:
compile rootProject.ext.supportDependencies.compile_support_v4
所以,大家如果要在config.gradle中添加新库引用的时候,记得按照规则,这样在各module中引用的时候也方便些
四.在project的build.gradle中引用配置文件config.gradle
project的build.gradle项目结构所处位置如下图:
3.png
在project的build.gradle中最配置如下代码:
apply from:"config.gradle"
配置截图如下:
4.png
五.在app module的build.gradle中引用配置文件config.gradle
app module中示例性引用代码如下:
apply plugin: 'com.android.application'
//android配置
def config = rootProject.ext.android
//相关库依赖
def librarys = rootProject.ext.supportDependencies
android {
compileSdkVersion config.compileSdkVersion
defaultConfig {
applicationId config.applicationId
minSdkVersion config.minSdkVersion
targetSdkVersion config.targetSdkVersion
versionCode config.versionCode
versionName config.versionName
testInstrumentationRunner config.testInstrumentationRunner
}
buildTypes {
release {
minifyEnabled false
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
}
}
}
dependencies {
implementation fileTree(dir: 'libs', include: ['*.jar'])
//基础库
implementation librarys.implementation_support_appcompat
compile librarys.compile_support_v4
compile librarys.compile_suppout_design
implementation librarys.implementation_constraint_layout
testImplementation librarys.testImplementation_test_junit
androidTestImplementation librarys.androidTestImplementation_support_runner
androidTestImplementation librarys.androidTestImplementation_support_espresso
//选择性引用config.gradle中的第三方库
// //butterKnife
// compile librarys.compile_butterknife
// annotationProcessor librarys.annotationProcessor_butterknife_compiler
//
// //ZXing二维码
// compile librarys.compile_zxing_core
//
// //gson依赖
// compile librarys.compile_retrofit2_converter_gson
}
app module的build.gradle中引用库需要注意的是:
- 全程配置引用应该类似这样(以versionCode 为例):
versionCode rootProject.ext.android.versionCode
为了方便起见,这里将 rootProject.ext.android 声明成一个对象 config,代码如下:
//android配置
def config = rootProject.ext.android
库依赖的逻辑处理和这个一样,例如 compile_support_v4 库的引用全程应该是这样的:
compile rootProject.ext.supportDependencies.compile_support_v4
然后为了方便,我们设置了librarys变量
//相关库依赖
def librarys = rootProject.ext.supportDependencies
则此库的引用简化成:
compile librarys.compile_support_v4
- config.gradle中所声明的库在一个module中未必会都用到,因此在子module的build.gradle中我们应该选择性的引用我们需要用到的库
ok,今天的内容就讲到这里了,谢谢诶。
网友评论