Gradle系列(三):项目实践

Gradle系列(一):Groovy基础
Gradle系列(二):AndroidStudio的Gradle简介
Gradle系列(三):项目实践

前言

就我现在工作项目来看,Gradle有这么几个方面的应用:版本号统一管理,debug/release编译模式区分,差异化编译,aar自动化管理等,看完我下面讲解,完全可以直接运用于你们的项目中,提高生产效率。

版本号统一管理

项目中肯定会以源码形式引入不少开源库,我们应该确保每个moduler的版本号:minSdkVersion ,compileSdkversion等都一样,因此有必要统一管理:
在根目录的build.gradle添加

ext {  

    // SDK And Tools  
    minSdkVersion = 14  
    targetSdkVersion = 23  
    compileSdkVersion = 23  
    buildToolsVersion = '24.0.2'  

    //Dependencies  
    supportLibraryVersion = '23.2.1'  

}  

在项目build.gradle中引用:

apply plugin: 'com.android.application'  

android {                       
    compileSdkVersion rootProject.ext.compileSdkVersion  
    buildToolsVersion rootProject.ext.buildToolsVersion  

    defaultConfig {  
        applicationId 'com.mainiway.demo'  
        minSdkVersion rootProject.ext.minSdkVersion  
        targetSdkVersion rootProject.ext.targetSdkVersion  
        versionCode 1  
        versionName "1.0.0"  
    }  
}
编译模式区分

有这样的场景:项目中的Log需要按照编译模式做区分,debug模式打印所有Log,发布版本只打印Error级别,怎么在代码中区分编译模式?
办法:项目中有个BuildConfig文件,位置在:(备注:如果编译过release,那么同样release文件夹也存在这个文件,内容一样)


image.png

BuildConfig:

public final class BuildConfig {
  public static final boolean DEBUG = Boolean.parseBoolean("true");
  public static final String APPLICATION_ID = "com.lubansoft.bimview4phone";
  public static final String BUILD_TYPE = "debug";
  public static final String FLAVOR = "";
  public static final int VERSION_CODE = 9;
  public static final String VERSION_NAME = "4.0.0";
  // Fields from default config.
  public static final boolean PUBLISH_MODE = false;
}

最后一个字段是我自定义的,前面都是这个配置文件自带的,包括是否为DEBUG,appID,versionCode等。自定义的PUBLISH_MODE就是来区分当前是否是发布模式的:
方法:在项目的build.gradle中加入:

    defaultConfig {
        ...
        buildConfigField "boolean", "PUBLISH_MODE", "true" //发布模式(生产环境下设为true,其他设为false)
        ...
    }```
这样就可以在编译期间,把值写入到BuildConfig,在发版当天把这个值设为true即可,然后再项目根据这个值来改变Log的打印规则:
```java
        // 设置Log调试开关
        LogUtil.setDebugState(!BuildConfig.PUBLISH_MODE);

注意:BuildConfig中有个DEBUG字段,该字段在debug模式就是true,在release模式就是false,不需要手动设置,但是release模式不一定是发布模式(也可能是打一个签名包测试)。

差异化编译

需求场景:项目中引用了一些Jar包,只在调试模式下用到了,在发布模式根本用不到,但是编译到项目中又会增大APP体积,能否只在发布模式下才去编译呢?
方法:把这些jar包不要放在libs文件夹,跟libs平级建一个目录比如:debugLibs,然后在项目的build.gradle根据当面的PUBLISH_MODE做差异化编译:

dependencies {
    compile fileTree(include: ['*.jar'], dir: 'libs')
   if (!publishMode) {
        compile fileTree(include: ['*.jar'], dir: 'debuglibs')
   }
    ...
}
统一管理aar

这一个不是所有项目都会用到,但是我强烈建议去实践的。实际项目中都会把一些基础控件,基础功能抽离出来,做为单独项目基础库用单独svn分支管理,在开发项目中写一个脚本打包成aar文件拉到本地使用,既可以复用到不同项目又可以缩短编译时间,一举两得。比如基础库按照UI,通用逻辑,业务通用模块生成了三个aar:

image.png

在项目中使用:

repositories{
    flatDir{
        dirs '../libs'
    }
}

dependencies {
    ...
    compile(name: 'base_1.2.0', ext: 'aar')
    compile(name: 'commombase_1.0.0', ext: 'aar')
    compile(name: 'uibase_1.2.0', ext: 'aar')
}```
假设现在基础库增加了新的模块,就会生成新的aar,或者产品迭代了这几个aar版本号也要迭代,难道每次都在build.gradle中手动去改吗,完全可以自动化这个过程。
方法:可以看出我把这几个aar放到根目录的libs文件夹(文件夹随意),那就获取这个文件夹下的所有文件名,动态引用。
```java
def path = rootProject.getRootDir().getAbsolutePath() + "/libs"
    def configFile = new File(path)
//获取文件夹下所有文件
    def files = configFile.listFiles(new FilenameFilter() {
        @Override
        boolean accept(File dir, String name) {
//文件名过滤,防止出错
            if (name.contains("base")) {
                return true;
            } else {
                return false
            }
        }
    })
    def aar1 = files[0].getName()
    def aar2 = files[1].getName()
    def aar3 = files[2].getName()
//动态引用这些aar
    compile(name: '$aar1', ext: 'aar')
    compile(name: '$aar2', ext: 'aar')
    compile(name: '$aar3', ext: 'aar')

这样够好了吗?
这些代码都在build.gradle的dependencies里面,太乱了,要是可以独立出去就好了,把获取aar封装成工具类。OK,gradle完全支持这么干,在根目录建一个utils.gradle

image.png

utils.gradle:

//gradle工具类
//获取基础库版本号
def getAARNames() {
    ...
//具体实现不写了,返回一个String数组
    return ["$lbName", "$aar1", "$aar2","$aar3"]
}
ext {
//注意这行不能少
    getAARNames = this.&getAARNames
}

在build.gradle中使用:


image.png
dependencies {
   ...
    //获取aar文件名,是一个数组
    def aarList = getAARNames()
    compile(name: aarList[0], ext: 'aar')
    compile(name: aarList[1], ext: 'aar')
    compile(name: aarList[1], ext: 'aar')
}

大功告成!代码清爽很多。

精简开源项目目录结构

实际中肯定会以源码形式用到不少开源库,特别是UI相关的我们要该里面的代码,只能以源码形式,那么一些都是作为moduler和我们的app并列放到一个目录,开源库数量达到十几个时项目结构看起来就主次不分了,有必要精简之。
方法:直接在根目录建立文件夹比如thirdpart,把开源库都放进去,然后在settings.gradle中配置项目结构:

include ':bvcommon',
        ':app',//这是主项目,下面都是开源库
        ':thirdpart:PullToRefreshLibrary',
        ':thirdpart:datetimepicker-library',
        ':thirdpart:MultilevelTreeLibrary',
        ':thirdpart:FFmpegAndroid',
        ':thirdpart:autolinklibrary'
        ...
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,254评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,875评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,682评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,896评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,015评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,152评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,208评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,962评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,388评论 1 304
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,700评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,867评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,551评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,186评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,901评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,142评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,689评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,757评论 2 351

推荐阅读更多精彩内容