将自动填充功能与 IME 和自动填充服务集成

从 Android 11 开始,键盘及其他输入法 (IME) 可以在建议栏或类似的容器中以内嵌方式显示自动填充建议,而不是系统在菜单中显示这些建议。由于这些自动填充建议可能包含隐私数据(如密码或信用卡信息),因此在用户选择某条建议之前,这些建议对 IME 隐藏。请更新 IME 和自动填充服务(例如密码管理器),以便使用此功能。如果 IME 或自动填充服务不支持内嵌自动填充功能,建议会显示在菜单中,就像在 Android 11 之前的版本中一样。

工作流程

在此流程中,IME 表示当前的键盘或其他输入法,建议提供程序表示自动填充建议的相应提供程序。根据输入字段和用户设置,建议提供程序可能是平台或自动填充服务。

  1. 用户将焦点置于一个会触发自动填充功能的输入字段上,如密码或信用卡输入字段。

  2. 平台查询当前的 IME 和相应的建议提供程序,查看它们是否支持内嵌自动填充功能。如果 IME 或建议提供程序不支持内嵌自动填充功能,建议会显示在菜单中,就像在 Android 10 及更低版本中一样。

  3. 平台要求 IME 提供建议请求。此建议请求指定了要显示的建议数量上限,并且还提供了每条建议的呈现规范。呈现规范指定了最大大小、文字大小、颜色和字体数据等等,从而让建议提供程序能够匹配 IME 的外观和风格。

  4. 平台要求建议提供程序提供建议,不超过请求的数量。每条建议都包含一个回调,以扩充包含建议界面的 View

  5. 平台通知 IME 建议已准备就绪。IME 调用回调方法以扩充每条建议的 View,从而显示建议。为了保护用户的隐私信息,IME 在这一阶段看不到建议是什么。

  6. 如果用户选择了其中一条建议,系统会通知 IME,通知方法与用户从系统菜单中选择建议时一样。

以下部分介绍了如何配置 IME 或自动填充服务以支持内嵌自动填充功能。

配置 IME 以支持内嵌自动填充功能

本部分介绍了如何配置 IME 以支持内嵌自动填充功能。如果 IME 不支持内嵌自动填充功能,平台会默认在菜单中显示自动填充建议。

IME 必须supportsInlinedSuggestions 属性设为 true

<input-method
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:supportsInlineSuggestions="true"/>

当平台需要自动填充建议时,它会调用 IME 的 InputMethodService.onCreateInlineSuggestionsRequest() 方法。您必须实现此方法。返回 InlineSuggestionsRequest,该对象指定了以下内容:

  • IME 需要多少条建议。
  • 每条建议的 InlinePresentationSpec,用于定义必须如何呈现建议。

平台有了建议后,它会调用 IME 的 onInlineSuggestionsResponse() 方法,并传递包含建议的 InlineSuggestionsResponse。您必须实现此方法。在实现中,调用 InlineSuggestionsResponse.getInlineSuggestions() 以获取建议的列表,然后通过调用 InlineSuggestion.inflate() 方法来扩充每条建议。

配置自动填充服务以支持内嵌自动填充功能

本部分介绍了如何配置自动填充服务以支持内嵌自动填充功能。如果您的应用不支持内嵌自动填充功能,平台会默认在菜单中显示自动填充建议。

自动填充服务必须supportsInlinedSuggestions 属性设为 true

<autofill-service
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:supportsInlineSuggestions="true"/>

当 IME 需要自动填充建议时,平台会调用您的自动填充服务的 onFillRequest() 方法,就像在 Android 11 以下版本中一样。不过,您的服务必须调用传递的 FillRequest 对象的 getInlineSuggestionsRequest() 方法,以获取 IME 创建的 InlineSuggestionsRequestInlineSuggestionsRequest 指定了需要多少个内嵌建议,以及每条建议必须如何呈现。如果 IME 不支持内嵌建议,该方法会返回 null

您的自动填充服务会创建 InlinePresentation 对象,不超过 InlineSuggestionsRequest 中请求的最大数量。呈现方式必须遵循由 InlineSuggestionsRequest 指定的大小约束条件。为了将建议返回给 IME,请针对每条建议调用一次 Dataset.Builder.setValue()。Android 11 提供了 Dataset.Builder.setValue() 版本来支持内嵌建议。