谷歌强制升级TargetSdkVersion,开发者如何快速适配
导读
谷歌发布的Android P 版本对TargetSdkVersion参数提出了要求,华为终端开放实验室迅速对 TOP3000应用展开检测,测试结果不容乐观:超过300个应用出现了兼容性问题,不兼容率超过十分之一。
那么,在 P 版本适配过程中开发者该如何解决由TargetSdkVersion引入的兼容性问题?下面由华为专家带您解读谷歌 TargetSdkVersion<17 适配指导。
一 谷歌 TargetSdkVersion 特性背景
谷歌要求,在 P 版本中应用设置的TargetSdkVersion需要>=17,否则将弹出警告对话框来提示用户,并且谷歌有明确的CDD要求,该提示无法去除。
二 适配指导
修改应用的 TargetSdkVersion 值:
建议开发者将 TargetSdkVersion设置成17+,如果认为TargetSdkVersion设置过高,适配工作量太大,也可以将TargetSdkVersion设置成17进行适配,此设置适配工作量最小。
测试并解决由 TargetSdkVersion 引入的兼容性问题
开发者可参考谷歌提供的适配指导文档,并且需重点关注谷歌每个新版本中只对 TargetSdkVersion 生效的变化和修改:
P版本:
将应用迁移到 Android P 链接:
https://developer.android.com/preview/migration
Android P 功能和 API 链接:
https://developer.android.com/preview/features
Android P 行为变更 链接:
https://developer.android.com/preview/behavior-changes
重点关注:
对于非 SDK 接口的限制 链接:
https://developer.android.com/preview/restrictions-non-sdk-interfaces
刘海屏适配 链接:
https://developer.android.com/preview/features#cutout
O版本:
向 Android 8.0迁移应用 链接:
https://developer.android.com/about/versions/oreo/android-8.0-migration
Android 8.0 功能和 API 链接:
https://developer.android.com/about/versions/oreo/android-8.0
重点关注:
Android 8.0 行为变更 链接:
https://developer.android.com/about/versions/oreo/android-8.0-changes
最大屏幕纵横比:如果应用设置TargetSdkVersion>=26,那么在任何纵横比的屏幕都会默认全屏显示,开发者需注意不同比例屏幕的显示适配。
以 Android 7.1(API级别25)或更低版本为目标平台的应用默认的最大屏幕纵横比为 1.86。针对 Android 8.0或更高版本的应用没有默认的最大纵横比。如果您的应用需要设置最大纵横比,请使用定义您的操作组件清单文件中的maxAspectRatio 属性。
后台执行限制:广播和后台服务管控 链接:
https://developer.android.com/about/versions/oreo/background
其他:
N版本:
Android 7.0 行为变更 链接:
https://developer.android.com/about/versions/nougat/android-7.0-changes
重点关注的特性变化:
NDK 应用链接至平台库从 Android 7.0 开始,系统将阻止应用动态链接非公开 NDK 库,这种库可能会导致您的应用崩溃,下表描述的是根据应用使用的私有原生库及其目标 API 级别 (android:targetSdkVersion),应用预期显示的行为:
M版本:
Android 6.0 变更 链接:
https://developer.android.com/about/versions/marshmallow/android-6.0-changes
Android 6.0 API 链接:
https://developer.android.com/about/versions/marshmallow/android-6.0
Android 6.0 测试指南 链接:
https://developer.android.com/about/versions/marshmallow/android-6.0-testing
L版本:
Android 5.1 API 链接:
https://developer.android.com/about/versions/android-5.1
Android 5.0 API 链接:
https://developer.android.com/about/versions/android-5.0
Android 5.0 行为变更 链接:
https://developer.android.com/about/versions/android-5.0-changes
K版本:
Android 4.4 API 链接:
https://developer.android.com/about/versions/android-4.4
J版本:
Android 4.3 APIs 链接:
https://developer.android.com/about/versions/android-4.3
Android 4.2 APIs(API Level: 17) 链接:
https://developer.android.com/about/versions/android-4.2
Android 4.1 APIs(API Level: 16) 链接:
https://developer.android.com/about/versions/android-4.1
建议开发者多次对应用进行测试验证,避免引入新的兼容性问题
三 测试验证方法
方法一:购买谷歌 Pixel、Pixel XL、Pixel2、Pixel 2 XL,刷 P 版本进行测试版本下载
参考:
https://developer.android.google.cn/preview/download
*DP2版本,需要将网页底部的显示语言修改为英文,中文显示的仍为DP1版本
刷机
*刷机前需要退出之前登录的谷歌账号
1.下载对应设备的压缩包并解压;
2.手机连 USB 后,执行 adb reboot bootloader 命令;
3.手机出现小机器人图案,并显示‘unlock’字样时,执行压缩包中的 bat 脚本。
如果是“lock”字样:
1.连续点击设置-版本号7次,打开开发人员选项;
2.在开发人员选项中打开 OEM unlock;
3.连接手机到电脑,执行 adb reboot bootloader 命令到小机器人界面;
4.执行 fastboot oem unlock,手机就解锁了,再使用上面的刷机方法即可。
方法二:远程真机调试
1.新用户注册使用
新用户如需申请使用华为终端开放实验室的云测功能,需加入安卓绿色联盟,成为会员。可通过以下步骤申请:
使用所在公司尾缀的邮箱进行账号注册;
将您新申请的账号、所在公司、个人姓名及电话、负责的应用名称发送至deveco@huawei.com,申请成为安卓绿色联盟会员,通过审核后,将为您开通使用权限;
2.登录账号选择真机进行远程调试
3.选择手机:Pixel
4.点击“立即体验”,上传 APK 进行调试
方法三:使用谷歌模拟器验证
安装和配置 Android P SDK 和模拟器
参考:
https://developer.android.google.cn/preview/setup-sdk
P版本中谷歌加入了“非SDK接口使用限制”,此特性将对所有开发者产生影响。
点击填写《非 SDK 适配问卷》,我们期待得到您的反馈!