Android兼容性介绍

两种类型的兼容性:设备兼容性和应用兼容性。

设备的Android兼容性就是app能够正确运行的Android执行环境(Android execution environment)。Android执行环境的具体定义可参见 Android compatibility program,并且每个设备都必须通过CTS(Compatibility Test Suite)的兼容性认证。

设备的Android兼容性主要目的是:

  1. 为程序开发者提供统一的程序环境和硬件环境。
  2. 为用户提供统一的程序体验。

作为一个应用开发者,我们不需要关心设备的Android兼容性,只需要关心app是否和不同厂商的设备兼容。因为Android运行的设备配置非常广泛,有些功能不是所有的设备都拥有的。比如有些设备可能没有罗盘传感器,而你的app核心功能正好需要罗盘传感器,这就会造成app与不同设备的兼容性问题。

app兼容不同设备

Android支持多种功能。有些功能是基于硬件的(比如罗盘传感器)、有些是基于软件的(比如app widget),还有一些是基于系统版本的。不是所有的设备都能支持所有的功能的,因此,需要基于app请求的功能来控制app的兼容性。

为了能够达到一个app适配不同设备的目的,结合上述Android的功能情景,app兼容不同设备可以通过一下三个方面:

Device features(设备功能)

Android为每一个硬件功能和软件功能都定义了功能ID。举例来说,罗盘传感器的功能ID是FEATURE_SENSOR_COMPASS,app widget的功能ID是FEATURE_APP_WIDGETS

必要的话,可以在mainifest中声明<uses-feature> 元素,阻止没有某一功能的设备用户安装app。例如:

1 <manifest ... >
2     <uses-feature android:name="android.hardware.sensor.compass"
3                   android:required="true" />
4     ...
5 </manifest>

然而,如果app的主要功能并非是请求某个设备功能,可以设置属性required为“false”并且在运行时检查这个设备功能,代码如下:

1 PackageManager pm = getPackageManager();
2 if (!pm.hasSystemFeature(PackageManager.FEATURE_SENSOR_COMPASS)) {
3     // This device does not have a compass, turn off the compass feature
4     disableCompassFeature();
5 }

注意:有些system permissions会隐藏着要求一些设备功能。比如蓝牙权限BLUETOOTH就隐含着请求使用设备功能 FEATURE_BLUETOOTH。更多的隐藏请求功能见 Permissions that Imply Feature Requirements

Platform version(平台版本)

不同的设备可能运行在不同的系统版本上。每个连续版本通常都会增加一些API,这些新增的API在旧版本中是不能用的。可以在manifest中使用<uses-sdk>标签和它的minSdkVersion属性,来声明app最低兼容的版本。

使用旧版本的API进行编码能够确保app前向兼容(兼容旧版本之后的),因此在使用API时务必要查看文档确定其API LEVEL。

1 <manifest ... >
2     <uses-sdk android:minSdkVersion="14" android:targetSdkVersion="19" />
3     ...
4 </manifest>

Screen configuration

Android运行在各种尺寸的设备上,从手机到平板再到电视等等。为了分别屏幕类别,Android为每个设备都定义了两个特点:屏幕尺寸(屏幕的物理大小)和屏幕密度(在屏幕上像素物理密度,被成为DPI)。

  • 四种广义尺寸:small, normal, large和xlarge。
  • 几种广义密度:mdpi (medium), hdpi (hdpi), xhdpi (extra high), xxhdpi (extra-extra high)和其它。

默认情况下,app是兼容所有屏幕尺寸和密度的,因为必要的时候,系统会给每个屏幕适当的调整UI布局和图片资源。但还是需要为每种屏幕配置优化用户体验。为不同的屏幕大小增加特定的布局,为共同的屏幕密度优化位图图片。

关于如何为不同屏幕创建可选资源和如何限定app使用某个屏幕大小,参见 Supporting Different Screens

Android兼容性介绍,布布扣,bubuko.com

Android兼容性介绍

上一篇:【ASP.NET】判断访问网站的客户端是PC还是手机


下一篇:"ios模拟器未能安装此应用程序"解决办法