谷歌针对的Q预览版的特性分享,内容涉及比较多。遗憾的是没有提供PPT给参会者,如下内容根据提纲与回忆整理,如有缺失敬请谅解。
适配Q重点归纳
- 限制后台拉activity
- 非系统应用无法获取到IMEI
- 外部存储的隔离存储;公共媒体文件的存储
- 后台地理位置权限
- 适配折叠屏
- 全屏手势导航,应用充分利用全面屏,建议应用不要覆盖系统手势,否则可能导致手势冲突,影响用户使用习惯
- 应用使用黑色主题,灵活动态变化
- Android Q,受限制的非SDK接口数量增多了
android Q发布时间表
1.后台启动 Acitvity 限制
禁止无用户交互的后台启动activity。
在后台,通过Notification也可以启动activity,但是通过alarm定时器无法启动activity。
允许Activity Starts的条件:
- 该应用有可见的窗口,例如有一个activity在前台
- 该应用程序有一个activity在foreground task
- 可见的应用程序绑定到应用程序的service
- 可见的应用程序发送该应用程序的pending intent
- 系统发送该应用程序的pending intent
- 系统发送broadcast到该应用程序
- 系统绑定到应用程序的服务
- 应用程序与配套硬件设备相关联
- 改应用程序是Device Policy Controller
2.设备标识符(deviceId)
从 Android Q 开始,应用必须具有 READ_PRIVILEGED_PHONE_STATE 签名权限才能访问设备的不可重置标识符(包含 IMEI 和序列号)。
原来的READ_PHONE_STATE权限已经不能获得IMEI和序列号,如果想在Q设备上通过如下代码获得设备ID,会返回空值(targetSDK<=P)或者报错(targetSDK==Q)。
((TelephonyManager) getActivity()
.getSystemService(Context.TELEPHONY_SERVICE)).getDeviceId()
IMEI 可以帮我们判断用户是否更换了设备。在 Android Q 里有没有合适的替代方案?
Android 官方唯一标识符最佳做法:https://developer.android.google.cn/training/articles/user-data-ids
3.Android Q 分区存储
官方文档:https://developer.android.google.cn/preview/privacy/scoped-storage
如下是Q Beta3版本的最新特性,目前网上大部分基于Beta1的存储分区解释有差异,以如下Beta3特性为准。
外部存储沙盒:
Android Q 在外部存储设备中为每个应用提供了一个“隔离存储沙盒”(例如 /sdcard)。任何其他应用都无法直接访问您应用的沙盒文件。卸载APK时也会删除SD卡沙盒内的数据,要想在卸载后保留文件,请将它们保存到MediaStore中.
访问自己文件:
当应用target Q时,它会进入分区存储模式,这意味着它不再能直接访问/sdcard。尝试直接访问将导致FileNotFoundException或EPERM错误。
可以无需任何权限,直接访问应用所属沙盒目录(例如Context.getExternalFilesDir()),要想访问沙盒目录以外的文件,需要使用MediaStore或存储访问框架SAF。
访问媒体文件:
要访问沙盒外的媒体共享文件,比如照片,音乐,视频等,需要通过MediaStore。MediaStore以外的文件需要通过系统的文件选择器应用来进行访问。
所有应用都可以在没有任何权限的情况下为MediaStore提供内容,但是要查看其他应用提供的内容,必须获取READ_EXTERNAL_STORAGE权限。
Metadata:
android Q开始,应用需要获取ACCESS_MEDIA_LOCATION权限才可以访问媒体文件的位置信息元数据。
MediaStore中的LATITUDE和LONGITUDE字段已废弃,请使用ExifInterface来替代。
适配:
当应用target Q时,默认会开启分区存储模式;Q以下,默认情况下,应用储存方式将不会发生任何改变,依旧采用与旧版本 Android 系统相同的储存机制。
主动开启或关闭分区特性,使用allowExternalStorageSandbox标签:
<manifest ... >
<application android:allowExternalStorageSandbox="false" ... >
</application>
</manifest>
明年的下个版本,与target SDK级别无关,所有应用都要支持分区存储。
4.Android Q 地理位置权限变更
Android 官方文档:https://developer.android.google.cn/preview/privacy/device-location
新增位置权限:ACCESS_BACKGROUND_LOCATION
除非应用的某个 Activity 可见或应用正在运行前台服务,否则应用将被视为在后台运行。如果应用需要在后台时也获得用户位置(比如滴滴),就需要动态申请ACCESS_BACKGROUND_LOCATION权限。
targetSDK <= P 应用如果请求了ACCESS_FINE_LOCATION 或 ACCESS_COARSE_LOCATION权限,Q设备会自动帮你申请ACCESS_BACKGROUND_LOCATION权限。
image
5.非SDK接口限制
Android 官方文档:https://developer.android.google.cn/preview/non-sdk-q#greylist-now-restricted
在 Android Q 中,受限制的非 SDK 接口数量更多了,建议您在开发时选用相等功能的公开 SDK 接口。为了帮助您成功过渡,并防止应用出现崩溃等问题,仅当应用的目标平台为 Android Q 时,这些限制才会生效。
名单 | 描述 | 影响 |
---|---|---|
白名单 | 公开SDK | |
浅灰名单 | 我们检测到有应用在使用的接口 | 允许访问,可能加入警告或日志 |
深灰名单 (maxTargetSDK = P) |
"接近"浅灰名单的接口,并在android新版本中已经增加了公开替代接口 | 当应用的targetSDK在P或者更早时,允许访问,否则(Q以后)禁止访问 |
黑名单 | 我们认为没有应用在使用的非SDK接口 | 禁止访问,抛出运行时错误 |
6.ART性能优化
- 云端配置JIT热路径(仅支持google play)
从 Android Nougat 开始,ART 便引入了热代码profile优化机制,通过识别并预编译频繁执行的代码,达到缩短应用启动时间的目的。为了进一步加快应用的启动速度,Google Play 现在除了 APK 文件之外,还会交付一套基于云的配置文件。它是一套已经过匿名化处理的汇总 ATR 配置文件,允许 ART 在应用开始运行之前就预编译一部分代码,这有助于显著提升优化进程的整体效率。基于云的编译文件适用于所有应用,而且运行 Android P 或更高版本系统的设备目前已提供相关支持。 - 分代垃圾回收(Generational Garbage Collection)
在 ART 的并发复制垃圾收集器 (Concurrent Copying Garbage Collector) 中加入了分代收集机制 (Generational Garbage Collection)。分代算法可以将新生代的对象单独收集出来,这样效率更高,而且与 full-heap GC 相比成本更小,释放空间也十分可观。总体而言,引入分代算法后,ART 垃圾回收速度和 CPU 利用效率有了明显提升,在减少垃圾的同时,帮助应用在低端设备上流畅运行。
7.Jetpack 更新
Jetpack官方文档:https://developer.android.google.cn/jetpack
主要更新:使用函数生成UI。
正常开发界面是xml布局+code,二者耦合。使用jetpack可以用代码生成UI,无需xml。
具体参看谷歌文档,需要使用Kotlin进行代码生成UI。
8.折叠屏设备适配
折叠屏官方文档:https://developer.android.google.cn/preview/features/foldables
折叠屏适配比较细化,主要是折叠、展开时,在onConfigurationChanged()做界面调整,支持拖拽等,请需要适配的APP模块自行参阅谷歌文档吧。
9.网络连接API
- APP不能自行开关wifi
- 设备管理APP才能调用网络配置API
- Telephony、WiFi、蓝牙的扫描API,必须获取FINE LOCATION权限
10.全屏手势导航
类似于我们现在的全屏手势,建议今后采用原生实现逻辑;建议应用不要覆盖系统手势,否则可能导致手势冲突。
11.深色主题
- 入口:设置—显示—主题背景;下拉快捷键
- 针对OLED屏幕的话,深色主题可以省电。
12.通用系统映像介绍
GSI通用系统映像是未经修改的 Android 开源项目 (AOSP) 代码编译出的“纯 Android”,是一个system.img,适用8.x后支持treble的机型。
GSI的意义:节约时间,提前适配。在没有pixel手机刷Q Beta的情况下,可以使用完全支持treble的机器刷Q GSI,体验Q的新特性。
刷GSI步骤:(适用pixel,其他具体咨询芯片商)
-
启动到 fastboot 模式,然后解锁bootloader。
-
通过刷写 vbmeta.img 停用验证启动 (AVB):
$ fastboot --disable-verification flash vbmeta vbmeta.img -
清空系统分区,然后将 GSI 刷写到系统分区:
$ fastboot erase system$ fastboot flash system system.img
-
擦除用户数据:$ fastboot -w
-
重新启动:$ fastboot reboot
官方文档:https://source.android.google.cn/setup/build/gsi
13.Google Play 商店政策
- DexClassLoder:
GP允许使用动态加载等代码更新,但是jar、so必须经过GP下发,不能使用自己的服务器下发jar,也就是jar要经过GP审核。 - 系统级permission:
GP政策中心上并没有包含针对OEM APK的说明,咨询了谷歌的人,他们说的也比较含糊,说是针对OEM厂商上架APK发过说明,针对OEM厂商APK的政策跟普通APK是不太一样的。 - 咨询GP政策的讲师,说放心用permission,有问题及时申诉就行。申诉周期比较快,2个工作日内会给答复。
14.其他更新点
- 19年下半年开始,Google Play 将要求所有新应用及更新将 targetSdkVersion 设置为 28 (Android 9 Pie)。除此以外,当用户首次运行 API 低级低于 23 (Android Marshmallow) 的应用时,会受到来自 Android Q 的警告信息。
- 所有应用必须满足 64 位要求
- 新增Bubble,Q正式版本在开发者选项中,未来浮动窗口可用Bubble替代
- AI SDK (ML KIT)增强
- 通知优化:自动生成文本回复,URL链接,其他deep links
- 系统分享框优化:提升速度、改良外观,增加描述信息和图标
- 隐私与安全
BiometricPrompt 是 Android 推出的统一验证框架,它能为生物识别提供层面的支持。
BiometricPrompt:https://developer.android.google.cn/reference/android/hardware/biometrics/package-summary
TLS 1.3 的支持。https://developer.android.google.cn/preview/features#tls-1.3
网友评论