作者: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了吗?的更多相关文章

  1. HDC2021技术分论坛:如何高效完成HarmonyOS分布式应用测试?

    作者:liuxun,HarmonyOS测试架构师 HarmonyOS是新一代的智能终端操作系统,给开发者提供了设备发现.设备连接.跨设备调用等丰富的分布式API.随着越来越多的开发者投入到Harmon ...

  2. HDC2021技术分论坛:异构组网如何解决共享资源冲突?

    作者:lijie,HarmonyOS软总线领域专家 相信大家对HarmonyOS的"超级终端"比较熟悉了.那么,您知道超级终端场景下的多种设备在不同环境下是如何组成一个网络的吗?这 ...

  3. HDC2021技术分论坛:进程崩溃/应用卡死,故障频频怎么办?

    ​作者:jiwenqiang,DFX技术专家 提到开发一个产品,我们通常首先想到的是要实现什么样的功能,但是除了功能之外,非功能属性也会很大程度上影响一个产品的体验效果,比如不定时出现的应用卡死.崩溃 ...

  4. HDC2021技术分论坛:“积木拼装”,HarmonyOS弹性部署大揭秘!

    作者:peitaiyi,华为终端OS产品交付专家 HarmonyOS是一款面向万物互联时代的.全新的分布式操作系统.在传统的单设备系统能力基础上,HarmonyOS提出了基于同一套系统能力.适配多种终 ...

  5. HDC技术分论坛:HarmonyOS新一代UI框架的全面解读

    作者:yuzhiqiang,UI编程框架首席技术专家 在Harmony 3.0.0开发者预览版中,包含了新一代的声明式UI框架ArkUI 3.0.多语言跨平台编译器ArkCompiler 3.0.跨端 ...

  6. 使用隧道技术进行C&C通信

    一.C&C通信 这里的C&C服务器指的是Command & Control Server--命令和控制服务器,说白了就是被控主机的遥控端.一般C&C节点分为两种,C&a ...

  7. OpenHarmony3.1 Release版本特性解析——硬件资源池化架构介绍

    李刚 OpenHarmony 分布式硬件管理 SIG 成员 华为技术有限公司分布式硬件专家 OpenHarmony 作为面向全场景.全连接.全智能时代的分布式操作系统,通过将各类不同终端设备的能力进行 ...

  8. 对象池化技术 org.apache.commons.pool

    恰当地使用对象池化技术,可以有效地减少对象生成和初始化时的消耗,提高系统的运行效率.Jakarta Commons Pool组件提供了一整套用于实现对象池化的框架,以及若干种各具特色的对象池实现,可以 ...

  9. vue组件通信全面总结

    写在前面 组件间的通信是是实际开发中非常常用的一环,如何使用对项目整体设计.开发.规范都有很实际的的作用,我在项目开发中对此深有体会,总结下vue组件间通信的几种方式,讨论下各自的使用场景 文章对相关 ...

随机推荐

  1. JavaFx WebView使用研究

    原文: JavaFx WebView使用研究 | Stars-One的杂货小窝 本篇是基于TornadoFx框架的基础研究的,示例代码都是Kotlin版本,各位可以看着参考下 WebView中比较重要 ...

  2. 安全防御之防xss、SQL注入、与CSRF攻击

    XSS攻击 个人理解,项目中最普通的就是通过输入框表单,提交js代码,进行攻击例如在输入框中提交 <script>alert("我是xss攻击");</scrip ...

  3. 如何高效地把Spring boot学到能干活的程度

    Spring boot要学什么?要学到什么程度?以及相关的学习方法是什么?这些很难量化,但极好形容:需要学到能帮你找到一份工作的程度.   任何脱离工作脱离实际的学习,都是没有意义的.比如程序员运行通 ...

  4. CF812A Sagheer and Crossroads 题解

    Content 有一个十字路口,从最下面的部分开始,逆时针依次标号为 \(1,2,3,4\).每个部分有四个灯,分别为左转的灯.直行的灯.右转的灯以及人行通道灯(只有可能为红灯和绿灯).如果某个部分的 ...

  5. java 图形化工具Swing 基本使用

    Swing介绍: 使用Swing开发图形界面比AWT更加优秀,因为Swing是一种轻量级组件,它采用100% Java实现,不再依赖于本地平台的图形界面,所以可以在所有平台上保持相同的运行效果,对跨平 ...

  6. 大型网站高可用架构之CAP原理

    在讨论高可用数据服务架构之前,必须先讨论的一个话题是,为了保证数据的高可用,网站通常会牺牲另一个也很重要的指标:数据一致性. CAP原理认为,一个提供数据服务的存储系统无法同时满足数据一致性.数据可用 ...

  7. TempCache 临时内存缓存器

    TempCache.h /* *************************************************** * Copyright(c) Xiamen AutoNavi Co ...

  8. 【LeetCode】 204. Count Primes 解题报告(Python & C++)

    作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 素数筛法 参考资料 日期 [LeetCode] 题目 ...

  9. 【九度OJ】题目1190:大整数排序 解题报告

    [九度OJ]题目1190:大整数排序 解题报告 标签(空格分隔): 九度OJ 原题地址:http://ac.jobdu.com/problem.php?pid=1190 题目描述: 对N个长度最长可达 ...

  10. codeforce 597C-Subsequences(dp+树状数组)

    题目和南阳那道题一样链接http://www.cnblogs.com/zzuli2sjy/p/4943774.html 代码: 1 #include<stdio.h> 2 #include ...