美文网首页
productFlavors + buildTypes + si

productFlavors + buildTypes + si

作者: hxx | 来源:发表于2018-02-13 11:27 被阅读0次

    gradle 脚本作为 AndroidStudio 使用的打包控制语言,有其独特的优势。

    常见功能

    和其他脚本语言一样,gradle 脚本也支持实现常见的功能和操作

    • def 定义变量和方法
    def getConfigs(environment,fileName) {
        //断言变量不为空
        assert environment!=null
        assert fileName!=null
        Properties props = new Properties()
        //加载文件内容为 Properties,方便使用
        props.load(new FileInputStream(file("conf/$environment/$fileName")))
        return props
    }
    
    • ${} 引用变量
    • ext 暴露变量(或方法)
    • 引入其他脚本文件
    apply from: "${rootProject.projectDir}/dependency/dependency.gradle"
    

    productFlavors 指定打包风味

    • productFlavors 下可以新增 flavor ,每个 flavor 都可以覆盖defaultConfig下的属性实现差异化。如:包名、应用名、编译版本;
    • flavor 里也可以执行脚本代码,实现特殊逻辑。
    • productFlavors.all 的代码所有 flavor 都会执行
    productFlavors.all{
                flavor ->
                ……
    }
    
    • buildConfigField 可以为 java 程序提供差异化的变量,在代码中借助
      BuildConfig 类得到这些变量。比如: BuildConfig.FLAVOR 的值是当前的
      flavor
    • manifestPlaceholders 可以给清单文件里的变量赋值,清单文件里 "${变量名}"获取值。常用于包名传递,及不同 flavor 不同的第三方 key
    android {
      productFlavors {
       dev{
       }
       prod{
       }
       ...............
         productFlavors.all{
                flavor ->
                    def props = getConfigs(name,'conf.properties')
                    props.propertyNames().each { name ->
                        buildConfigField valueType(props.getProperty(name.toString())), name, props.getProperty(name.toString())
                    }
                    manifestPlaceholders = [
                            JPUSH_PKGNAME : "${applicationId}"                        
                    ]
            }
      }
    }
    

    signingConfigs 签名配置

    signingConfigs 用于声明签名配置,使用自定义配置前必须先定义

    • signingConfigs 下可以定义多个签名配置供不同 falvor 和 buildType 使用
    • 变量可以在项目根目录的 gradle.properties 文件定义,gradle 脚本直接按变量名使用即可
    signingConfigs {
            demo{
                storeFile file(DEMO_STORE_FILE)
                storePassword DEMO_STORE_PASSWORD
                keyAlias DEMO_KEY_ALIAS
                keyPassword DEMO_KEY_PASSWORD
            }
           .......
        }
    

    buildTypes 打包配置

    buildTypes 下可以制定多个打包方式,一般会有debug、release,可以指定不同的签名方式、混淆逻辑等

    • 与 productFlavors 类似 applicationVariants.all 是所有配置都会执行的代码
    • debug 打包方式不指定 signingConfig ,则使用默认签名(系统默认的签名证书)
        buildTypes {
            debug {
                minifyEnabled false
                zipAlignEnabled false
                shrinkResources false       
                signingConfig signingConfigs.debug    
            }
            release {
                //是否混淆
                minifyEnabled true
                zipAlignEnabled true
                // 移除无用的resource文件
                shrinkResources false
                proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
                signingConfig signingConfigs.release    
            }
    
            applicationVariants.all {
                variant ->
                    variant.outputs.all {
                        outputFileName = "DEMO_${variant.name}_${variant.versionName}.apk"
                    }
            }
        }
    
    

    不同 flavor 使用不同签名配置

    • 在 flavor 里指定 signingConfig (使用前先定义)就可以指定 release 包的签名配置,但对 debug 包无效
    android {
      productFlavors {
       dev{
                    signingConfig signingConfigs.dev
       }
       prod{
                    signingConfig signingConfigs.prod
       }
       ...............
          }
    }
    
    • 如果想 debug 包也使用不同的签名配置,可以显示的指定 debug 使用release 的签名配置
        buildTypes {
            debug {
                // 指定 debug 使用release的签名
                signingConfig release.signingConfig
            }
            release {
            }
        }
    

    这样就可以完成 gradle 脚本控制不同 flavor 使用不同的签名

    相关文章

      网友评论

          本文标题:productFlavors + buildTypes + si

          本文链接:https://www.haomeiwen.com/subject/nctdtftx.html