Gradle for Android(二)全局设置、自定义BuildConfig、混淆-by:nixs

本文详细介绍了Gradle在Android开发中的基本配置、依赖管理、多渠道打包和签名信息设置。通过全局变量、config.gradle文件、gradle.properties的使用,实现版本和依赖的统一管理。同时,讲解了如何自定义BuildConfig字段以适应不同环境,并展示了启用混淆的配置。文章还提供了完整的配置示例链接,帮助开发者更好地理解和应用Gradle。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

系列博客

Gradle for Android(一)基本配置、依赖管理
Gradle for Android(三)多渠道打包、配置签名信息

全局设置

根目录build.gradle

如果有很多项目,可以设置全局来统一管理版本号或依赖库,根目录下build.gradle添加:

def androidSupportVersion = '25.3.1'
ext {
    //编译的 SDK 版本,如API20
    compileSdkVersion = 25
    //构建工具的版本,其中包括了打包工具aapt、dx等,如API20对应的build-tool的版本就是20.0.0
    buildToolsVersion = "26.0.0"
    //兼容的最低 SDK 版本
    minSdkVersion = 14
    //向前兼容,保存新旧两种逻辑,并通过 if-else 方法来判断执行哪种逻辑
    targetSdkVersion = 22
    appcompatV7 = "com.android.support:appcompat-v7:$androidSupportVersion"
}

app/build.gradle

android {
    compileSdkVersion rootProject.ext.compileSdkVersion
    buildToolsVersion rootProject.ext.buildToolsVersion
    defaultConfig {
        applicationId "com.wuxiaolong.gradle4android"
        minSdkVersion rootProject.ext.minSdkVersion
        targetSdkVersion rootProject.ext.targetSdkVersion
        versionCode 1
        versionName "1.0"
    }
}
dependencies {
    //……    
    compile rootProject.ext.appcompatV7
}

新建config.gradle

可以在根目录下建个config.gradle,然后只需在根目录下build.gradle最顶部加上下面一行代码,然后同步下,意思就是所有的子项目或者所有的modules都可以从这个配置文件里读取内容。

apply from: "config.gradle"

config.gradle

ext {
    android = [
            compileSdkVersion: 23,
            buildToolsVersion: "23.0.2",
            minSdkVersion    : 14,
            targetSdkVersion : 22,
    ]
    dependencies = [
            appcompatV7': 'com.android.support:appcompat-v7:23.2.1',
            design      : 'com.android.support:design:23.2.1'
    ]
}

app/build.gradle

android {
    compileSdkVersion rootProject.ext.android.compileSdkVersion
    buildToolsVersion rootProject.ext.buildToolsVersion
    defaultConfig {
        applicationId "com.wuxiaolong.gradle4android"
        minSdkVersion rootProject.ext.android.minSdkVersion
        targetSdkVersion rootProject.ext.android.targetSdkVersion
        versionCode 1
        versionName "1.0"
    }
  
...
dependencies {
    compile fileTree(dir: 'libs', include: ['*.jar'])
    testCompile 'junit:junit:4.12'
    compile rootProject.ext.dependencies.appcompatV7
    compile rootProject.ext.dependencies.design
}

gradle.properties

根项目下的gradle.properties:

COMPILE_SDK_VERSION=25
BUILDTOOLS_VERSION=26.0.0
SUPPORT_LIB_VERSION=25.3.1
MIN_SDK_VERSION=12
TARGET_SDK_VERSION=25

app/build.gradle

android {
    compileSdkVersion Integer.parseInt(COMPILE_SDK_VERSION)
    buildToolsVersion BUILDTOOLS_VERSION
    defaultConfig {
        minSdkVersion Integer.parseInt(MIN_SDK_VERSION)
        targetSdkVersion Integer.parseInt(TARGET_SDK_VERSION)
        versionName "0.0.1"
    }
dependencies {
    compile "com.android.support:support-v4:${SUPPORT_LIB_VERSION}"
    compile "com.android.support:appcompat-v7:${SUPPORT_LIB_VERSION}"
}

自定义BuildConfig

实际开发中服务器可能有正式环境和测试环境,gradle可以通过buildConfigField来配置。

defaultConfig {
       buildConfigField 'String','API_SERVER_URL','"http://wuxiaolong.me/"'
   }

buildConfigField 一共有3个参数,第一个是数据类型,和Java的类型是对等的;第二个参数是常量名,这里是API_SERVER_URL;第三个参数就是你要配置的值。

如图路径下就有个常量API_SERVER_URL,如何在代码取得这个常量值:

Log.d("wxl", "API_SERVER_URL=" + BuildConfig.API_SERVER_URL);

一般release发布版本是需要启用混淆的,这样别人反编译之后就很难分析你的代码,而我们自己开发调试的时候是不需要混淆的,所以debug不启用混淆。对release启用混淆的配置如下:

android {
    buildTypes {
        release {
            minifyEnabled true//是否启动混淆
			shrinkResources true //是否移除无用资源文件,shrinkResources依赖于minifyEnabled,必须和minifyEnabled一起用
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }
   }
}

minifyEnabled为true表示启用混淆,proguardFile是混淆使用的配置文件,这里是module根目录下的proguard-rules.pro文件

完整配置

https://github.com/WuXiaolong/Gradle4Android

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值