HarmonyOS NEXT 技术实践-基于意图框架服务实现智能分发

在智能设备的交互中,如何准确理解并及时响应用户需求,成为提升用户体验的关键。HarmonyOS Next 的意图框架服务(Intents Kit)为这一目标提供了强大的技术支持。本文将通过一个项目实现的示例,展示如何使用意图框架服务,实现意图共享与调用的功能,推动智慧分发的应用。

在这里插入图片描述


一、项目背景与目标

1. 意图框架介绍

Intents Kit(意图框架服务)是HarmonyOS级的意图标准体系 ,意图连接了应用/元服务内的业务功能。意图框架能帮开发者将应用/元服务内的业务功能,智能分发到各系统入口,这个过程即智慧分发。其中系统入口包括:小艺对话、小艺搜索、小艺建议等。

系统入口、意图框架、鸿蒙生态的关系如下:

在这里插入图片描述
利用HarmonyOS的大模型、多维设备感知等AI能力,准确且及时地获取到用户显性、潜在意图,从而实现个性化、多模态、精准的智慧分发。

HarmonyOS、应用/元服务的交互中,意图运行方式分为意图调用和意图共享:

在这里插入图片描述

方式发起者定义
意图共享应用/元服务指应用/元服务主动向HarmonyOS共享意图,可用于HarmonyOS构建本地内容索引、学习用户的行为规律,以支持本地搜索和主动建议。意图共享包含动作和实体两个部分。动作支持完成时和将来时两种机制: - 完成时:用户意图已执行,共享的数据可用于本地搜索和系统建议。- 将来时:意图是基于用户行为预测的,共享的数据可用于本地搜索。 意图框架还支持开发者向系统进行辅助实体共享,例如位置信息等,用于场景推荐和其他智慧分发功能的增强。
意图调用HarmonyOS指HarmonyOS主动调用应用/元服务的功能。 用户在系统入口输入信息或者系统主动推荐后,系统可向应用/元服务发起意图调用,例如播放音乐、查看旅游攻略、搜索视频等。

2. 项目目标

本项目的目标是展示如何在HarmonyOS中利用意图框架服务实现智能分发,准确匹配用户需求。通过@kit.IntentsKit进行意图共享,使用@kit.AbilityKitInsightIntentExecutor实现意图调用,用户的需求将能够被智能解析并传递到相关服务或应用中。

具体来说,本示例包括两个主要部分:

  1. 意图共享:通过意图共享机制,将用户的需求从一个模块传递到其他模块,实现跨应用的需求匹配。
  2. 意图调用:在共享意图之后,通过意图调用机制,将数据回传至调用端,并根据需求执行相应操作。

本示例仅支持标准系统上运行,支持设备:华为手机、华为平板。

  • HarmonyOS系统:HarmonyOS NEXT Developer
  • Beta1及以上。 DevEco Studio版本:DevEco Studio NEXT Developer Beta1及以上。
  • HarmonyOS SDK版本:HarmonyOS NEXT Developer Beta1 SDK及以上。

二、项目实现

1. 项目目录结构

本项目的目录结构如下所示:

entry/src/main/
| --- ets
|     | --- entryability
|     |     | --- EntryAbility.ets                                  // 共享界面Ability
|     |     | --- InsightIntentExecutorImpl.ets                     // 意图调用逻辑
|     | --- pages
|     |     | --- Index.ets                                         // 共享界面UI
|     | --- utils
|     |     | --- ...                                               // 工具类

主要功能分布如下:

  • EntryAbility.ets:负责展示意图共享界面。
  • InsightIntentExecutorImpl.ets:处理意图调用的逻辑。
  • Index.ets:显示共享界面的UI,包含获取和展示示范数据的功能。

2. 意图共享实现

意图共享是实现智能分发的基础。我们通过@kit.IntentsKit来共享数据,确保用户需求能够跨应用或模块传递。

  • 获取示范数据:用户点击获取insightIntent示例数据后,示范数据将展示在共享界面上方的输入框内。
@kit.IntentsKit.getInsightIntents().then((data) => {// 处理获取到的示范数据updateUI(data);
});
  • 共享数据:用户点击“分享意图”按钮后,数据将通过@kit.IntentsKit.shareIntent()共享,结果将展示在共享界面的下方结果栏内。
@kit.IntentsKit.shareIntent(intentData).then((result) => {// 显示共享结果updateResult(result);
});

3. 意图调用实现

意图调用功能允许在共享的意图处理后,返回调用端并执行相应操作。通过使用小艺建议的模板卡片,我们可以展示共享的意图,并通过点击卡片触发相应的跳转和操作。

  • 小艺建议展示模板卡片:我们使用音乐类模板卡片来展示共享意图。在点击卡片后,触发与共享界面跳转并执行意图调用逻辑。
@kit.AbilityKit.InsightIntentExecutor.execute(intent).then((result) => {// 处理执行结果,并展示在共享界面下方updateResult(result);
});
  • SID管理:项目中还实现了SID的获取和刷新功能,确保每次操作都能获取最新的会话标识。
@kit.AbilityKit.getSid().then((sid) => {updateSid(sid);
});@kit.AbilityKit.getSidRenew().then((newSid) => {updateSid(newSid);
});

4. 实现结果

  1. 意图共享界面展示:用户可以查看共享意图的数据,并通过“获取示范数据”和“分享意图”按钮进行交互,数据将在共享界面的输入框和结果栏中显示。

  2. 意图调用逻辑展示:点击小艺建议模板卡片后,意图将被调用并返回结果,展示在共享界面的结果栏中。用户可以通过点击“获取SID”或“刷新SID”来管理会话状态。


三、核心代码解析

接下来,我们详细解析**InsightIntentExecutorImpl.ets**中的核心代码,重点展示如何通过InsightIntentExecutor类实现意图的执行与分发。

1. 引入模块和定义常量

首先,引入所需的模块:

import { Logger } from '../utils/Logger';
import { insightIntent, InsightIntentExecutor } from '@kit.AbilityKit';
import { window } from '@kit.ArkUI';
import type { BusinessError } from '@kit.BasicServicesKit';
  • Logger:用于记录执行日志,帮助开发者调试和跟踪意图执行过程。
  • insightIntent, InsightIntentExecutorInsightIntentExecutor是基类,提供了意图执行的接口方法。insightIntent包含了定义意图及其执行结果的类型。
  • windowwindow.WindowStage用于管理UI窗口,允许我们在界面中展示意图的执行结果。
  • BusinessError:用于描述在意图执行过程中可能遇到的业务错误。

接着,我们定义常量:

private static readonly PLAY_MUSIC = 'PlayMusic';
private static readonly PLAY_MUSIC_LIST = 'PlayMusicList';

这两个常量分别代表两个不同的意图:播放单曲(PlayMusic)和播放音乐列表(PlayMusicList)。这些常量将用于后续的意图分发和执行。

2. 重写核心方法

下面,重写onExecuteInUIAbilityForegroundMode方法:

onExecuteInUIAbilityForegroundMode(name: string, param: Record<string, Object>, pageLoader: window.WindowStage):Promise<insightIntent.ExecuteResult> {Logger.info(TAG, `onExecuteInUIAbilityForegroundMode name: ${name}, param: ${JSON.stringify(param)}`);switch (name) {case InsightIntentExecutorImpl.PLAY_MUSIC:return this.playMusic(param, pageLoader);case InsightIntentExecutorImpl.PLAY_MUSIC_LIST:return this.playMusicList(param, pageLoader);default:break;}return Promise.resolve({code: -1,result: {message: 'unknown intent'}} as insightIntent.ExecuteResult)
}
  • onExecuteInUIAbilityForegroundMode:这是InsightIntentExecutor中的核心方法,负责根据意图名称(name)执行对应的操作,并返回执行结果。此方法首先记录日志,展示接收到的意图名称和参数。然后,根据意图名称分发处理逻辑。

  • 播放音乐:如果接收到的意图是PlayMusic,则调用playMusic方法,执行播放音乐的逻辑。

  • 播放音乐列表:如果接收到的意图是PlayMusicList,则调用playMusicList方法,执行播放音乐列表的逻辑。

  • 未知意图:如果接收到的意图未知,返回一个错误信息。

3. 播放音乐方法实现

playMusic方法实现

private playMusic(param: Record<string, Object>, pageLoader: window.WindowStage): Promise<insightIntent.ExecuteResult> {// 处理播放音乐的逻辑Logger.info(TAG, `Playing music with parameters: ${JSON.stringify(param)}`);// 假设这是一个简单的模拟逻辑,实际中可能调用外部音乐播放APIreturn Promise.resolve({code: 0,result: {message: 'Music is playing successfully!'}});
}
  • playMusic:此方法模拟播放音乐的操作。在实际应用中,您可以根据传入的参数(如歌曲名称、歌手等)调用外部API来实现播放。这里,我们简单地记录日志并返回成功的结果。

playMusicList方法实现:

private playMusicList(param: Record<string, Object>, pageLoader: window.WindowStage): Promise<insightIntent.ExecuteResult> {// 处理播放音乐列表的逻辑Logger.info(TAG, `Playing music list with parameters: ${JSON.stringify(param)}`);return Promise.resolve({code: 0,result: {message: 'Music list is playing successfully!'}});
}
  • playMusicList:与playMusic类似,但它是用于处理音乐列表播放的逻辑。在实际应用中,您可以将多个歌曲信息传递给该方法并调用相应的播放服务。

4. 错误处理

return Promise.resolve({code: -1,result: {message: 'unknown intent'}
} as insightIntent.ExecuteResult);

如果接收到一个未知的意图,该方法将返回一个错误信息,表示无法识别该意图。


四、效果预览

1. 意图共享

共享界面展示:

在这里插入图片描述
按获取insightIntents获取insightIntent示例数据,获取的示范数据将显示在共享界面上方输入框内。

在这里插入图片描述

按shareIntent进行数据共享,并在共享界面下方的结果栏内获取意图共享结果。

在这里插入图片描述

2. 意图调用

待共享的意图完成处理后,将会在小艺建议的卡片内展示共享的意图,点击展示的对应卡片,执行意图调用逻辑。

使用小艺建议模板卡片实现意图调用

小艺建议展示模板卡片,此项目内使用音乐类模板卡片。

在这里插入图片描述

点击模板卡片,按照意图注册配置内逻辑,执行对应跳转。此项目内跳转至共享界面,并在共享界面下方结果栏内展示意图调用回传参数

在这里插入图片描述

3. SID获取

点击getSid获取SID,并在结果栏内展示(优先获取缓存)。

在这里插入图片描述

点击getSidRenew强制获取新的SID,并在结果栏内展示。

在这里插入图片描述


五、总结

通过本项目,我们展示了如何利用HarmonyOS的意图框架服务(Intents Kit)实现智能分发功能,精准理解并响应用户需求。通过意图共享和调用机制,用户的需求得以在不同应用和模块之间流转,进而提供更加个性化、智能化的服务。这种基于AI和系统感知的智慧分发,极大提升了用户交互体验,并为开发者提供了更加灵活和高效的应用开发方式。

通过本示例,开发者可以学习到如何在实际项目中使用意图框架服务,并将其应用于自己的HarmonyOS应用中,打造更加智能、个性化的用户体验。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/64829.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

观察者模式(sigslot in C++)

大家&#xff0c;我是东风&#xff0c;今天抽点时间整理一下我很久前关注的一个不错的库&#xff0c;可以支持我们在使用标准C的时候使用信号槽机制进行观察者模式设计&#xff0c;sigslot 官网&#xff1a; http://sigslot.sourceforge.net/ 本文较为详尽探讨了一种观察者模…

workman服务端开发模式-应用开发-gateway长链接端工作原理

一、长链接的工作原理 Register类其实也是基于基础的Worker开发的。Gateway进程和BusinessWorker进程启动后分别向Register进程注册自己的通讯地址&#xff0c;Gateway进程和BusinessWorker通过Register进程得到通讯地址后&#xff0c;就可以建立起连接并通讯了。而Gateway进程…

Ubuntu vi(vim)编辑器配置一键补全main函数

1.打开对应的配置文件 vi ~/.vim/snippets/c.snippets 2.按G将光标定位到文件末尾 3.按i进入插入模式 以tab键开头插入下的内容&#xff0c;空行也要加 tab键 4.:wq保存退出 5.再打开任意一个新的 .c文件后&#xff0c;插入模式输入 main 然后按tal键就能补全了

Windows脚本清理C盘缓存

方法一&#xff1a;使用power文件.ps1的文件 脚本功能 清理临时文件夹&#xff1a; 当前用户的临时文件夹&#xff08;%Temp%&#xff09;。系统临时文件夹&#xff08;C:\Windows\Temp&#xff09;。 清理 Windows 更新缓存&#xff1a; 删除 Windows 更新下载缓存&#xff0…

THM:Skynet[WriteUP]

目录 连接至THM服务器并启动靶机 信息收集 使用rustscan对靶机TCP端口进行开放扫描 使用nmap对靶机TCP开放端口进行脚本、服务扫描 使用nmap对靶机TCP开放端口进行漏洞、系统扫描 使用nmap对靶机常用UDP端口进行开放扫描 使用nmap对137端口进行针对性扫描 使用enum4lin…

Redis篇--常见问题篇7--缓存一致性2(分布式事务框架Seata)

1、概述 在传统的单体应用中&#xff0c;事务管理相对简单&#xff0c;通常使用数据库的本地事务&#xff08;如MySQL的BEGIN和COMMIT&#xff09;来保证数据的一致性。然而&#xff0c;在微服务架构中&#xff0c;由于每个服务都有自己的数据库&#xff0c;跨服务的事务管理变…

基于winform的五子棋机器人系统开发 (更新中ing)

一、实物硬件表拟定 笔记本电脑、正运动控制器、三个汇川伺服驱动器、三个滑动模组 二、软件开发 注意细节&#xff1a; ①主界面使用三个panel容器进行构建 pannel容器设置属性参数&#xff1a;(1) dock ② 添加自定义控件&#xff1a;首先创建类库&#xff0c;删除默认…

微服务分布式(二、注册中心Consul)

首先我们需要安装consul,到官网下载Consul Install | Consul | HashiCorp Developer 在解压的consul目录下 执行启动命令 consul agent -dev 启动服务 -dev表示开发模式 -server表示服务模式 启动后在浏览器访问8500端口http://localhost:8500/可以看到服务管理界面 项目…

示波器--UNI-T 优利德 UT4102C 使用介绍

示波器--UNI-T 优利德 UT4102C 使用介绍 1 介绍图示特点 2 UTP04示波器探头&#xff08;100M带宽&#xff09;3 功能介绍4 示例RS232 电平信号测试 参考 1 介绍 图示 特点 2GS/s的实时采样率&#xff1a;设备能够以每秒2吉萨&#xff08;Giga Samples per second&#xff09;…

基础库正则表达式

我们已经可以用requests 库来获取网页的源代码&#xff0c;得到 HTML 代码。但我们真正想要的数据是包含在 HTML代码之中的&#xff0c;要怎样才能从 HTML,代码中获取想要的信息呢?正则表达式就是其中一个有效的方法。 本篇博客我们将了解一下正则表达式的相关用法。正则表达…

PID 控制算法理论背景:飞控领域的核心调控机制(1)

在飞控工程领域&#xff0c;PID 控制算法占据着极为关键的地位&#xff0c;是实现飞行器精确稳定控制的基石。PID 作为比例&#xff08;P&#xff09;、积分&#xff08;I&#xff09;、微分&#xff08;D&#xff09;的集成代表&#xff0c;构建起了控制系统的核心架构&#x…

复合翼与倾转旋翼飞行器:设计与控制算法对比

一、引言 复合翼&#xff08;Compound Wing&#xff09;和倾转旋翼&#xff08;Tilt - Rotor&#xff09;飞行器在现代航空领域均占据独特地位&#xff0c;二者在设计和控制算法方面展现出显著差异。这些差异在飞行模式切换、推进系统设计、控制算法复杂度以及飞行器稳定性等多…

Vue2五、自定义指令,全局局部注册、指令的值 ,插槽--默认插槽,具名插槽 ( 作用域插槽)

一、自定义指令 使用步骤 1. 注册 (全局注册 或 局部注册) &#xff0c;在 inserted 钩子函数中&#xff0c;配置指令dom逻辑 2. 标签上 v-指令名 使用 1、自定义指令&#xff08;全局&#xff09; Vue.directive("指令名"&#xff0c;{ 指令的配置项 insert…

一次BC站点渗透实录

初探 打开首页 简单信息收集: IP地址&#xff1a;美国加利福尼亚洛杉矶 无CDN 中间件:Nginx 80端口直接突破&#xff0c;故未进行端口扫描 渗透思路 一般这种BC站点&#xff0c;有几种思路可以切入&#xff1a; 1&#xff09;通过SQL注入查到管理员账号密码&#xff0c;扫描…

java 集合对象

Java 基础之集合_java集合继承关系图-CSDN博客 集合可以有序或无序&#xff0c;重复或不能重复&#xff0c;空或不能空。 List<> 集合&#xff0c;是有序&#xff0c;允许重复元素&#xff0c;允许空元素 1、ArrayList<> 非线程安全 2、LInkedList<> 非线…

web实操8-cookie

会话技术 会话&#xff1a; 一次会话中包含多次请求和响应。 客户端浏览器访问服务器的资源&#xff0c;只要客户端或者服务器端不关闭&#xff0c;这始终在一次会话范围内&#xff0c;这一次会话范围内可以包含多次请求并且收到多次相应。 一次会话&#xff1a;浏览器第一…

VMWare 的克隆操作

零、碎碎念 VMWare 的这个克隆操作很简单&#xff0c;单拎出来成贴的目的是方便后续使用。 一、操作步骤 1.1、在“源”服务器上点右键&#xff0c;选择“管理--克隆” 1.2、选择“虚拟机的当前状态”为基础制作克隆&#xff0c;如下图所示&#xff0c;然后点击“下一页” 1.3、…

JVM性能优化一:初识内存泄露-内存溢出-垃圾回收

本文主要是让你充分的认识到什么叫做内存泄露&#xff0c;什么叫做内存溢出&#xff0c;别再傻傻分不清了&#xff0c;别再动不动的升级服务器的内存了。 文章目录 1.基本概念1.1.内存泄露1.2.内存溢出1.3.垃圾回收1.4.内存泄露-垃圾回收-内存溢出三者的关系关系 2.代码示例2.…

dockfile镜像加速

运行给的终端命令 全覆盖法 {"registry-mirrors": ["https://registry.docker-cn.com","http://hub-mirror.c.163.com","https://dockerhub.azk8s.cn","https://mirror.ccs.tencentyun.com","https://registry.cn-han…

数据结构经典算法总复习(下卷)

第五章:树和二叉树 先序遍历二叉树的非递归算法。 void PreOrderTraverse(BiTree T, void (*Visit)(TElemType)) {//表示用于查找的函数的指针Stack S; BiTree p T;InitStack(S);//S模拟工作栈while (p || !StackEmpty(S)) {//S为空且下一个结点为空&#xff0c;意味着结束遍…