Android 6.0 (M) 为用户和应用开发者提供了新功能。本文档介绍了其中最值得关注的 API。
开始开发
要着手开发 Android 6.0 应用,您必须先获取 Android SDK。然后使用 SDK 管理器下载 Android 6.0 SDK Platform 和系统映像。
更新目标 API 级别
如需进一步优化您的应用在搭载 Android 的设备上的性能,请将您的 targetSdkVersion
设置为 "23"
,在 Android 系统映像上安装您的应用并进行测试,然后发布更新了此变更的应用。
您可以通过在代码中添加条件,在执行您的 minSdkVersion
不支持的 API 之前检查系统 API 级别,实现在使用 Android API 的同时仍为旧版本提供支持。如需详细了解如何保持向后兼容性,请参阅支持不同的平台版本。
如需详细了解 API 级别的运作方式,请参阅什么是 API 级别?
指纹身份验证
此版本提供了一些新的 API,在受支持的设备上,用户只需扫描其指纹即可完成身份验证,这些 API 还可与 Android 密钥库系统结合使用。
如需通过指纹扫描验证用户身份,请获取新 FingerprintManager
类的实例,并调用 authenticate()
方法。您的应用必须运行在带有指纹传感器的兼容设备上。您必须在应用中实现指纹身份验证流程的界面,并在界面中使用标准 Android 指纹图标。生物识别身份验证示例中包含有 Android 指纹图标 (c_fp_40px.png
)。
请注意,如果您要开发多个使用指纹身份验证的应用,每个应用必须独立验证用户的指纹。
如需在您的应用中使用此功能,请先在清单中添加 USE_FINGERPRINT
权限。
<uses-permission android:name="android.permission.USE_FINGERPRINT" />
如需查看指纹身份验证的应用实现,请参阅生物识别身份验证示例。 如需查看有关将这些身份验证 API 与其他 Android API 结合使用方法的演示,请观看视频 Fingerprint API 和 Payment API。
如果您要测试此功能,请执行以下步骤:
- 如果您尚未安装 Android SDK 工具 24.3 修订版,请执行此操作。
- 依次前往 Settings > Security > Fingerprint,然后按照注册说明在模拟器中注册新指纹。
- 使用模拟器通过以下命令模拟指纹触摸事件。使用同一命令模拟锁屏上或应用中的指纹触摸事件。
adb -e emu finger touch <finger_id>
在 Windows 上,您可能需要先运行
telnet 127.0.0.1 <emulator-id>
,然后再运行finger touch <finger_id>
。
确认凭据
您的应用可以根据用户在多久之前最后一次解锁设备来验证其身份。此功能让用户不必记住其他应用专用密码,也无需您实现自己的身份验证界面。您的应用应当利用此功能并结合实现公钥或私钥,以进行用户身份验证。
如需设置用户成功验证身份后可重复使用同一密钥的超时时长,请在设置 KeyGenerator
或 KeyPairGenerator
时调用新的 setUserAuthenticationValidityDurationSeconds()
方法。
避免过多显示重新验证对话框 - 您的应用应尝试先使用加密对象,如果超时到期,请使用 createConfirmDeviceCredentialIntent()
方法在您的应用内重新验证用户身份。
应用关联
此版本通过提供功能更强大的应用链接,增强了 Android 的 intent 系统。 您可以利用此功能将应用与您拥有的某个 Web 域关联。平台可以根据此关联确定在处理特定 Web 链接时默认使用的应用,跳过提示用户选择应用的步骤。如需了解如何实现此功能,请参阅处理应用链接。
自动备份应用
现在,系统可以自动为应用执行完整数据备份和恢复。您的应用必须以 Android 6.0(API 级别 23)为目标平台才能启用此行为;您无需添加任何其他代码。如果用户删除其 Google 账号,其备份数据也会随之删除。如需了解该功能的运作方式以及如何配置文件系统备份内容,请参阅配置应用自动备份。
直接共享
此版本为您提供的 API 可让用户直观、快捷地进行共享。您现在可以定义可在应用中启动特定 activity 的“直接共享目标”。这些直接共享目标通过“共享”菜单向用户显示。借助此功能,用户可以与其他应用内的目标(如联系人)分享内容。例如,直接共享目标可以启动另一社交网络应用中的某个 activity,让用户可以直接向该应用中的某位朋友或某个社区共享内容。
如需启用直接共享目标,您必须定义一个类,用于扩展 ChooserTargetService
类。在清单中声明您的服务。在该声明内,指定 BIND_CHOOSER_TARGET_SERVICE
权限和一个使用 SERVICE_INTERFACE
操作的 intent 过滤器。
以下示例展示了如何在清单中声明 ChooserTargetService
。
<service android:name=".ChooserTargetService" android:label="@string/service_name" android:permission="android.permission.BIND_CHOOSER_TARGET_SERVICE"> <intent-filter> <action android:name="android.service.chooser.ChooserTargetService" /> </intent-filter> </service>
对于您想要向 ChooserTargetService
公开的每个 activity,请在应用清单中为其添加一个名为 "android.service.chooser.chooser_target_service"
的 <meta-data>
元素。
<activity android:name=".MyShareActivity” android:label="@string/share_activity_label"> <intent-filter> <action android:name="android.intent.action.SEND" /> </intent-filter> <meta-data android:name="android.service.chooser.chooser_target_service" android:value=".ChooserTargetService" /> </activity>
语音交互
此版本提供了一个新的语音交互 API,与语音操作一起使用时,可让您为应用打造对话式语音体验。调用 isVoiceInteraction()
方法可确定是否是响应语音操作触发了您的 activity。如果是这样,则您的应用可以使用 VoiceInteractor
类请求用户进行语音确认、从选项列表中进行选择以及执行其他操作。
大多数语音互动都源于用户语音操作。不过,语音互动 activity 也可以在没有用户输入的情况下启动。例如,通过语音交互启动的另一应用也可发送 intent 来启动语音交互。如需确定您的 activity 是由用户语音查询还是另一语音交互应用启动,请调用 isVoiceInteractionRoot()
方法。如果另一应用启动了您的 activity,该方法会返回 false
。您的应用可能随即提示用户确认其有意执行此操作。
如需详细了解如何实现语音操作,请参阅语音操作开发者网站。
Assist API
此版本为用户提供了一种通过助理与您的应用互动的新方式。如需使用此功能,用户必须启用助手以使用当前上下文。启用助手后,用户可通过长按主屏幕按钮在任何应用内召唤助手。
您的应用可以通过设置 FLAG_SECURE
标志来选择不与智能助理分享当前上下文。除了平台传递给助手的一组标准信息外,您的应用还可利用新增的 AssistContent
类共享其他信息。
要为助手提供您的应用内的其他上下文,请执行以下步骤:
- 实现
Application.OnProvideAssistDataListener
接口。 - 使用
registerOnProvideAssistDataListener()
注册此监听器。 - 如需提供特定于 activity 的上下文信息,请替换
onProvideAssistData()
回调和新的onProvideAssistContent()
回调(可选)。
可采用的存储设备
使用此版本时,用户可以采用 SD 卡等外部存储设备。采用外部存储设备可加密和格式化设备,使其具有类似内部存储设备的行为。用户可以利用此特性在存储设备之间移动应用及其私有数据。移动应用时,系统会遵守清单中的 android:installLocation
首选项。
请注意,在内部存储设备与外部存储设备之间移动应用时,如果您的应用访问以下 API 或字段,它们返回的文件路径将会动态变化。强烈建议:在生成文件路径时,请始终动态调用这些 API。请勿使用硬编码文件路径或之前生成的永久性完全限定文件路径。
Context
方法:ApplicationInfo
字段:
如需调试此功能,您可以运行以下命令,启用通过 USB On-The-Go (OTG) 数据线连接到 Android 设备的 U 盘:
$ adb shell sm set-force-adoptable true
通知
此版本针对通知功能引入了下列 API 变更:
- 新增了
INTERRUPTION_FILTER_ALARMS
过滤级别,它对应于新增的仅闹钟免打扰模式。 - 新增了
CATEGORY_REMINDER
类别值,用于区分用户安排的提醒与其他事件 (CATEGORY_EVENT
) 和闹铃 (CATEGORY_ALARM
)。 - 新增了
Icon
类,您可以通过setSmallIcon()
和setLargeIcon()
方法将其附加到通知上。同理,addAction()
方法现在接受Icon
对象,而不接受可绘制资源 ID。 - 新增了
getActiveNotifications()
方法,让您的应用能够了解哪些通知目前处于活动状态。
蓝牙触控笔支持
此版本改善了对用户使用蓝牙触控笔进行输入的支持。用户可将兼容的蓝牙触控笔与其手机或平板电脑配对并建立连接。连接后,来自触摸屏的位置信息将与来自触控笔的压力和按键信息融合,从而实现比单纯使用触摸屏更丰富的表达。您的应用可以通过在 activity 中注册 View.OnContextClickListener
和 GestureDetector.OnContextClickListener
对象,侦听触控笔按键动作并执行辅助操作。
使用 MotionEvent
方法和常量来检测触控笔按键交互:
- 如果用户使用带按钮的触控笔在应用屏幕上触摸触控笔,
getTooltype()
方法会返回TOOL_TYPE_STYLUS
。 - 对于以 Android 6.0(API 级别 23)为目标平台的应用,当用户按触控笔的主按键时,
getButtonState()
方法会返回BUTTON_STYLUS_PRIMARY
。如果触控笔有辅助按键,当用户按下它时,该方法会返回BUTTON_STYLUS_SECONDARY
。如果用户同时按下两个按钮,该方法会同时返回通过 OR 运算符连接起来的两个值 (BUTTON_STYLUS_PRIMARY
|BUTTON_STYLUS_SECONDARY
)。 -
对于以较低平台版本为目标平台的应用,
getButtonState()
方法会返回BUTTON_SECONDARY
(按下触控笔主按钮时)、BUTTON_TERTIARY
(按下触控笔辅助按钮时),或同时返回这两者。
改进的蓝牙低功耗扫描
如果您的应用执行蓝牙低功耗扫描,可以使用新增的 setCallbackType()
方法指定您只希望在下列条件下通知回调:首次找到与设置的 ScanFilter
匹配的播发数据包,或者已过很长时间后才再次看到该数据包。这种扫描方法与旧平台版本中提供的方法相比更加节能。
Hotspot 2.0 第 1 版支持
此版本在 Nexus 6 和 Nexus 9 设备上添加了对 Hotspot 2.0 第 1 版规范的支持。如需在您的应用中配置 Hotspot 2.0 凭据,请使用 WifiEnterpriseConfig
类的新方法,例如 setPlmn()
和 setRealm()
。在 WifiConfiguration
对象中,您可以设置 FQDN
和 providerFriendlyName
字段。新增的 isPasspointNetwork()
方法可指示检测到的网络是否为 Hotspot 2.0 接入点。
4K 显示模式
现在,平台允许应用在兼容硬件上请求将显示分辨率升级到 4K 渲染。如需查询当前物理分辨率,请使用新的 Display.Mode
API。请注意,如果界面是以较低逻辑分辨率绘制并通过放大达到更高的物理分辨率,则 getPhysicalWidth()
方法返回的物理分辨率可能不同于 getSize()
所报告的逻辑分辨率。
您可以通过设置应用窗口的 preferredDisplayModeId
属性请求系统更改应用运行时的物理分辨率。如果您想切换到 4K 显示分辨率,此功能会非常有用。在 4K 显示模式下,界面会继续以原始分辨率(如 1080p)渲染,并会调大到 4K,但 SurfaceView
对象可能会以原生分辨率显示内容。
主题化 ColorStateList
对于搭载 Android 6.0(API 级别 23)的设备,ColorStateList
现在支持主题属性。Resources.getColorStateList()
和 Resources.getColor()
方法已废弃。如果您要调用这些 API,请改为调用新的 Context.getColorStateList()
或 Context.getColor()
方法。还可在 v4 appcompat 库中通过 ContextCompat
使用这些方法。
音频功能
此版本增强了 Android 上的音频处理功能,包括:
- 通过新增的
android.media.midi
API 提供了对 MIDI 协议的支持。使用这些 API 可发送和接收 MIDI 事件。 - 新增了
AudioRecord.Builder
和AudioTrack.Builder
类,用于分别创建数字音频捕获和播放对象,并配置音频源和接收器属性以替换系统默认设置。 - 用于关联音频和输入设备的 API 钩子。如果您的应用允许用户通过与 Android TV 相连的游戏控制器或遥控器启动语音搜索,此功能尤为有用。系统会在用户启动搜索时调用新的
onSearchRequested()
回调。如需确定用户的输入设备是否带有内置麦克风,请从该回调中检索InputDevice
对象,然后调用新的hasMicrophone()
方法。 - 新增了
getDevices()
方法,让您可以检索系统当前连接的所有音频设备的列表。如果您想让系统在音频设备连接或断开时通知应用,还可以注册一个AudioDeviceCallback
对象。
视频功能
此版本为视频处理 API 添加了新功能,包括:
- 新增了
MediaSync
类,可帮助应用同步渲染音频流和视频流。音频缓冲区以非阻塞方式提交,并通过回调返回。此外,它还支持动态回放速率。 - 新增了
EVENT_SESSION_RECLAIMED
事件,它表示应用打开的会话已被资源管理器收回。如果您的应用使用 DRM 会话,则应处理此事件,并确保不使用收回的会话。 - 新增了
ERROR_RECLAIMED
错误代码,它表示资源管理器收回了编解码器使用的媒体资源。出现此异常时,必须释放编解码器,因为它已转入终止状态。 - 新增了
getMaxSupportedInstances()
接口,用于获取有关支持的编解码器实例最大并发数量的提示。 - 新增了
setPlaybackParams()
方法,用于设置快动作回放或慢动作回放的媒体回放速率。此外,它还会随视频一起自动拉长或加速音频回放。
相机功能
此版本包含以下新 API,用于访问相机的闪光灯和相机的图片再处理:
Flashlight API
如果相机设备带有闪光灯,您可以通过调用 setTorchMode()
方法,在不打开相机设备的情况下打开或关闭闪光灯的火炬模式。应用对闪光灯或相机设备不享有独占所有权。每当相机设备不可用,或者开启火炬的其他相机资源不可用时,火炬模式即会被关闭并变为不可用状态。其他应用也可以调用 setTorchMode()
来关闭手电筒模式。当最后一个开启手电筒模式的应用关闭时,手电筒模式就会被关闭。
您可以注册一个回调,通过调用 registerTorchCallback()
方法接收有关手电筒模式状态的通知。第一次注册回调时,系统会立即调用它,并返回所有当前已知配备闪光灯的相机设备的火炬模式状态。如果成功开启或关闭火炬模式,系统会调用 onTorchModeChanged()
方法。
Reprocessing API
Camera2
API 进行了扩展,以支持 YUV 和专用不透明格式图像再处理。如需确定这些再处理功能是否可用,请调用 getCameraCharacteristics()
并检查有无 REPROCESS_MAX_CAPTURE_STALL
键。如果设备支持再处理,您可以通过调用 createReprocessableCaptureSession()
创建可再处理的相机拍摄会话,并创建输入缓冲区再处理请求。
使用 ImageWriter
类可将输入缓冲区流与相机再处理输入相连。要获得空白缓冲区,请遵循以下编程模型:
- 调用
dequeueInputImage()
方法。 - 在输入缓冲区中填充数据。
- 通过调用
queueInputImage()
方法将缓冲区发送到相机。
如果您将 ImageWriter
对象与 PRIVATE
图片搭配使用,您的应用无法直接访问图片数据。请改为调用 queueInputImage()
方法,将 PRIVATE
图片直接传递给 ImageWriter
,而不进行任何缓冲区复制。
ImageReader
类现在支持 PRIVATE
格式图像流。借助此支持特性,您的应用可使 ImageReader
输出图像保持为循环图像队列,还可选择一个或多个图像并将其发送给 ImageWriter
进行相机再处理。
Android for Work 功能
此版本提供了下列用于 Android for Work 的新 API:
- 用于企业所有、单一用途设备的增强型控件:现在,设备所有者可以通过控制以下设置来改善企业所有、单一用途 (COSU) 设备的管理:
- 使用
setKeyguardDisabled()
方法停用或重新启用键盘锁。 - 您可以使用
setStatusBarDisabled()
方法停用或重新启用状态栏(包括快捷设置、通知以及启动 Google 即时的向上滑动导航手势)。 - 通过
UserManager
常量DISALLOW_SAFE_BOOT
停用或重新启用安全启动。 - 通过
STAY_ON_WHILE_PLUGGED_IN
常量防止屏幕在插入电源的情况下关闭。
- 使用
- 设备所有者静默安装和卸载应用:现在,设备所有者可使用
PackageInstaller
API 在不依赖 Google Play for Work 的情况下静默安装和卸载应用。现在,您可以通过设备所有者配置设备,从而无需用户干预即可获取并安装应用。此功能可用于在不激活 Google 账号的情况下实现信息亭或其他此类设备的一键式配置。 - 静默企业证书访问 :现在,当应用调用
choosePrivateKeyAlias()
时,配置文件所有者或设备所有者可以在系统提示用户选择证书前调用onChoosePrivateKeyAlias()
方法,静默式向发出请求的应用提供别名。借助此功能,您可以在无需用户干预的情况下授予托管应用访问证书的权限。 - 自动接受系统更新。现在,设备所有者可以通过
setSystemUpdatePolicy()
设置一个系统更新政策来自动接受系统更新(例如对于信息亭设备),或者推迟更新并在至多 30 天的时间内防止用户获取更新。此外,管理员还可设置每日必须获取更新的时间窗口,例如在信息亭设备无人使用的时段。有可用的系统更新时,系统会检查设备政策控制器应用是否设置了系统更新政策,并相应地执行操作。 -
委托证书安装:配置文件所有者或设备所有者现在可以授权第三方应用调用以下
DevicePolicyManager
证书管理 API: - 流量消耗情况跟踪。现在,配置文件所有者或设备所有者可以利用新增的
NetworkStatsManager
方法查询 Settings > Data 中显示的数据使用情况统计信息。配置文件所有者会被自动授予查询其管理的配置文件相关数据的权限,而设备所有者则被授予对其管理的主要用户使用情况数据的访问权。 - 运行时权限管理:
配置文件所有者或设备所有者可以利用
setPermissionPolicy()
设置适用于所有应用全部运行时请求的权限政策,以提示用户授予权限,或自动以静默方式授予或拒绝权限。如果设置后一种政策,则用户将无法修改配置文件所有者或设备所有者在应用权限屏幕的设置内所做的选择。 - “设置”中的 VPN:现在,设置 > 更多 > VPN 中会显示 VPN 应用。此外,现在,关于 VPN 使用情况的通知取决于该 VPN 的配置方式。对于配置文件所有者,通知取决于该 VPN 是针对托管配置文件、个人配置文件还是同时针对这两者进行配置。对于设备所有者,通知取决于是否为整个设备配置了 VPN。
- 工作状态通知:现在,每当来自受管个人资料的应用具有前台 activity 时,状态栏就会显示一个公文包图标。此外,如果设备直接解锁到托管配置文件中某个应用的 activity,则会显示一个 Toast,通知用户他们位于托管配置文件内。