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.rhkb.cn/news/494728.html

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

相关文章

sfnt-pingpong -测试网络性能和延迟的工具

sfnt-pingpong 是一个用于测试网络性能和延迟的工具&#xff0c;通常用于测量不同网络环境下的数据包传输性能、吞吐量、延迟等指标。 它通常是基于某种网络协议&#xff08;如 TCP&#xff09;执行“ping-pong”式的测试&#xff0c;即客户端和服务器之间相互发送数据包&…

前端下载文件的几种方式使用Blob下载文件

前端下载文件的几种方式 使用Blob下载文件 在前端下载文件是个很通用的需求&#xff0c;一般后端会提供下载的方式有两种&#xff1a; 1.直接返回文件的网络地址&#xff08;一般用在静态文件上&#xff0c;比如图片以及各种音视频资源等&#xff09; 2.返回文件流&#xff08;…

智能座舱进阶-应用框架层-Jetpack主要组件

Jetpack的分类 1. DataBinding&#xff1a;以声明方式将可观察数据绑定到界面元素&#xff0c;通常和ViewModel配合使用。 2. Lifecycle&#xff1a;用于管理Activity和Fragment的生命周期&#xff0c;可帮助开发者生成更易于维护的轻量级代码。 3. LiveData: 在底层数据库更…

知乎 PB 级别 TiDB 数据库集群管控实践

以下文章来源于知乎技术专栏 &#xff0c;作者代晓磊 导读 在现代企业中&#xff0c;数据库的运维管理至关重要&#xff0c;特别是面对分布式数据库的复杂性和大规模集群的挑战。作为一款兼容 MySQL 协议的分布式关系型数据库&#xff0c;TiDB 在高可用、高扩展性和强一致性方…

SpringBoot 自动装配原理及源码解析

目录 一、引言 二、什么是 Spring Boot 的自动装配 三、自动装配的核心注解解析 3.1 SpringBootApplication 注解 &#xff08;1&#xff09;SpringBootConfiguration&#xff1a; &#xff08;2&#xff09;EnableAutoConfiguration&#xff1a; &#xff08;3&#xf…

C++中的字符串实现

短字符串优化(SSO) 实现1 实现2 写时复制 #define _CRT_SECURE_NO_WARNINGS #include<iostream> #include<cstdio> #include<cstring> #include<cstring> using std::cout; using std::endl;// 引用计数存放的位置 // 1. 存放在栈上 --- 不行 // 2. 存…

Linux 基本使用和程序部署

1. Linux 环境搭建 1.1 环境搭建方式 主要有 4 种&#xff1a; 直接安装在物理机上。但是Linux桌面使用起来非常不友好&#xff0c;所以不建议。[不推荐]。使用虚拟机软件&#xff0c;将Linux搭建在虚拟机上。但是由于当前的虚拟机软件(如VMWare之类的)存在一些bug&#xff…

环网冗余CAN转光纤 CAN光端机在风电项目应用

在风力发电项目中&#xff0c;所有的风机内部的状态都需要能够在中控室备被监控到&#xff0c;不论是风机的工作状态还是风机内部的消防状态&#xff0c;以便中控室的工作人员都够根据观测到的信息及时的做出反应&#xff0c;避免造成重大损失。 通常风机的工作信息通过将网口…

ubuntu 如何重装你的apt【apt-get报错: symbol lookup error/undefined symbol】

副标题:解决error:apt-get: symbol lookup error: /lib/x86_64-linux-gnu/libapt-private.so.0.0: undefined symbol: _ZNK13pkgTagSection7FindULLENS_3KeyERKy, version APTPKG_6.0 文章目录 问题描述报错分析解决方案:重装你的apt1、查看你的ubuntu版本2、下载适配你的ap…

网络管理 详细讲解

讲一下之前获取CPU的&#xff0c;其余的原理和这个一样 python代码 app.route(/cpu/) def cpu_used():cpuoidObjectType(ObjectIdentity(myOIDs[cpu_loads]))ret getTableRows((cpuoid,))cpuload0for i in ret:cpuload i[0]print(cpuload)return {cpu:cpuload} var dom do…

用Python PySide6 复刻了两软件UI 做下练习

图样 1 代码 1&#xff1a; # -*- coding: utf-8 -*-import sys from PySide6.QtCore import (QCoreApplication, QMetaObject, QRect, QDate) from PySide6.QtGui import QIcon, QPixmap, QColor from PySide6.QtWidgets import (QApplication, QDialog, QLineEdit, QPushBut…

【day14】异常处理与Object类深入解析

【day13】回顾 在深入探讨异常处理与Object类之前&#xff0c;让我们回顾一下【day13】中的关键内容&#xff1a; 权限修饰符&#xff1a; public&#xff1a;最广的访问范围&#xff0c;任何地方都可以访问。protected&#xff1a;在同包和子类中可以访问。默认&#xff08;无…

题解 洛谷 Luogu P1135 奇怪的电梯 广度优先搜索 BFS C/C++

题目传送门&#xff1a; P1135 奇怪的电梯 - 洛谷 | 计算机科学教育新生态https://www.luogu.com.cn/problem/P1135思路&#xff1a; 一道比较裸的 BFS&#xff0c;就是把走迷宫每次搜周围相邻四格&#xff0c;改成了楼层每次搜上下方向的某层而已 感觉这个题难度只有普及- …

苏黎世联邦理工学院与加州大学伯克利分校推出MaxInfoRL:平衡内在与外在探索的全新强化学习框架

每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗&#xff1f;订阅我们的简报&#xff0c;深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同&#xff0c;从行业内部的深度分析和实用指南中受益。不要错过这个机会&#xff0c;成为AI领…

第146场双周赛:统计符合条件长度为3的子数组数目、统计异或值为给定值的路径数目、判断网格图能否被切割成块、唯一中间众数子序列 Ⅰ

Q1、统计符合条件长度为3的子数组数目 1、题目描述 给你一个整数数组 nums &#xff0c;请你返回长度为 3 的子数组&#xff0c;满足第一个数和第三个数的和恰好为第二个数的一半。 子数组 指的是一个数组中连续 非空 的元素序列。 2、解题思路 我们需要在给定的数组 nums…

【RAG实战】Prompting vs. RAG vs. Finetuning: 如何选择LLM应用选择最佳方案

在构建基于大型语言模型&#xff08;LLM&#xff09;的应用时&#xff0c;通常不可能立即使用模型而无需任何调整。为了保持高实用性&#xff0c;我们可以选择以下几种方法之一&#xff1a; Prompt Engineering&#xff08;提示工程&#xff09;Fine-tuning&#xff08;微调&a…

Odoo:免费开源ERP的AI技术赋能出海企业电子商务应用介绍

概述 伴随电子商务的持续演进&#xff0c;客户对于便利性、速度以及个性化服务的期许急剧攀升。企业务必要探寻创新之途径&#xff0c;以强化自身运营&#xff0c;并优化购物体验。达成此目标的最为行之有效的方式之一&#xff0c;便是将 AI 呼叫助手融入您的电子商务平台。我们…

如何打造用户友好的维护页面:6个创意提升WordPress网站体验

在网站运营中&#xff0c;无论是个人博主还是大型企业网站的管理员&#xff0c;难免会遇到需要维护的情况。无论是服务器迁移、插件更新&#xff0c;还是突发的技术故障&#xff0c;都可能导致网站短暂无法访问。这时&#xff0c;设计维护页面能很好的缓解用户的不满&#xff0…

定位方式:css

使用相对路径 div ul #div下的所有ul&#xff0c;空格表示相对路径&#xff08;这个实际中用的多一些&#xff09; 绝对路径-一般不用绝对路径 html>head>div&#xff0c;“>”表示根路径 使用class名称定位 使用.表示 使用id定位 使用#表示 使用属性定位 [属性名…

【YashanDB知识库】jdbc查询st_geometry类型的数据时抛出YAS-00101错误

本文内容来自YashanDB官网&#xff0c;原文内容请见 https://www.yashandb.com/newsinfo/7802956.html?templateId1718516 问题现象 某客户的业务在通过YashanDB jdbc驱动查询含有st_geometry列的数据时&#xff0c;报如下异常&#xff1a;YAS-00101 cannot allocate 0 byte…