HDC2021技术分论坛:组件通信、硬件池化,这些创新技术你get了吗?
作者:ligang 华为分布式硬件技术专家,sunbinxin 华为应用框架技术专家
HarmonyOS是一款全新的分布式操作系统,为开发者提供了元能力框架、事件通知、分布式硬件等分布式技术,使能开发出面向全场景的分布式应用。随着HarmonyOS应用生态的不断壮大,开发者使用原有的分布式技术在实现某些创新场景时显得力不从心,因为开发难度较大,直接影响了开发效率。
“创新推动发展”,我们需要对分布式技术不断探索与创新,才能让开发者更好地适应应用生态的发展。本期我们将通过两个多端协同的创新技术,结合创新案例为大家展示技术革新给开发者带来的高效开发体验。
一、技术创新
多端协同是分布式应用中最为常见的技术方案,通过同时或交替运行多端设备上的FA/PA实现完整的业务功能。下面我们将为大家介绍多端协同中跨设备通信与外部设备硬件资源访问两个技术创新。
1.跨设备通信
跨设备通信是多设备进行交互的基础。如图1所示,在以往的跨设备通信实现过程中,ServiceAbility作为消息中转的媒介,提供后台运行任务的能力以及统一的数据访问抽象,实现同应用不同设备的两个PageAbility的交互。开发者不仅要完成业务逻辑层设备的业务逻辑开发,还要完成通信层的包括跨设备连接管理、数据转发、生命周期绑定和感知等复杂功能的实现,开发起来费时费力。
图1 ServiceAbility实现方式
为了帮助开发者更加方便高效地实现跨设备通信,我们改变了原来的实现方式,提供了最新的startAssistAbility接口,直接拉起建立协同的对端设备的PageAbility。如图2所示,通过使用startAssistAbility接口,让通信层的跨设备连接管理、数据转发、生命周期绑定和感知由系统实现,开发者只需要关注上层业务逻辑,实现简单高效地开发。
图2 startAssistAbility实现方式
2.外设硬件访问
外设硬件访问是多设备进行协同的关键,如图1所示,在原来的外部设备硬件资源访问过程中,通过HarmonyOS提供的分布式设备虚拟化能力将两台设备的硬件资源进行融合,形成一个虚拟终端,实现了两台设备间硬件资源的访问。但是,随着全场景智慧生活的不断深入,一对一的设备硬件资源访问方式已不能满足现今某些场景的业务需求。
图3 一对一设备硬件资源访问
为了打破“一对一”的壁垒,我们提出了硬件资源池化技术。如图3所示,通过增强原来的分布式设备虚拟化能力,将多台设备的各种硬件资源,如屏幕、相机、扩音器、键盘、传感器及存储器等予以抽象并转换为“超级终端”内的统一资源池,并支持硬件资源的按需分配和重新组合,真正实现了超级终端全局硬件资源的调用。
图4 硬件资源池化
二、创新案例
以上两个分布式技术创新能为开发者带来什么不一样的开发体验呢?下面,我们将通过两个案例为你解答。
1.组件协同案例
如下图所示,手机和平板利用各自的优势协作完成同一个杂志设计任务的不同部分。如何高效地实现这个分布式场景中手机和平板的界面协同呢?
我们采用了最新的startAssistAbility接口。
- 首先,我们把两个设备的连接抽象为AssistChannel对象,通过监听该对象的事件实现连接成功/断开/失败;
- 然后,协同发起端通过startAssistAbility接口,指定对应的want和channel启动参数,发起连接;
- 最后,协同响应端响应channel的连接事件,连接成功后会回调一个Agent对象,该对象提供了收发消息及监听对端生命周期的接口,用于实现消息的接收与发送以及感知对端的生命周期变化。
下面是具体的实现步骤与示例代码。
(1)协同发起端调用startAssistAbility接口发出连接请求。示例代码如下:
const channel = new AssistChannel()
channel.on('assistConnect', (agent) => {
// 监听连接成功后回调
})
channel.on('assistDisconnect', (agent) => {
// 监听连接断开后回调
})
channel.on('assistFail', (agent) => {
// 监听连接失败后回调
})
// assistWant中指定了待启动的Ability的名称和设备的NetworkId
context.startAssistAbility(assistWant, channel)
(2)协同响应端响应协同发起端channel的协同事件。示例代码如下:
const channel = new AssistChannel()
channel.on('assistConnect', (agent) => {
// 监听连接成功后回调
})
channel.on('assistDisconnect', (agent) => {
// 监听连接断开后回调
})
channel.on('assistFail', (agent) => {
// 监听连接失败后回调
})
context.setAssistChannel(channel)
(3)通过Agent接口收发消息。不论是协同发起端,还是协同响应端,都可以通过该接口,设置消息接收器和发送消息到对端。示例代码如下:
// 注册消息接收器
agent.on(‘message’, (event)=>{
//处理接收到的事件
})
//可以发送InnerEvent给对端
agent.postMessage(event);
(4)通过Agent接口感知对端生命周期。协同响应端的生命周期是绑定到协同发起端的,当协同发起端退出后,协同响应端也会跟着退出。示例代码如下:
//注册生命周期监听,监听对端生命周期变化
agent.on(‘stateChange’, (event) => {
if (event === LifecycleEvent.ON_INACTIVE) {
// 处理消息
}
// TODO 其他生命周期处理
})
2.多机位相机案例
如下图所示,通过多机位模式呈现了周围环境内不同机位的视角。如何实现这个分布式场景中访问周边设备Camera硬件的功能呢?
我们使用了硬件资源池化技术。
- 首先,我们通过getCapabilities接口获取硬件资源池内的外设Camera硬件列表,该列表中包含了外设Camera ID,该ID可调用OpenCamera接口获取Camera帧信息;
- 然后,通过distributeHardwareMgr接口监听外设硬件的插拔事件;
- 最后,通过enableCapability接口使能该Camera硬件。
下面是具体的实现步骤与示例代码。
(1)用户点击外设按钮时,查询可用分布式相机信息。示例代码如下:
// 创建disHardwareMgr实例
var disHardwareMgr;
distributedHardware.createDHManager(app.getInfo().appID, (err, data) => {
if (err) {
console.info(TAG + "createDHManager err:" + JSON.stringify(err));
return;
}
disHardwareMgr = data;
});
let filter = {
deviceId: "",
deviceType: CAMERA
};
// 查询已有的可用外设信息
let array = disHardwareMgr.getDHCapabilities(filter);
console.info("getCapabilities result:" + JSON.stringify(array));
// 监听超级终端内可用外设的接入和移除事件
disHardwareMgr.registerListener((data) => {
console.info("registerHardwareListener on:" + JSON.stringify(data));
this.capEnable = data.cap;
});
(2)用户点击连接设备时,使能外设Camera硬件,此时本机出现外设机位摄像头的画面。示例代码如下:
// 找到指定外设后,使能外设的硬件驱动,将外部设备硬件添加为本地硬件使用
var cameraId;
let deviceId = this.capEnable.deviceId;
let dhId = this.capEnable.dhId;
let useType = 0;
disHardwareMgr.enable(deviceId, dhId, useType, (data) => {
cameraId = data;
});
// 从相机服务获取分布式相机,打开相机预览
CameraManager.openCamera(cameraId);
CameraManager.startPreview(cameraId);
以上就是本期全部内容。本文所介绍只是HamronyOS分布式创新技术的冰山一角,期待广大开发者积极加入我们,共同见证全场景智慧生态的无限可能。
扫码添加开发者小助手微信
获取更多HarmonyOS开发资源和开发者活动资讯
HDC2021技术分论坛:组件通信、硬件池化,这些创新技术你get了吗?的更多相关文章
- HDC2021技术分论坛:如何高效完成HarmonyOS分布式应用测试?
作者:liuxun,HarmonyOS测试架构师 HarmonyOS是新一代的智能终端操作系统,给开发者提供了设备发现.设备连接.跨设备调用等丰富的分布式API.随着越来越多的开发者投入到Harmon ...
- HDC2021技术分论坛:异构组网如何解决共享资源冲突?
作者:lijie,HarmonyOS软总线领域专家 相信大家对HarmonyOS的"超级终端"比较熟悉了.那么,您知道超级终端场景下的多种设备在不同环境下是如何组成一个网络的吗?这 ...
- HDC2021技术分论坛:进程崩溃/应用卡死,故障频频怎么办?
作者:jiwenqiang,DFX技术专家 提到开发一个产品,我们通常首先想到的是要实现什么样的功能,但是除了功能之外,非功能属性也会很大程度上影响一个产品的体验效果,比如不定时出现的应用卡死.崩溃 ...
- HDC2021技术分论坛:“积木拼装”,HarmonyOS弹性部署大揭秘!
作者:peitaiyi,华为终端OS产品交付专家 HarmonyOS是一款面向万物互联时代的.全新的分布式操作系统.在传统的单设备系统能力基础上,HarmonyOS提出了基于同一套系统能力.适配多种终 ...
- HDC技术分论坛:HarmonyOS新一代UI框架的全面解读
作者:yuzhiqiang,UI编程框架首席技术专家 在Harmony 3.0.0开发者预览版中,包含了新一代的声明式UI框架ArkUI 3.0.多语言跨平台编译器ArkCompiler 3.0.跨端 ...
- 使用隧道技术进行C&C通信
一.C&C通信 这里的C&C服务器指的是Command & Control Server--命令和控制服务器,说白了就是被控主机的遥控端.一般C&C节点分为两种,C&a ...
- OpenHarmony3.1 Release版本特性解析——硬件资源池化架构介绍
李刚 OpenHarmony 分布式硬件管理 SIG 成员 华为技术有限公司分布式硬件专家 OpenHarmony 作为面向全场景.全连接.全智能时代的分布式操作系统,通过将各类不同终端设备的能力进行 ...
- 对象池化技术 org.apache.commons.pool
恰当地使用对象池化技术,可以有效地减少对象生成和初始化时的消耗,提高系统的运行效率.Jakarta Commons Pool组件提供了一整套用于实现对象池化的框架,以及若干种各具特色的对象池实现,可以 ...
- vue组件通信全面总结
写在前面 组件间的通信是是实际开发中非常常用的一环,如何使用对项目整体设计.开发.规范都有很实际的的作用,我在项目开发中对此深有体会,总结下vue组件间通信的几种方式,讨论下各自的使用场景 文章对相关 ...
随机推荐
- 解决Tomcat10.0.12源码编译问题进而剖析其优秀分层设计架构
概述 Tomcat.Jetty.Undertow这几个都是非常有名实现Servlet规范的应用服务器,Tomcat本身也是业界上非常优秀的中间件,简单可将Tomcat看成是一个Http服务器+Serv ...
- java 输入输出IO流 字符流 FileWriter FileReader
为什么要使用字符流 当使用字节流读取文本文件时,可能会有一个小问题.就是遇到中文字符时,可能不会显示完整的字符,那是因为一个中文字符可能占用多个字节存储.所以Java提供一些字符流类,以字符为单位读写 ...
- 客户通过新型网络访问Web服务
- Centos使用kafka自带zookeeper安装kafka
首先要安装jdk环境 可以参考:https://www.cnblogs.com/pxblog/p/10512886.html 下载kafka 地址:http://kafka.apache.org/do ...
- BitBake使用攻略--BitBake的语法知识一
目录 写在前面 1. BitBake中的赋值 1.1 直接赋值 1.2 间接赋值 1.3 追加与前加赋值 1.4 Override风格的赋值语法 1.5 标志赋值 1.6 内联函数赋值 1.7 其他一 ...
- Win8/Win10 Ctrl+Alt+方向键 屏幕显示翻转解决办法
状况 Win10系统下,在Android Studio中使用快捷键 Ctrl + Alt + ↓ 复制代码段的时候神奇的情况出现了,屏幕显示倒转了,我也只能是一脸懵逼,Win7下没有这个问题.经验判断 ...
- 【九度OJ】题目1064:反序数 解题报告
[九度OJ]题目1064:反序数 解题报告 标签(空格分隔): 九度OJ 原题地址:http://ac.jobdu.com/problem.php?pid=1064 题目描述: 设N是一个四位数,它的 ...
- 【九度OJ】题目1018:统计同成绩学生人数 解题报告
[九度OJ]题目1018:统计同成绩学生人数 解题报告 标签(空格分隔): 九度OJ [LeetCode] http://ac.jobdu.com/problem.php?pid=1018 题目描述: ...
- [LeetCode] 448. Find All Numbers Disappeared in an Array 找到数组中消失的数字
题目描述 给定n个数字的数组,里面的值都是1-n,但是有的出现了两遍,因此有的没有出现,求没有出现值这个数组中的值有哪些. 要求不能用额外的空间(除了返回列表之外),时间复杂度n 思路 因为不能用额外 ...
- 修改gorm支持protobuf
gorm的功能很强大,支持很多很多特性,打算在项目中用上它. 但gorm不支持protobuf,如果idl用的是protobuf,需要对每个message做一个重新定义一个内部的struct,使得可以 ...