架构师(二)——gradle语法

项目结构

在根目录创建config.gradle,并把公用的字段定义好

// 添加多个自定义属性,可以通过ext代码块
ext {

    username = "simon"

    // 生产/开发环境(正式/测试)
    isRelease = true

    // 建立Map存储,对象名、key都可以自定义,groovy糖果语法,非常灵活
    androidId = [
            compileSdkVersion: 28,
            buildToolsVersion: "29.0.0",
            minSdkVersion    : 19,
            targetSdkVersion : 28,
            versionCode      : 1,
            versionName      : "1.0"
    ]

    appId = [
            app    : "com.netease.modular.gradle",
            library: "com.netease.modular.library"
    ]

    // 生产/开发环境URL
    url = [
            "debug"  : "https://11.22.33.44/debug",
            "release": "https://11.22.33.44/release"
    ]

    supportLibrary = "28.0.0" // ${xxx}
    // 第三方库
    dependencies = [
            "appcompat" : "com.android.support:appcompat-v7:${supportLibrary}",
            "recyclerview" : "com.android.support:recyclerview-v7:${supportLibrary}",
            "constraint" : "com.android.support.constraint:constraint-layout:1.1.3"
    ]
}

接下来看app中的build.gradle

如果要在build.gradle中打印,可以使用
println("hello gradle")
println "hello gradle"

要访问config.gradle中定义的字段,首先要在根目录的build.gradle中加入一条语句apply from: "config.gradle",相当于include。这样,所有的module都可以访问这个config.gradle
如果把字段直接放到根目录的build.gradle里面,也是可以的,不需要apply from,可以直接访问

访问自定义的字段
使用"${xxxxxxx}"
比如说访问config.gradle中的username,可以使用println "${username}"
如果要修改变量的值,那就要使用全路径:rootProject.ext.username = 163

赋值与引用

def androidId = rootProject.ext.androidId
def appId = rootProject.ext.appId
def support = rootProject.ext.dependencies
def url = rootProject.ext.url
//使用
compileSdkVersion androidId.compileSdkVersion

遍历map

dependencies {
    implementation fileTree(dir: 'libs', include: ['*.jar'])
    // 标准写法
    // implementation group: 'com.android.support', name:'appcompat-v7', version:'28.0.0'
    // 简写
    // implementation 'com.android.support:appcompat-v7:28.0.0'

    // 依赖library库
    implementation project(":library")
//    implementation support.appcompat
//    implementation support.recyclerview
//    implementation support.constraint

    // 依赖第三方库最简洁的方式:
    support.each { k, v -> implementation v }
}

另一种写法
在gradle.properties中定义字段,比如:
MIN_SDK_VERSION = 15
TAR_SDK_VERSION = 28
COMPILER_SDK_VESION = 28
LOGIN_IS_APPLICATION = false
MEMBER_IS_APPLICATION = false
在build.gradle中这样使用
minSdkVersion MIN_SDK_VERSION.toInteger()
targetSdkVersion TAR_SDK_VERSION.toInteger()
if(!LOGIN_IS_APPLICATION.toBoolean()){
}

代码中使用自定义的字段

// 签名配置(必须写在buildTypes之前)
    signingConfigs {
        debug {
            storeFile file('C:/Users/Administrator/.android/debug.keystore')
            storePassword "android"
            keyAlias "androiddebugkey"
            keyPassword "android"
        }
        release {
            // 签名证书文件
            storeFile file('D:/NetEase/netease.jks')
            // 签名证书的类型
            storeType "netease"
            // 签名证书文件的密码
            storePassword "net163"
            // 签名证书中密钥别名
            keyAlias "netease"
            // 签名证书中该密钥的密码
            keyPassword "net163"
            // 是否开启V2打包
            v2SigningEnabled true
        }
    }
    buildTypes {
        debug {
            // 对构建类型设置签名信息
            signingConfig signingConfigs.debug
            buildConfigField("String", "debug", "\"${url.debug}\"")
        }

        release {
            minifyEnabled false
            // 对构建类型设置签名信息
            signingConfig signingConfigs.release
            buildConfigField("String", "debug", "\"${url.release}\"")
            proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
        }
    }

注意看这一句buildConfigField("String", "debug", ""${url.debug}"")
这个加上之后,重新build一下工程,就会在BuildConfig.java中生成自定义的字段,代码中可以通过BuildConfig.debug去访问
我们可以看到debug和release是不一样的

app\build\generated\source\buildConfig\debug\com\netease\modular\gradle\BuildConfig.java
public final class BuildConfig {
  public static final boolean DEBUG = Boolean.parseBoolean("true");
  public static final String APPLICATION_ID = "com.netease.modular.gradle";
  public static final String BUILD_TYPE = "debug";
  public static final String FLAVOR = "";
  public static final int VERSION_CODE = 1;
  public static final String VERSION_NAME = "1.0";
  // Fields from build type: debug
  public static final String debug = "https://11.22.33.44/debug";
}
app\build\generated\source\buildConfig\release\com\netease\modular\gradle\BuildConfig.java
public final class BuildConfig {
  public static final boolean DEBUG = false;
  public static final String APPLICATION_ID = "com.netease.modular.gradle";
  public static final String BUILD_TYPE = "release";
  public static final String FLAVOR = "";
  public static final int VERSION_CODE = 1;
  public static final String VERSION_NAME = "1.0";
  // Fields from build type: release
  public static final String debug = "https://11.22.33.44/release";
}

一些其他配置

// 将svg图片生成 指定维度的png图片
// vectorDrawables.generatedDensities('xhdpi','xxhdpi')
// 使用support-v7兼容(5.0版本以上)
vectorDrawables.useSupportLibrary = true
// 只保留指定和默认资源
resConfigs('zh-rCN')

// 配置so库CPU架构(真机:arm,模拟器:x86)
// x86  x86_64  mips  mips64
ndk {
    //abiFilters('armeabi', 'armeabi-v7a')
    // 为了模拟器启动
    abiFilters('x86', 'x86_64')
}



// 源集 - 设置源集的属性,更改源集的 Java 目录或者自由目录等
sourceSets {
    main {
        if (!isRelease) {
            // 如果是组件化模式,需要单独运行时
            manifest.srcFile 'src/main/AndroidManifest.xml'
            java.srcDirs = ['src/main/java']
            res.srcDirs = ['src/main/res']
            resources.srcDirs = ['src/main/resources']
            aidl.srcDirs = ['src/main/aidl']
            assets.srcDirs = ['src/main/assets']
        } else {
            // 集成化模式,整个项目打包
            manifest.srcFile 'src/main/AndroidManifest.xml'
        }
    }
}   

你可能感兴趣的:(架构师(二)——gradle语法)