@ohos.app.ability.InsightIntentEntryExecutor (@InsightIntentEntry的意图执行基类)
本模块提供@InsightIntentEntry装饰器的意图执行基类,必须与@InsightIntentEntry装饰器联合使用。
开发者需要在继承该基类的子类中,实现onExecute()意图执行回调,并使用@InsightIntentEntry装饰器来装饰子类。
说明:
本模块首批接口从API version 20开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。
本模块接口仅可在Stage模型下使用。
导入模块
import { InsightIntentEntryExecutor } from '@kit.AbilityKit';
InsightIntentEntryExecutor<T>
属性
系统能力:SystemCapability.Ability.AbilityRuntime.Core
原子化服务API:从API version 20开始,该接口支持在原子化服务中使用。
| 名称 | 类型 | 只读 | 可选 | 说明 |
|---|---|---|---|---|
| executeMode | insightIntent.ExecuteMode | 否 | 否 | 表示意图执行模式。即拉起绑定的Ability组件时支持的执行模式。 |
| context | InsightIntentContext | 否 | 否 | 表示意图执行上下文。 |
| windowStage | window.WindowStage | 否 | 是 | 表示windowStage实例对象,和onWindowStageCreate接口的windowStage实例是同一个,可用于加载意图执行的页面。仅当executeMode字段取值为UI_ABILITY_FOREGROUND(即意图执行需要将UIAbility显示在前台时),该属性生效。 |
| uiExtensionSession | UIExtensionContentSession | 否 | 是 | 表示UIExtensionContentSession实例对象,和onSessionCreate接口的UIExtensionContentSession实例是同一个,可用于加载意图执行的页面。仅当executeMode字段取值为UI_EXTENSION_ABILITY(即意图执行需要拉起UIExtensionAbility时),该属性生效。 |
onExecute
onExecute(): Promise<insightIntent.IntentResult<T>>
当AI入口触发意图执行时,系统将会拉起该类绑定的Ability组件,并触发该回调,开发者可以在该回调中实现需要执行的意图操作。使用Promise异步回调。
该接口的调用时机与意图执行模式的对应关系如下:
| 意图执行模式 | 接口调用时机和顺序 |
|---|---|
| UI_ABILITY_FOREGROUND UIAbility前台模式 |
- 若UIAbility冷启动,意图执行时UIAbility生命周期触发顺序:onCreate、onWindowStageCreate、onExecute、onForeground。 - 若UIAbility热启动,且启动时UIAbility处于后台,意图执行时UIAbility生命周期触发顺序:onNewWant、onExecute、onForeground。 - 若UIAbility热启动,且启动时UIAbility处于前台,意图执行时UIAbility生命周期触发顺序:onExecute。 |
| UI_ABILITY_BACKGROUND UIAbility后台模式 |
- 若UIAbility冷启动,意图执行时UIAbility生命周期触发顺序:onCreate、onExecute、onBackground。 - 若UIAbility热启动,意图执行时UIAbility生命周期触发顺序:onExecute。 |
| UI_EXTENSION_ABILITY UIExtension模式 |
意图执行时UIExtensionAbility生命周期触发顺序:onCreate、onSessionCreate、onExecute、onForeground。 |
| SERVICE_EXTENSION_ABILITY ServiceExtension模式 |
意图执行时ServiceExtensionAbility生命周期触发顺序:onCreate、onRequest、onExecute。 |
系统能力:SystemCapability.Ability.AbilityRuntime.AbilityCore
原子化服务API:从API version 20开始,该接口支持在原子化服务中使用。
返回值:
| 类型 | 说明 |
|---|---|
| Promise<insightIntent.IntentResult<T>> | Promise对象。返回insightIntent.IntentResult<T>对象,表示意图执行结果。 |
示例
import { insightIntent, InsightIntentEntry, InsightIntentEntryExecutor } from '@kit.AbilityKit';
import { hilog } from '@kit.PerformanceAnalysisKit';
const LOG_TAG: string = 'testTag-EntryIntent';
// 使用@InsightIntentEntry装饰器定义意图
@InsightIntentEntry({
intentName: 'PlayMusic',
domain: 'MusicDomain',
intentVersion: '1.0.1',
displayName: '播放歌曲',
displayDescription: '播放音乐意图',
icon: $r('app.media.app_icon'), // $r表示本地图标,需要在资源目录中定义
llmDescription: '支持传递歌曲名称,播放音乐',
keywords: ['音乐播放', '播放歌曲', 'PlayMusic'],
abilityName: 'EntryAbility',
executeMode: [insightIntent.ExecuteMode.UI_ABILITY_FOREGROUND],
parameters: {
'schema': 'http://json-schema.org/draft-07/schema#',
'type': 'object',
'title': 'Song Schema',
'description': 'A schema for describing songs and their artists',
'properties': {
'songName': {
'type': 'string',
'description': 'The name of the song',
'minLength': 1
}
},
'required': ['songName']
}
})
export default class PlayMusicDemo extends InsightIntentEntryExecutor<string> {
songName: string = '';
onExecute(): Promise<insightIntent.IntentResult<string>> {
hilog.info(0x0000, LOG_TAG, 'PlayMusicDemo executeMode %{public}s', JSON.stringify(this.executeMode));
hilog.info(0x0000, LOG_TAG, '%{public}s', JSON.stringify(this));
let storage = new LocalStorage();
storage.setOrCreate('songName', this.songName);
// 根据executeMode参数的不同情况,提供不同拉起PlayMusicPage页面的方式。
if (this.executeMode == insightIntent.ExecuteMode.UI_ABILITY_FOREGROUND) {
this.windowStage?.loadContent('pages/PlayMusicPage', storage);
} else if (this.executeMode == insightIntent.ExecuteMode.UI_EXTENSION_ABILITY) {
this.uiExtensionSession?.loadContent('pages/PlayMusicPage', storage);
}
// 定义意图的执行结果
let result: insightIntent.IntentResult<string> = {
code: 123,
result: 'result'
}
hilog.info(0x0000, LOG_TAG, 'PlayMusicDemo return %{public}s', JSON.stringify(result));
// 以Promise的方式返回意图执行结果
return Promise.reject(result);
}
}