详解Android Studio 3.0的新特性与适配
简介
android studio升级到3.0后,有不少的改动和新特性,先贴出。
本文会持续收集与总结本人在使用android studio 3.0进行开发的过程中所遇到的问题。
版本配置
gradle版本
- android studio 3.0需要的gradle版本至少为4.1。
- 如果是使用gradle wrapper,则工程根目录/gradle/wrapper/gradle-wrapper.properties中的distributionurl字段为https\://services.gradle.org/distributions/gradle-4.1-all.zip。
android gradle插件版本
android studio 3.0需要android gradle插件版本为3.0.0。
android studio 3.0默认使用google's maven repository来下载android support library,所以在脚本中要使用google()来加入谷歌仓库。
工程根目录/build.gradle的相关配置如下。
buildscript { repositories { google() } dependencies { classpath 'com.android.tools.build:gradle:3.0.0' } }
使用annotationprocessor
从android studio 3.0开始,使用annotationprocessor代替apt。不可再使用apt,否则会编译报错。
error:android-apt plugin is incompatible with the android gradle plugin. please use 'annotationprocessor' configuration instead.
比如在android studio 3.0之前在application模块导入butterknife 8.4.0的gradle配置如下。
buildscript { dependencies { classpath 'com.neenbedankt.gradle.plugins:android-apt:1.8' } }
apply plugin: 'com.neenbedankt.android-apt' dependencies { compile 'com.jakewharton:butterknife:8.4.0' apt 'com.jakewharton:butterknife-compiler:8.4.0' }
而在android studio 3.0中,使用annotationprocessor代替apt,不用再导入android-apt插件。
dependencies { compile 'com.jakewharton:butterknife:8.4.0' annotationprocessor 'com.jakewharton:butterknife-compiler:8.4.0' }
修改apk名称
常用的修改输出的apk文件的名称的脚本如下。
def apkbasename() { // 先查找project.ext.apkname变量,若无则使用项目名 if(project.hasproperty("apkname")) { return project.apkname } else { return project.name } } def buildtime() { return new date().format("yyyymmdd") } def delunderline(string str) { def result = str.startswith("_") ? str.substring(1) : str return result.endswith("_") ? result.substring(0, result.length() - 1) : result } android.applicationvariants.all { variant -> // applicationvariant variant.outputs.each { output -> // basevariantoutput def file = output.outputfile if(file != null && file.name.endswith(".apk")) { def flavorname = delunderline(variant.flavorname) def buildtypename = delunderline(variant.buildtype.name) def apkfile = new file(file.parent, "${apkbasename()}_" + "${buildtypename.empty ? "" : buildtypename + "_"}" + "${flavorname.empty ? "" : flavorname + "_"}" + "v${variant.versionname}_" + "${buildtime()}.apk") output.outputfile = apkfile } } }
在android studio 3.0中执行此脚本会报错如下,原因是apkvariantoutputimpl的outputfile属性改为只读。
cannot set the value of read-only property ‘outputfile' for apkvariantoutputimpl_decorated{apkdata=main{type=main, fullname=debug, filters=[]}} of type com.android.build.gradle.internal.api.apkvariantoutputimpl
不再设置outputfile属性,而是设置outputfilename。同时把each()改为all()。
android.applicationvariants.all { variant -> // applicationvariant variant.outputs.all { if (outputfilename.endswith(".apk")) { def flavorname = delunderline(variant.flavorname) def buildtypename = delunderline(variant.buildtype.name) outputfilename = "filename" } } }
aapt2
为了改进增量资源处理,android gradle插件3.0默认开启aapt2。
在旧项目中开启aapt2,有时候会报错,如:
error: java.util.concurrent.executionexception: com.android.tools.aapt2.aapt2exception: aapt2 error: check logs for details
可在gradle.properties中加入以下配置来禁用aapt2。
android.enableaapt2=false
新的依赖配置
gradle 3.4推出了新的java library plugin配置,而android gradle插件3.0是使用gradle 4.1的,因此,需要注意更改为新的依赖配置。
旧的依赖配置,如compile project(':base-library'),会导致如下错误。应该修改为implementation project(':base-library')。
error:cannot choose between the following configurations of project :base-library: - debugapielements - debugruntimeelements - releaseapielements - releaseruntimeelements
flavor
从android gradle插件3.0开始,如果build.gradle中有自定义的productflavors配置,需要添加自定义的flavordimensions(风味维度),否则会编译报错。
error:all flavors must now belong to a named flavor dimension.
the flavor 'flavor_name' is not assigned to a flavor dimension.
解决方法是:先定义一个flavordimensions,之后在每个flavor中指定为这个dimension。
android { flavordimensions 'core' productflavors { beta { dimension 'core' } production { dimension 'core' } } }
在设置flavordimensions之前,最终的build variant = product flavor + build type。而设置之后,最终的build variant = 维度1 + 维度2 + ... + 维度n + build type。
kotlin支持
在android studio 3.0之前,使用kotlin需要进行额外的配置。而android studio 3.0开始,默认内置支持kotlin,无需额外配置。
使用android studio工具栏中的code -> convert java file to kotlin file,可将.java文件转为.kt文件。
java8支持
从android studio 2.1起,官方通过jack来支持java8,从而开发者能使用lambda等特性。
android { compileoptions { sourcecompatibility javaversion.version_1_8 targetcompatibility javaversion.version_1_8 } defaultconfig { jackoptions { enabled true } } }
可在android studio工具栏,file -> project structure,修改source compatibility和target compatibility为1.8。
project structure
从android studio 3.0起,默认支持java8,无需额外进行jackoptions配置。
android profiler
从android studio 3.0起,新增android profiler来代替旧的android monitor工具。
android profiler提供了cpu、memory和network等三个调试分析工具。
android profiler
android profiler的详细使用方法参考官方文档。
cpu profiler
memory profiler
network profiler
device file explorer
在android studio 3.0主界面的右下角,点开"device file explorer",可访问当前连接设备的文件。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
推荐阅读
-
详解Android Studio 3.0的新特性与适配
-
浅谈Android Studio 3.0 工具新特性的使用 Android Profiler 、Device File Explorer
-
详解升级Android Studio3.0时遇到的几个问题
-
Android Studio3.0新特性及安装图文教程
-
神经网络API、Kotlin支持,那些你必须知道的Android 8.1预览版和Android Studio 3.0新特性
-
详解Android Studio 3.0的新特性与适配
-
android studio 3.6.0 绑定视图新特性的方法
-
浅谈Android Studio 3.0 工具新特性的使用 Android Profiler 、Device File Explorer
-
解决Android Studio新版本(3.0以上)与butterknife不兼容的问题
-
Android Studio 4.0新特性及升级异常问题的解决方案