优雅的项目配置--经常使用库和版本号管理

Posted liguangsunls

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了优雅的项目配置--经常使用库和版本号管理相关的知识,希望对你有一定的参考价值。

欢迎Follow我的GitHub, 关注我的CSDN.

近期经常有人问我, 怎样管理gradle版本号, 我来统一解说这些小技巧.

随着android开发的成熟, 模块越来越多, 为了开发稳定的程序, 引入的库也随之添加, 怎样确保全部项目使用同样的编译版本号he库版本号呢?

当然, Gradle的參数配置能够帮我们实现这些.

技术分享

主要
(1) 经常使用库的展示与配置.
(2) 统一管理项目和库的版本号.
(3) 设置项目的私有參数.


1. 经常使用库

编程三剑客, RxJava+Retrofit+Dagger.
经常使用: ButterKnife依赖注解, Glide/Picasso图片处理.
使用根项目(rootProject)的參数管理子项目的版本号.

apply plugin: ‘me.tatarka.retrolambda‘      // Lambda表达式
apply plugin: ‘com.android.application‘     // Android应用
apply plugin: ‘com.neenbedankt.android-apt‘ // 编译时类
apply plugin: ‘com.android.databinding‘     // 数据绑定

def cfg = rootProject.ext.configuration // 配置
def libs = rootProject.ext.libraries // 库

android {
    compileSdkVersion cfg.compileVersion
    buildToolsVersion cfg.buildToolsVersion

    defaultConfig {
        applicationId cfg.package
        minSdkVersion cfg.minSdk
        targetSdkVersion cfg.targetSdk
        versionCode cfg.version_code
        versionName cfg.version_name

        buildConfigField "String", "MARVEL_PUBLIC_KEY", "\"${marvel_public_key}\""
        buildConfigField "String", "MARVEL_PRIVATE_KEY", "\"${marvel_private_key}\""
    }

    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile(‘proguard-android.txt‘), ‘proguard-rules.pro‘
        }
    }

    compileOptions {
        sourceCompatibility JavaVersion.VERSION_1_8
        targetCompatibility JavaVersion.VERSION_1_8
    }

    // 凝视冲突
    packagingOptions {
        exclude ‘META-INF/services/javax.annotation.processing.Processor‘
    }
}

dependencies {
    compile fileTree(dir: ‘libs‘, include: [‘*.jar‘])
    testCompile ‘junit:junit:4.12‘

    // Android
    compile "com.android.support:design:${libs.supportVersion}"
    compile "com.android.support:appcompat-v7:${libs.supportVersion}"
    compile "com.android.support:cardview-v7:${libs.supportVersion}"
    compile "com.android.support:recyclerview-v7:${libs.supportVersion}"
    compile "com.android.support:palette-v7:${libs.supportVersion}"

    // Retrofit
    compile "com.squareup.retrofit:retrofit:${libs.retrofit}"
    compile "com.squareup.retrofit:converter-gson:${libs.retrofit}"
    compile "com.squareup.retrofit:adapter-rxjava:${libs.retrofit}"

    // ReactiveX
    compile "io.reactivex:rxjava:${libs.rxandroid}"
    compile "io.reactivex:rxandroid:${libs.rxandroid}"

    // Dagger
    compile "com.google.dagger:dagger:${libs.dagger}"
    apt "com.google.dagger:dagger-compiler:${libs.dagger}"
    compile "org.glassfish:javax.annotation:${libs.javax_annotation}"

    // Others
    compile "com.jakewharton:butterknife:${libs.butterknife}" // 资源注入
    compile "com.github.bumptech.glide:glide:${libs.glide}" // 图片处理
    compile "jp.wasabeef:recyclerview-animators:${libs.recycler_animators}" // Recycler动画
    compile "de.hdodenhof:circleimageview:${libs.circleimageview}" // 头像视图
}

项目版本号:
def cfg = rootProject.ext.configuration
cfg.compileVersion
库版本号:
def libs = rootProject.ext.libraries
${libs.retrofit}


2. 參数管理

buildConfigField管理私有參数, 配置在gradle.properties里面.

android {
    defaultConfig {
        buildConfigField "String", "MARVEL_PUBLIC_KEY", "\"${marvel_public_key}\""
        buildConfigField "String", "MARVEL_PRIVATE_KEY", "\"${marvel_private_key}\""
    }
}

设置參数的类型\变量名\位置三个部分.

marvel_public_key   = 74129ef99c9fd5f7692608f17abb88f9
marvel_private_key  = 281eb4f077e191f7863a11620fa1865f2940ebeb

未指定路径, 默认是配置在gradle.properties中.
两个地方能够配置參数, 一个是项目的build.gradle, 一个是gradle.properties.

项目中使用BuildConfig.xxx引入參数.

        MarvelSigningIterceptor signingIterceptor = new MarvelSigningIterceptor(
                BuildConfig.MARVEL_PUBLIC_KEY, BuildConfig.MARVEL_PRIVATE_KEY);

3. 版本号管理

版本号管理配置在项目的build.gradle中, 包括两个部分, 一个是项目的版本号, 一个是库的版本号. 把经常使用參数设置成为变量. 子项目使用rootProject.ext.xxx的形式引入.

ext {
    configuration = [
            package          : "me.chunyu.spike.springrainnews",
            buildToolsVersion: "23.0.1",
            compileVersion   : 23,
            minSdk           : 14,
            targetSdk        : 23,
            version_code     : 1,
            version_name     : "0.0.1",
    ]

    libraries = [
            supportVersion    : "23.1.1",
            retrofit          : "2.0.0-beta2",
            rxandroid         : "1.1.0",
            dagger            : "2.0",
            javax_annotation  : "10.0-b28",
            butterknife       : "7.0.1",
            glide             : "3.6.1",
            recycler_animators: "2.1.0",
            circleimageview   : "2.0.0"
    ]
}

buildscript {
    repositories {
        jcenter()
    }

    dependencies {
        classpath ‘com.android.tools.build:gradle:2.0.0-alpha5‘
        classpath ‘com.neenbedankt.gradle.plugins:android-apt:1.8‘
        classpath ‘me.tatarka:gradle-retrolambda:3.2.4‘
        classpath ‘com.android.databinding:dataBinder:1.0-rc4‘
    }
}

allprojects {
    repositories {
        jcenter()
    }
}

task clean(type: Delete) {
    delete rootProject.buildDir
}

通过这种方式管理Android项目, 能够便捷的更改版本号号, 全部模块统一.

OK, that’s all! Enjoy it!












以上是关于优雅的项目配置--经常使用库和版本号管理的主要内容,如果未能解决你的问题,请参考以下文章

maven中snapshot快照库和release发布库的区别和作用

Eclipse中git插件导入远程库和上传项目源代码到远程库

Python之如何优雅的重试

maven中snapshot快照库和release发布库的区别和作用

Android Studio中Gradle统一管理版本号引用配置

Android Studio中统一管理版本号引用配置