安卓开发安卓资源收集安卓开发

Build.gradle 与 BuildConfig 小记

2019-11-27  本文已影响0人  卡路fly

1. Build.gradle

android#defaultConfig

android {
    ......
    defaultConfig {//默认项目配置信息
        applicationId "com.**.**" //应用的id,这里决定应用的唯一标识。
        minSdkVersion 9 //决定此应用最低兼容的安卓系统版本
        targetSdkVersion 23 //决定此应用最高可兼容的安卓系统版本
        versionCode 1 //应用的版本号
        versionName "1.0" //应用的版本名
    }
    ......
}

android#buildTypes

android {
    ......
    buildTypes {//构建的类型方式
            release { // release方式,一般这种是定义为正式包渠道
                minifyEnabled false //编译时是否混淆的开关
                proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'//混淆文件的路径,注意这里用的是proguardFiles,是后面带s的,所以可以添加多个混淆文件路径,每个之间用“,“号隔开
    }
    ......
}

dependencies

dependencies {
    compile fileTree(xxx) //编译的文件树
    testCompile 'xxxx' //测试项目需要引用的
    compile 'xxxx' //正常项目需要引用的
}

拓展写法

android#signingConfigs

android {
    ......
    signingConfigs {//签名配置
        config { //此 config 名称是自定义的
            keyAlias '指定签名文件的别名'
            keyPassword '指定签名文件的别名配对密码'
            storeFile file('签名文件路径')
            storePassword '签名文件的密码'
        }
    }
    ......
}

android#defaultConfig

android{
    ......
    defaultConfig {
        ......
        testApplicationId '测试工程的application id'
        testInstrumentationRunner '测试工程'
        signingConfig signingConfigs.config //配置默认签名配置
        proguardFile '默认混淆文件配置'
        proguardFiles '默认多个混淆文件配置'
    }
    ......
}

android#buildTypes

android{
    ......
    buildTypes{
        release{
            ......
        }
        custom{
            ......
        }
        debug{//debug,默认包含此类型,参数都是默认的
        //这里就以debug为例,这里的语法在release和自定义中也是支持的
            debuggable true //默认false,是否开启断点调试
            jniDebuggable true //默认false,是否开启jni的断点调试
            signingConfig signingConfigs.config //配置签名方式,这里配置会覆盖defaultConfig中配置的签名方式
            renderscriptDebuggable true //默认false,是否开启 renderscript 断点调试
            renderscriptOptimLevel 2 //renderscript的版本号
            minifyEnabled true //默认false,是否混淆的开关
            pseudoLocalesEnabled true //默认false,是否支持本地化整理
            applicationIdSuffix '.test' //applicationId的后缀,相当于更改了applicationId,可以认为是一个新的应用
            versionNameSuffix '.520' //版本名的后缀
            zipAlignEnabled false //默认true,是否进行zip align优化

            //--------------------
            buildConfigField "boolean", "IS_DEBUG", "true"//为BuildConfig类创建一个常量,类型为boolean,变量名为IS_DEBUG,值为true
            resValue "string", "name", "value" //在strings.xml中创建一个名为name,值为value的一个字符串资源
        }
    }
    ......
}

BugildConfig

自定义BuildConfig

buildConfigField(String type,String name,String value)

参数 解释
type 要创建的字段类型
name 要创建的字段名
value 创建此字段的值

build.gradle

buildTypes {
         ……
        debug {
             ……
            // 只在debug环境可以获取
            buildConfigField "boolean", "logEncrypt", logEncryptFlag
            buildConfigField "boolean", "debugUI", debugUI
            ……
        }
        ……
}

BuildConfig

public final class BuildConfig {
  // 这个常量是标识当前是否为`debug`环境,由`buildType`中的`debuggable`来确定的,这是修改此类值的一个方式
  public static final boolean DEBUG = Boolean.parseBoolean("true");
  // application id
  public static final String APPLICATION_ID = "com.**.**";
  // 当前编译方式
  public static final String BUILD_TYPE = "debug";
  // 编译渠道,如果没有渠道,则为空
  public static final String FLAVOR = "dev";
  // 版本号
  public static final int VERSION_CODE = 1;
  // 版本名,获取当前应用的版本名可以直接 BuildConfig.VERSION_NAME
  public static final String VERSION_NAME = "1.1.1.1";
  
  // Fields from build type: debug
  public static final boolean debugUI = true;
  public static final boolean logEncrypt = false;
}

参考文章

上一篇下一篇

猜你喜欢

热点阅读