关于Android-Studio3.0中的Gradle配置


AS3.0 新特性

看官方的版本发布说明,就能知道大概了: https://developer.android.google.cn/studio/releases/index.html

如:

对java8的一些feature的支持; 
profiler debug;
device file explorer;
instant apps support;
app links support;
layout editor;
apk analyzer;
d8 dex compiler;
...

Gradle 变化

kotlin、cmake的支持,新建一个项目,应用这些特性,就能看到配置了,就不贴了

AS3.0的gradle变化的说明地址:https://developer.android.google.cn/studio/build/gradle-plugin-3-0-0-migration.html

gradle.properties

#新的dex编译器
android.enableD8 = true

<module>/build.gradle

  • 新的依赖项
api: 与以前的compile 完全一样:在依赖项,其内部的依赖发生变化时,将会使所有的module重新编译;且会向外暴露所依赖子项的接口。
implementation:  在依赖项,其内部的依赖发生变化时,只重新编译内部依赖项;不会向外暴露内部依赖项的接口
testImplementation:测试依赖。        对应以前:testCompile
compileOnly:  只编译,不打参与打包。   对应以前:provided
runtimeOnly:  只在运行时,参与打包。   对应以前:apk

作者君,某天就被api和implementation 坑了好久。还以为哪里的环境出了问题,报各种gradle相关错误。

引发的场景:有一个android-Lib-module, 内部有依赖一些jar文件… 在app-module中,有代码使用到了jar文件中的类;而在android-Lib-module中jar的依赖是这样的implementation fileTree(include: ['*.jar'], dir: 'libs'),造成在app中老是提示 cannot access xxx-class

  • productFlavors 要求每个flavor都有配置一个dimension属性
demo {
  dimension "DimenA"
  applicationId "com.stone.myapplication.pro"
  ...
}

这些dimension要配置在一个地方,一般放在defaultConfig中:

defaultConfig {
  ...
  flavorDimensions "DimenA", "DimenB"
}

3.0 之前:flavors和buildTypes的子项 会多对多匹配;即会有 m * n 个build variant

3.0 之后:flavors中需要配置dimension, 其又声明在flavorDimensions里面;
匹配规则是:不同dimension的flavor会被联合,然后与buildTypes的每项匹配。

如buildType有:debug和release; productFlavors如下:

demo {
  dimension "DimenA"
  applicationId "com.stone.myapplication.pro"
}

full {
  dimension "DimenA"
  applicationId "com.stone.myapplication.free"
}

xxx {
  dimension "DimenB"
  applicationId "com.stone.myapplication.xxx"
}

这样就会组合成如下6项build variant:

demoXxxDebug
demoXxxRelease
demoXxxStaging
fullXxxDebug
fullXxxRelease
fullXxxStaging
  • applicationVariants中的变化

3.0前可以改变apk的输出路径和名字:

applicationVariants.all { variant ->
    variant.outputs.each { output ->
        output.outputFile = ...
    }
}

3.0中,outputFile只有get方法,没有set方法了,所以不能通过这种方式设置

可以通过如下方式,设置输出apk的名字:

applicationVariants.all { variant ->
  variant.outputs.all {
      outputFileName = "v${variant.versionName}_${variant.flavorName}}.apk"
  }
}

关于variant.outputs.each 要说的一点是:该迭代器,访问的对象需要在构建之前就已经是存在的。测试时发现如果在each内操作一个File对象,其对应的文件必须事先存在,才能操作;且在构建任务一开始运行时就被执行了。

猜你喜欢

转载自blog.csdn.net/jjwwmlp456/article/details/80271366