0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

輸入事件和設(shè)備狀態(tài)數(shù)據(jù)流介紹

OpenAtom OpenHarmony ? 來(lái)源:OpenAtom OpenHarmony ? 作者:OpenAtom OpenHarmony ? 2022-06-21 11:15 ? 次閱讀

一、 多模輸入概述

多模輸入服務(wù)旨在支撐開(kāi)發(fā)者面向用戶提供豐富多樣的人機(jī)交互方式,在持續(xù)完善支持傳統(tǒng)輸入的基礎(chǔ)上,多模輸入還會(huì)發(fā)揮 OpenAtom OpenHarmony(以下簡(jiǎn)稱“OpenHarmony”)的分布式優(yōu)勢(shì),提升跨設(shè)備交互體驗(yàn),面向新場(chǎng)景、新業(yè)務(wù)提供系統(tǒng)級(jí)支撐能力。 多模輸入 Input 部件是 OpenHarmony 系統(tǒng)級(jí)輸入事件管理框架;南向?qū)佣喾N輸入設(shè)備,匯聚多種輸入事件(按鍵、觸摸),通過(guò)歸一/標(biāo)準(zhǔn)化處理后,分發(fā)給消費(fèi)者(系統(tǒng)服務(wù)、應(yīng)用)。 南向輸入設(shè)備對(duì)接包括多種類型的輸入設(shè)備,如:觸屏、鼠標(biāo)、鍵盤(pán)、觸摸板、遙控器。

二、輸入事件和設(shè)備狀態(tài)數(shù)據(jù)流介紹

首先,我們看下多模輸入體系架構(gòu)下的關(guān)鍵數(shù)據(jù)流程,方便深入了解用戶從發(fā)起一次交互請(qǐng)求,到系統(tǒng)、應(yīng)用給予一次交互響應(yīng)的全流程。

如下圖所示,包括兩類關(guān)鍵數(shù)據(jù)流:

●輸入設(shè)備狀態(tài)數(shù)據(jù)流:

輸入設(shè)備狀態(tài)數(shù)據(jù)描述輸入設(shè)備的狀態(tài)變化及其設(shè)備屬性信息,包括:設(shè)備插入、移除狀態(tài)、設(shè)備唯一標(biāo)識(shí)、設(shè)備名稱、設(shè)備支持的輸入方式等。

輸入設(shè)備狀態(tài)數(shù)據(jù),經(jīng)過(guò)內(nèi)核設(shè)備驅(qū)動(dòng)上報(bào)給多模輸入服務(wù)端的輸入設(shè)備狀態(tài)管理模塊。在輸入設(shè)備管理模塊對(duì)全局輸入設(shè)備狀態(tài)進(jìn)行管理和維護(hù),同時(shí)設(shè)備狀態(tài)會(huì)封裝為可監(jiān)聽(tīng)接口提供給上層業(yè)務(wù)模塊用來(lái)監(jiān)聽(tīng)系統(tǒng)輸入外設(shè)的狀態(tài)。 ●交互輸入事件數(shù)據(jù)流: 交互輸入事件數(shù)據(jù)用來(lái)描述鍵盤(pán)、鼠標(biāo)、觸摸屏輸入事件;鍵盤(pán)事件包括:按鍵碼、按鍵時(shí)間戳、按鍵所屬設(shè)備等信息;鼠標(biāo)事件包括:鼠標(biāo) X/Y 坐標(biāo)、鼠標(biāo)按鈕(如:鼠標(biāo)左|中|右)事件等;觸摸事件包括:時(shí)間戳、觸摸位置 X/Y 坐標(biāo)等。 輸入事件數(shù)據(jù)由設(shè)備驅(qū)動(dòng)上報(bào)給輸入事件接收模塊完成輸入事件從內(nèi)核空間到用戶空間的轉(zhuǎn)發(fā),然后再給輸入事件預(yù)處理模塊完成輸入事件標(biāo)準(zhǔn)化處理(按鍵 KeyCode 映射標(biāo)準(zhǔn)化等),最后由輸入事件分發(fā)模塊以系統(tǒng)預(yù)設(shè)分發(fā)機(jī)制和原則完成事件的分發(fā)。 參考以下數(shù)據(jù)流圖,我們可以很清晰地了解到在用戶通過(guò)輸入設(shè)備發(fā)起一次交互請(qǐng)求后,輸入事件上報(bào)和分發(fā)全流程。

a2ad8d94-f09a-11ec-ba43-dac502259ad0.png

圖1 輸入事件和設(shè)備狀態(tài)數(shù)據(jù)流圖 注:數(shù)據(jù)流圖箭頭示意說(shuō)明 輸入事件分發(fā)模塊對(duì)于事件預(yù)處理說(shuō)明: 1)輸入事件分發(fā)過(guò)程會(huì)優(yōu)先經(jīng)過(guò)輸入事件攔截模塊,當(dāng)有攔截器注冊(cè)時(shí),輸入事件會(huì)終止繼續(xù)上報(bào),相應(yīng)的攔截器會(huì)攔截所有輸入事件。該事件攔截特性當(dāng)前主要支持無(wú)障礙模式。 2)當(dāng)沒(méi)有攔截器注冊(cè)時(shí),輸入事件會(huì)上報(bào)給輸入事件監(jiān)聽(tīng)模塊,系統(tǒng)級(jí)應(yīng)用(如:系統(tǒng)設(shè)置、桌面)通過(guò)監(jiān)聽(tīng)輸入事件,支持系統(tǒng)級(jí)特性(如:狀態(tài)欄隱藏/消失等)。 3)事件監(jiān)聽(tīng)模塊對(duì)事件的監(jiān)聽(tīng)不會(huì)阻斷事件繼續(xù)上報(bào);支持事件監(jiān)聽(tīng)的同時(shí),輸入事件還會(huì)繼續(xù)上報(bào)。 4)對(duì)于按鍵事件會(huì)上報(bào)給訂閱按鍵分發(fā)模塊處理,分發(fā)給對(duì)應(yīng)的應(yīng)用處理,事件分發(fā)流程結(jié)束; 5)其他觸摸屏事件和鼠標(biāo)事件不會(huì)經(jīng)過(guò)訂閱按鍵分發(fā)模塊,會(huì)繼續(xù)上報(bào)給應(yīng)用窗口處理。

三、多模輸入事件分發(fā)原則

1. 鼠標(biāo)/觸摸屏事件分發(fā)原則

鼠標(biāo)/觸摸屏坐標(biāo)指向哪個(gè)目標(biāo),輸入事件就分發(fā)給對(duì)應(yīng)的目標(biāo)。 鼠標(biāo)/觸摸屏事件分發(fā)特殊場(chǎng)景說(shuō)明: 1)如沒(méi)有鼠標(biāo)上的按鈕按下,當(dāng)前鼠標(biāo)指向哪個(gè)目標(biāo),鼠標(biāo)輸入事件就分發(fā)給坐標(biāo)鎖定的目標(biāo)。 2)如果有鼠標(biāo)上的按鈕按下,以第一個(gè)按鈕按下時(shí)刻鼠標(biāo)坐標(biāo)鎖定的目標(biāo)作為分發(fā)標(biāo)的,直到所有的按鈕都抬起。 3)觸摸屏輸入時(shí),將第一個(gè)手指按下鎖定的目標(biāo)作為輸入事件分發(fā)標(biāo)的,直到所有的手指都抬起。

2. 按鍵事件分發(fā)原則

按鍵事件分發(fā)以當(dāng)前用戶可視界面中的焦點(diǎn)作為分發(fā)標(biāo)的,當(dāng)前界面焦點(diǎn)在哪個(gè)目標(biāo)上,按鍵事件就分發(fā)給對(duì)應(yīng)的標(biāo)的。

四、OpenHarmony 3.1版本新增接口說(shuō)明

為了更好的支持上層應(yīng)用和系統(tǒng)服務(wù)實(shí)時(shí)檢測(cè)和處理輸入設(shè)備熱插拔狀態(tài)變更事件,在 OpenHarmony 3.1 版本新增開(kāi)放了 JS API 接口,可支持通過(guò) JS API 監(jiān)聽(tīng)設(shè)備的熱插拔事件。同時(shí)提供通過(guò)注冊(cè)回調(diào)接口的方式獲取熱插拔輸入設(shè)備唯一標(biāo)識(shí)。輸入設(shè)備熱插拔監(jiān)聽(tīng)接口與 inputDevice.getDevice 接口配合即可獲取熱插拔設(shè)備的詳細(xì)信息,包括:輸入設(shè)備名稱、設(shè)備支持的輸入類型(鍵盤(pán)|觸摸屏|鼠標(biāo)|游戲手柄)等。

1. 多模輸入子系統(tǒng)新增接口說(shuō)明

輸入外設(shè)熱插拔監(jiān)聽(tīng)接口: function on(type: "change", listener: Callback): void; 輸入外設(shè)取消監(jiān)聽(tīng)接口: function off(type: “change”, listener?: CallbackDeviceListener): void;

2. 新增接口接口參數(shù)說(shuō)明

【DeviceListener】

a2bdd974-f09a-11ec-ba43-dac502259ad0.png

【ChangeType】

a2d0cf66-f09a-11ec-ba43-dac502259ad0.png

3. 輸入設(shè)備熱插拔接口應(yīng)用場(chǎng)景

軟鍵盤(pán)自適應(yīng)顯示:在文本編輯場(chǎng)景下,輸入法通過(guò)監(jiān)聽(tīng)物理鍵盤(pán)輸入設(shè)備的熱插拔操作,可自適應(yīng)決策軟鍵盤(pán)是否顯示。當(dāng)有物理鍵盤(pán)設(shè)備時(shí),軟鍵盤(pán)無(wú)需顯示,用戶輸入操作通過(guò)物理鍵盤(pán)完成輸入。當(dāng)無(wú)物理鍵盤(pán)時(shí),輸入法彈出軟鍵盤(pán),用戶通過(guò)軟鍵盤(pán)完成輸入操作。

4. 輸入設(shè)備熱插拔接口使用范例

對(duì)于鼠標(biāo)熱插拔監(jiān)聽(tīng)接口有了初步的認(rèn)識(shí)后,讓我們來(lái)詳細(xì)了解下,在實(shí)際開(kāi)發(fā)中如何使用輸入設(shè)備熱插拔接口: 1)首先導(dǎo)入模塊 import inputDevice from '@ohos.multimodalInput.inputDevice'; 2)通過(guò)監(jiān)聽(tīng)接口實(shí)現(xiàn)輸入設(shè)備熱插拔事件監(jiān)聽(tīng):

// 輸入法在軟鍵盤(pán)顯示邏輯中通過(guò)訂閱物理鍵盤(pán)的狀態(tài):插入/拔出// 根據(jù)isPhysicalkeyboardExist的值決定軟鍵盤(pán)是否彈出...let isPhysicalkeyboardExist = false;inputDevice.on("change", (callback) => { console.log("type: " + callback.type + ", deviceId: " + callback.deviceId); inputDevice.getDevice(callback.deviceId, (ret) => { console.log("The keyboard type of the device is: " + ret); if (ret == keyboard.ALPHABETIC_KEYBOARD && callback.type == 'add') { // 熱插拔設(shè)備為鍵盤(pán) isPhysicalkeyboardExist = true; } else if (ret == keyboard.ALPHABETIC_KEYBOARD && callback.type == 'remove') { isPhysicalkeyboardExist = false; } });});...3)通過(guò)取消監(jiān)聽(tīng)接口實(shí)現(xiàn)輸入設(shè)備熱插拔事件取消監(jiān)聽(tīng):
listener: function(data) { console.log("type: " + data.type + ", deviceId: " + data.deviceId);}// 單獨(dú)取消listener的監(jiān)聽(tīng)。inputDevice.off("change", this.listener);// 取消所有監(jiān)聽(tīng)inputDevice.off("change");//取消監(jiān)聽(tīng)后,軟鍵盤(pán)默認(rèn)都彈出

注:取消熱插拔事件監(jiān)聽(tīng)接口中,入?yún)istener可選;當(dāng)入?yún)istener代表取消特定監(jiān)聽(tīng)回調(diào)。當(dāng)入?yún)⒉粠istener,代表取消所有監(jiān)聽(tīng)回調(diào)。

通過(guò)上述介紹,相信大家對(duì) OpenHarmony 多模輸入子系統(tǒng)的輸入事件處理和分發(fā)機(jī)制有了一個(gè)全面的了解。同時(shí)我們也對(duì) OpenHarmony 3.1 版本新增的輸入設(shè)備熱插拔監(jiān)聽(tīng)接口做了詳細(xì)的介紹,更多有關(guān)多模輸入子系統(tǒng)為開(kāi)發(fā)者提供的 API 接口歡迎訪問(wèn) Gitee 詳細(xì)了解:

https://gitee.com/openharmony/docs/blob/master/zh-cn/application-dev/reference/apis/js-apis-inputdevice.md

相信大家在后續(xù)開(kāi)發(fā)中有了上面這些基礎(chǔ)知識(shí)作為鋪墊,在后續(xù)開(kāi)發(fā)中便可以更加游刃有余,開(kāi)發(fā)出交互體驗(yàn)更好的應(yīng)用來(lái)。期待與廣大開(kāi)發(fā)者一起共同構(gòu)建極致用戶體驗(yàn)。最后,期待諸位攜手一起共建,可在 OpenHarmony 社區(qū)(https://gitee.com/openharmony)一起交流探討。

審核編輯 :李倩

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 多模
    +關(guān)注

    關(guān)注

    1

    文章

    28

    瀏覽量

    10837
  • OpenHarmony
    +關(guān)注

    關(guān)注

    25

    文章

    3648

    瀏覽量

    16075

原文標(biāo)題:多模輸入事件分發(fā)機(jī)制詳解

文章出處:【微信號(hào):gh_e4f28cfa3159,微信公眾號(hào):OpenAtom OpenHarmony】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    理解ECU數(shù)據(jù)流的分析方法

    隨著汽車電子化程度的提高,ECU在車輛中扮演的角色越來(lái)越重要。它們不僅控制著發(fā)動(dòng)機(jī)管理、變速箱、制動(dòng)系統(tǒng)等關(guān)鍵功能,還涉及到車輛的舒適性和安全性。 ECU數(shù)據(jù)流分析的重要性 故障診斷 :通過(guò)
    的頭像 發(fā)表于 11-05 11:07 ?242次閱讀

    請(qǐng)問(wèn)TLV320AIC3254EVM-K怎么讀取音頻數(shù)據(jù)流

    您好,我在學(xué)習(xí)TLV320AIC3254EVM-K開(kāi)發(fā)板的過(guò)程中碰到一個(gè)這樣的問(wèn)題,TI提供的軟件是否具備讀取I2S的音頻數(shù)據(jù)流的功能,或者是否有PC機(jī)軟件可以讀取音頻數(shù)據(jù)流,或者其它方法?請(qǐng)高手幫忙解決,萬(wàn)分感謝!
    發(fā)表于 10-31 06:14

    統(tǒng)一日志數(shù)據(jù)流

    統(tǒng)一日志數(shù)據(jù)流圖 日志系統(tǒng)數(shù)據(jù)流圖 系統(tǒng)進(jìn)行日志收集的過(guò)程可以分為三個(gè)環(huán)節(jié): (1)日志收集和導(dǎo)入ElasticSearch (2)ElasticSearch進(jìn)行索引等處理 (3)可視化操作,查詢等
    的頭像 發(fā)表于 08-21 15:00 ?260次閱讀
    統(tǒng)一日志<b class='flag-5'>數(shù)據(jù)流</b>圖

    使用CYUSB3014實(shí)現(xiàn)USB3VISION,不能成功發(fā)送DSI數(shù)據(jù)流是怎么回事?

    /USB3-Vision-DMA-on-Leader-packet-on-FX3...。目前使用eBUS Player這個(gè)軟件能夠成功識(shí)別到U3V設(shè)備,并且連接成功,但是啟動(dòng)發(fā)送數(shù)據(jù)流時(shí),僅能夠發(fā)送leader數(shù)據(jù),不能夠正常發(fā)
    發(fā)表于 07-05 07:58

    ESP32如何在不漏數(shù)據(jù)的情況下采集數(shù)據(jù)流

    esp32作為spi從機(jī)連接一款A(yù)D,該AD芯片上電后就會(huì)持續(xù)不斷地向外發(fā)送數(shù)據(jù),如果循環(huán)調(diào)用spi_slave_transmit(),那么兩次調(diào)用之間就會(huì)漏掉一些數(shù)據(jù)。 請(qǐng)問(wèn)從機(jī)有沒(méi)有辦法在不漏數(shù)據(jù)的情況下采集這個(gè)
    發(fā)表于 06-19 08:02

    PLC輸入設(shè)備有哪些

    在工業(yè)自動(dòng)化領(lǐng)域,PLC(可編程邏輯控制器)作為核心控制設(shè)備,其輸入設(shè)備扮演著至關(guān)重要的角色。這些輸入設(shè)備負(fù)責(zé)將外部信號(hào)轉(zhuǎn)化為PLC可以識(shí)別
    的頭像 發(fā)表于 06-15 11:25 ?1196次閱讀

    讓YUV2演示在FX3的內(nèi)存上運(yùn)行,啟動(dòng)數(shù)據(jù)流時(shí)卻無(wú)法正常工作,應(yīng)用程序會(huì)崩潰,為什么?

    效(我看到了我的 4 幀樣本),但啟動(dòng)數(shù)據(jù)流時(shí)卻無(wú)法正常工作,應(yīng)用程序會(huì)崩潰。 在 linux 上運(yùn)行時(shí),v4L2 報(bào)告說(shuō)它根本不起作用: VIDIOC_STREAMON returned -1
    發(fā)表于 05-28 08:18

    stm32F429串口采用DMA方式發(fā)送,數(shù)據(jù)流使能失敗的原因?

    DMA1 時(shí)鐘穩(wěn)定 DMA_DeInit(DMA2_Stream7);// 復(fù)位初始化DMA數(shù)據(jù)流 while (DMA_GetCmdStatus(DMA2_Stream7) != DISABLE
    發(fā)表于 04-17 07:05

    STM32F407USB HAL庫(kù)的USB In時(shí)的數(shù)據(jù)流向是什么?

    最近在學(xué)習(xí)STM32 F407的USB功能。想要做一個(gè)USB聲卡,可以播放,可以錄音。 但是在Host錄音的時(shí)候,F(xiàn)407不會(huì)發(fā)送數(shù)據(jù)到Host。 請(qǐng)問(wèn)有大佬可以介紹一下F407 USB HAL庫(kù)的USB In時(shí)的數(shù)據(jù)流向么?
    發(fā)表于 03-19 06:58

    寬電壓輸入降壓型恒壓恒DCDC FS2957數(shù)據(jù)手冊(cè)

    電子發(fā)燒友網(wǎng)站提供《寬電壓輸入降壓型恒壓恒DCDC FS2957數(shù)據(jù)手冊(cè).pdf》資料免費(fèi)下載
    發(fā)表于 03-18 14:28 ?1次下載

    fx3進(jìn)行視頻數(shù)據(jù)流的傳輸?shù)臅r(shí)候,請(qǐng)問(wèn)如何修改可以達(dá)到同步傳輸?shù)囊螅?/a>

    在fx3的固件中給出的slavefifo 是通過(guò)bulk傳輸?shù)膁emo 我想進(jìn)行視頻數(shù)據(jù)流的傳輸?shù)臅r(shí)候,請(qǐng)問(wèn)如何修改可以達(dá)到同步傳輸?shù)囊? 我目前在固件里面只看到了bulk的方式,如果有同步傳輸?shù)膁emo或者修改教程請(qǐng)不吝賜教 FX3中的ISO數(shù)據(jù)傳輸,這一部分
    發(fā)表于 02-28 07:50

    電氣設(shè)備四種狀態(tài)介紹

    電氣設(shè)備的運(yùn)行、熱備用、冷備用和檢修狀態(tài)是描述電力系統(tǒng)中設(shè)備工作模式的術(shù)語(yǔ)。這些狀態(tài)反映了設(shè)備在電力系統(tǒng)中的不同角色和功能,以及它們對(duì)系統(tǒng)可
    的頭像 發(fā)表于 01-25 14:46 ?3071次閱讀
    電氣<b class='flag-5'>設(shè)備</b>四種<b class='flag-5'>狀態(tài)</b><b class='flag-5'>介紹</b>

    LabVIEW開(kāi)發(fā)工業(yè)設(shè)備遠(yuǎn)程在線狀態(tài)監(jiān)測(cè)

    LabVIEW開(kāi)發(fā)工業(yè)設(shè)備遠(yuǎn)程在線狀態(tài)監(jiān)測(cè) 項(xiàng)目需要減少意外停機(jī)和維護(hù)費(fèi)用、提供更完整的機(jī)器操作和狀態(tài)圖、改進(jìn)設(shè)備使用情況跟蹤。 該解決方案是一個(gè)多節(jié)點(diǎn)(即多站點(diǎn))遠(yuǎn)程監(jiān)控系統(tǒng),它利用
    發(fā)表于 12-04 21:03

    用于處理豐富輸入輸出數(shù)據(jù)流的圖形和圖像處理工具

    電子發(fā)燒友網(wǎng)站提供《用于處理豐富輸入輸出數(shù)據(jù)流的圖形和圖像處理工具.pdf》資料免費(fèi)下載
    發(fā)表于 11-15 14:12 ?0次下載
    用于處理豐富<b class='flag-5'>輸入</b>輸出<b class='flag-5'>數(shù)據(jù)流</b>的圖形和圖像處理工具