shortcuts.xml
中的 capability 可让您声明用户启动应用时可以执行的操作类型,并直接执行特定任务。
例如,Google 助理的与应用有关的 Action 通过使用 capability 使开发者可将应用内功能扩展到内置 intent (BII),从而让用户能够使用语音指令激活和控制这些功能。能力包含操作的名称和 intent
(用于定位到解析用户 intent 的应用中的目的地)。
在 shortcuts.xml 中定义能力
您可以在 Android 应用开发项目的 shortcuts.xml
资源文件中定义 capability
元素。如需定义 capability
元素,请执行以下操作:
- 按照创建静态快捷方式中的说明创建
shortcuts.xml
资源。 请在功能中提供以下必要信息:
功能名称:您希望应用支持的操作。如需了解需要能力定义的功能,请参阅组件文档。支持与应用有关的 Action 语音的指令会使用 BII
Action ID
作为 capability 名称(您可以在 BII 参考文档中找到这些名称)。例如,GET_THING
BII 会将其Action ID
列为actions.intent.GET_THING
。应用目的地:应用中的目的地,操作启动该目的地来执行用户请求。使用嵌套在
capability
中的intent
元素定义应用目的地。参数映射:每个
intent
可能包含要作为 intent 的extra
数据传递的参数。例如,每个与应用有关的 Action BII 都包括表示用户通常在触发 BII 的查询中提供的信息的字段。
以下示例演示了 shortcuts.xml
中 actions.intent.START_EXERCISE
的能力定义,该 BII 使用户能够通过 Google 助理使用语音指令在健身应用中开始锻炼:
<shortcuts xmlns:android="http://schemas.android.com/apk/res/android">
<capability android:name="actions.intent.START_EXERCISE">
<intent
android:action="android.intent.action.VIEW"
android:targetPackage="com.example.sampleApp"
android:targetClass="com.example.sampleApp.ExerciseActivity">
<parameter
android:name="exercise.name"
android:key="exerciseType"/>
</intent>
</capability>
</shortcuts>
在上例中,<capability>
android:name
属性引用了 START_EXERCISE
BII。如果用户通过向 Google 助理发出指令“Ok Google,启动 ExampleApp,开始跑步”来调用此 BII,Google 助理会使用嵌套 intent
元素中提供的信息执行用户请求。此示例中的 intent
定义了以下详细信息:
android:targetPackage
为此 intent 设置目标应用软件包。android:targetClass
字段指定目的地 activity:com.example.sampleApp.ExerciseActivity
。- intent
parameter
声明对 BII 参数exercise.name
的支持,以及如何将从用户处收集的参数值作为intent
中的 extra 数据进行传递。
将快捷方式与能力相关联
定义某项 capability 后,您可以通过将静态快捷方式或动态快捷方式与该 capability 相关联来扩展其功能。快捷方式如何关联到 capability
取决于要实现的功能以及用户请求中包含的实际字词。例如,当用户向 Google 助理发出指令“Hey Google,在 ExampleApp 中开始跑步”,开始在您的健身跟踪应用中跟踪跑步情况时,Google 助理可以使用快捷方式启动一个 capability
实例,该实例为 exercise.name
参数定义有效的“run”运动实体。
如需详细了解如何将快捷方式与与应用有关的 Action 相关联,请参阅与应用有关的 Action 概览。