谷歌发布的 Android P 版本对 TargetSdkVersion 参数提出了要求,华为终端开放实验室迅速对 TOP3000 应用展开检测,测试结果不容乐观:超过300个应用出现了兼容性问题,不兼容率超过十分之一。
那么,在 P 版本适配过程中开发者该如何解决由 TargetSdkVersion 引入的兼容性问题?下面由华为专家带您解读谷歌 TargetSdkVersion
一谷歌 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.新用户注册使用
新用户如需申请使用华为终端开放实验室的云测功能,需加入安卓绿色联盟,成为会员。可通过以下步骤申请:
2.登录账号选择真机进行远程调试
3.选择手机:Pixel
4.点击“立即体验”,上传 APK 进行调试
方法三:使用谷歌模拟器验证
安装和配置 Android P SDK 和模拟器
参考:
https://developer.android.google.cn/preview/setup-sdk
P版本中谷歌加入了“非SDK接口使用限制”,此特性将对所有开发者产生影响。
领取专属 10元无门槛券
私享最新 技术干货