组件通信、硬件池化,这些创新技术你 get 了吗?|HDC2021 技术分论坛
作者: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 接口发出连接请求。示例代码如下:
(2)协同响应端响应协同发起端 channel 的协同事件。示例代码如下:
(3)通过 Agent 接口收发消息。不论是协同发起端,还是协同响应端,都可以通过该接口,设置消息接收器和发送消息到对端。示例代码如下:
(4)通过 Agent 接口感知对端生命周期。协同响应端的生命周期是绑定到协同发起端的,当协同发起端退出后,协同响应端也会跟着退出。示例代码如下:
2.多机位相机案例
如下视频所示,通过多机位模式呈现了周围环境内不同机位的视角。如何实现这个分布式场景中访问周边设备 Camera 硬件的功能呢?
我们使用了硬件资源池化技术,首先,我们通过 getCapabilities 接口获取硬件资源池内的外设 Camera 硬件列表,该列表中包含了外设 Camera ID,该 ID 可调用 OpenCamera 接口获取 Camera 帧信息。然后通过 distributeHardwareMgr 接口监听外设硬件的插拔事件。最后通过 enableCapability 接口使能该 Camera 硬件。下面是具体的实现步骤与示例代码。
(1)用户点击外设按钮时,查询可用分布式相机信息。示例代码如下:
(2)用户点击连接设备时,使能外设 Camera 硬件,此时本机出现外设机位摄像头的画面。示例代码如下:
以上就是本期全部内容,本文所介绍只是 HamronyOS 分布式创新技术的冰山一角,期待广大开发者积极加入我们,共同见证全场景智慧生态的无限可能。
评论