第一篇:build.gradle统一管理

前言

在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中引用库需要注意的是:

  1. 全程配置引用应该类似这样(以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
  1. config.gradle中所声明的库在一个module中未必会都用到,因此在子module的build.gradle中我们应该选择性的引用我们需要用到的库

ok,今天的内容就讲到这里了,谢谢诶。

你可能感兴趣的:(第一篇:build.gradle统一管理)