Android:你好,androidX.再见,android.s

作者: CnPeng | 来源:发表于2018-09-27 10:26 被阅读114次

1、AndroidX简介

点击查看Android文档中对androidx的简介

按照官方文档说明 androidx 是对 android.support.xxx 包的整理后产物。由于之前的support包过于混乱,所以,google推出了 androidX。

由于在后续版本中,会逐步放弃对support 的升级和维护,所以,我们必须迁移到 androidX.对此,官方描述如下:

Existing packages, such as the Android Support Library, are being refactored into AndroidX.
Although Support Library versions 27 and lower are still available on Google Maven,
all new development will be included in only AndroidX versions 1.0.0 and higher.

2、迁移步骤

2.1 修改gradle.properties

android.useAndroidX=true
android.enableJetifier=true

其中:

  • android.useAndroidX=true 表示当前项目启用 androidx
  • android.enableJetifier=true 表示将依赖包也迁移到androidx 。如果取值为false,表示不迁移依赖包到androidx,但在使用依赖包中的内容时可能会出现问题,当然了,如果你的项目中没有使用任何三方依赖,那么,此项可以设置为false

2.2 如何迁移

点击查看官方迁移指南

在AndroidStudio 3.2 或更高版本(目前最新正式版为3.2,其他更高版为alpha版)中执行如下操作:

  • Refactor > Migrate to AndroidX


    image

在执行该操作时会提醒我们是否将当前项目打包备份。如果你提前已经做好了备份,可以忽略;如果没有备份,则先备份。

3 迁移后续

3.1 手动修改错误包名

由于 Migrate to AndroidX 执行之后,部分控件的包名/路径名转换的有问题,所以还需要我们手动调整(包括修改xml布局文件和.java/.kt 文件)。

如:ViewPager,RecyclerView 等,这些内容在迁移完成之后,包名是 androidx.core.weight.xxxx,这是一个错误的包名,我们必须手动修改,否则,无法正常编译——点击绿色 Run(运行) 按钮时会详细报出哪里有错误。

此处需要注意,在 AndroidStudio 的 build 选项卡中一次最多只会报 50条错误!! 所以,可能在你修完第一批之后,后面还有N个50。此处要保持一个平静的💗。

3.2 修复DataBinding中的错误

在 AndroidStudio3.2 + androidx 环境下,对错误的检查和处理更为严格。如果同一个xml布局文件中存在同名id,在之前的版本中,我们可以正常编译和运行,但是,在新的环境下, 必然会报错,错误信息如下:

image

在上图的错误信息中,我们以 DecibelBinding 为例,简述修复过程。

  • 如上图,无法将xxxBinding 构造器中的xxxBinding应用到指定类型指明了出错的 Binding类 为 DecibelBinding

  • 按照DataBinding类名的生成规则,我们可以知道,DecibelBinding 对应的xml文件名应该是 decibel.xml (如果你在xml中通过 class="xxxBinding" 指定了DataBinding的生成类名,那么就全局搜索吧)

  • 在确定了xml之后,我们还需要知道到底哪里出了错误,那么,就继续看图中的 错误:找不到符号 符号:变量 xxx.这个变量就是控件的id名称。

  • DataBinding转换控件id名的规则是:去除下划线连接符,然后将原下划线后面的第一个字母大写。所以,图中的 fragmentDiscoverGridItemRelativeLayout1 对应的控件id应该是:@+id/fragment_discover_grid_item_relative_layout,后面之所以有一个1 ,是因为重复了。然后,我们在对应的xml文件中搜索这个控件名,然后删除重复即可。

3.3 去除 attr.xml 中重复的属性名称

在迁移到 androidX 之前,我们为自定义控件编写自定义属性时,可以与android已有的属性重名,但是,在AndroidX环境下不行了,如果存在重名的情况, 必然会报错——会提示你重复定义(详细错误信息没截图,但翻译过来就是重复定义了attr/xxx)。

  • 错误示例:
<declare-styleable name="RoundImageView">
    ...
    <!-在迁移到androidx之前,这样写虽然不规范,但是能用,不报错->
    <attr name="textSize" format="Integer" />
    ...
</declare-styleable>
  • 正确示例
<declare-styleable name="RoundImageView">
    ...
    <!-迁移到androidX之后,必须使用android:xxx 属性,不能定义android已有的属性->
    <attr name="android:textSize" />
    ...    
</declare-styleable>

关于重名属性,在 androidX 中不知道哪个控件中包含了一个 mode 属性,所以,如果之前你的自定义控件中有 attr/mode,需要手动改成其他。

3.4 Glide中的注解不兼容androidX

迁移到 androidX 之后,Glide中使用的 android.support.annotation.CheckResultandroid.support.annotation.NonNull这两个注解无法迁移。之前有用户在Glide中提过issue: https://github.com/bumptech/glide/issues/3185

在上述issue 中有用户表示,将Glide升级到 4.8.0 之后,可以正常迁移。但是,我这边并不行。然后,我先升级了Glide ,又在 gralde文件中增加了support.annotation ,这样才能正常编译通过。貌似在后续Glide 5.x 版本中会完成对 androidx的完全兼容。

我的临时解决方案:

 //图片加载——Glide
implementation "com.github.bumptech.glide:glide:4.8.0
annotationProcessor "com.github.bumptech.glide:compiler:4.8.0

//CnPeng 2018/9/26 下午8:38 这两行是为了解决 https://github.com/bumptech/glide/issues/3185 ——Glide 中的注解还没有完全兼容androidx
implementation "com.android.support:support-annotations:28.0.0-alpha3"
annotationProcessor "com.android.support:support-annotations:28.0.0-alpha3"

3.5 规范包名(即文件夹名)

这里所说的包名,指的是项目中的文件夹名称。在之前版本中,我们命名包名时可能会出现大写字母,虽然这并不符合Java命名规范,但起码能正常编译和运行。然而,升级到 AndroidStudio3.2 + androidX 环境后,必须严格遵守命名规范,否则,可能报错,从而导致不能正常编译和运行。

错误示例:

正确示例:


对于包名的命名规范,好像要求并非十分严格。因为我发现,部分包含大写字母的报名在编译时会报错,部分不报错。但是,遵守规范总会更好一点!

相关文章

网友评论

  • 87457174aa9e:大神牛逼:smile:
  • c20478772317:我本机的项目引用的都是同一个gradle.properties文件,这样一改其他的项目也就改了,请问有什么办法吗?
    CnPeng:抱歉,这个——我也不知道:joy:
  • 小小_轮上飘:迁移时最恶心的事引入和好多三方库,然而三方库已经不维护了。就指的把作者的代码clone下来修改完之后以项目的形式导入引入项目
    CnPeng:@小小_轮上飘 确实存在这种问题。
    小小_轮上飘:@CnPeng clone下来不方便的地方是作者更新了新功能修复了潜在bug后你还得从新clone一遍
    CnPeng:我是被DataBinding的报错恶心到了,因为我们之前的DataBinding代码中有许多不规范的地方。关于三方库,除了几个大公司的库,我大部分都是clone下来,然后自己摘取其中需要的部分直接放到项目中——当然了,摘取的过程也很痛苦,但是方便扩展和维护
  • 06665b1c6699:你好 针对项目中其中一个sdk需要 android.enableJetifier = false 有对策吗
    CnPeng:@06665b1c6699 你要保留的是个什么库?等忙过这段时间我也去研究一下
    :smiley:
    06665b1c6699:@CnPeng多谢, 我放弃了挣扎。。
    CnPeng:这个。。。真的就不知道怎么做了
  • 受伤的粽子:迁移后可以撤销吗
    CnPeng:@受伤的粽子 迁移的操作不可逆,所以,需要自己提前做好备份——在点击“Migrate to AndroidX ” 的时候也会提醒你备份
  • 550a1c5c4c37:迁移了androidX后,第三方库不兼容,android.enableJetifier=true无效
    CnPeng:@issyou這一秒 到对应三方库的官方网站/地址中查看相关迁移说明,看看是否已经做了 androidX的适配
  • 有点健忘:不记得上次是学习 room还是啥,用的androidx,最后编译都挂了,后来就不用它了。
    先收藏了,等不忙的时候把demo都改成x试试:smile:
    CnPeng:极有可能是包名导致的。今早AndroidStudio又推送 3.2.1的更新,不知道新版中对于 migrate androidX 的支持是否更好。
  • 阿群1986:怀疑谷歌准备先把安卓弄死,好力推她家的新操作系统

本文标题:Android:你好,androidX.再见,android.s

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