91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级av|欧美特级日韩特级

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

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

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

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

OpenAtom OpenHarmony ? 來源:OpenAtom OpenHarmony ? 作者:OpenAtom OpenHarmony ? 2022-06-21 11:15 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

一、 多模輸入概述

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

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

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

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

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

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

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

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

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

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

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

鼠標/觸摸屏坐標指向哪個目標,輸入事件就分發(fā)給對應的目標。 鼠標/觸摸屏事件分發(fā)特殊場景說明: 1)如沒有鼠標上的按鈕按下,當前鼠標指向哪個目標,鼠標輸入事件就分發(fā)給坐標鎖定的目標。 2)如果有鼠標上的按鈕按下,以第一個按鈕按下時刻鼠標坐標鎖定的目標作為分發(fā)標的,直到所有的按鈕都抬起。 3)觸摸屏輸入時,將第一個手指按下鎖定的目標作為輸入事件分發(fā)標的,直到所有的手指都抬起。

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

按鍵事件分發(fā)以當前用戶可視界面中的焦點作為分發(fā)標的,當前界面焦點在哪個目標上,按鍵事件就分發(fā)給對應的標的。

四、OpenHarmony 3.1版本新增接口說明

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

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

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

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

【DeviceListener】

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

【ChangeType】

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

3. 輸入設備熱插拔接口應用場景

軟鍵盤自適應顯示:在文本編輯場景下,輸入法通過監(jiān)聽物理鍵盤輸入設備的熱插拔操作,可自適應決策軟鍵盤是否顯示。當有物理鍵盤設備時,軟鍵盤無需顯示,用戶輸入操作通過物理鍵盤完成輸入。當無物理鍵盤時,輸入法彈出軟鍵盤,用戶通過軟鍵盤完成輸入操作。

4. 輸入設備熱插拔接口使用范例

對于鼠標熱插拔監(jiān)聽接口有了初步的認識后,讓我們來詳細了解下,在實際開發(fā)中如何使用輸入設備熱插拔接口: 1)首先導入模塊 import inputDevice from '@ohos.multimodalInput.inputDevice'; 2)通過監(jiān)聽接口實現(xiàn)輸入設備熱插拔事件監(jiān)聽:

// 輸入法在軟鍵盤顯示邏輯中通過訂閱物理鍵盤的狀態(tài):插入/拔出// 根據(jù)isPhysicalkeyboardExist的值決定軟鍵盤是否彈出...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') { // 熱插拔設備為鍵盤 isPhysicalkeyboardExist = true; } else if (ret == keyboard.ALPHABETIC_KEYBOARD && callback.type == 'remove') { isPhysicalkeyboardExist = false; } });});...3)通過取消監(jiān)聽接口實現(xiàn)輸入設備熱插拔事件取消監(jiān)聽:
listener: function(data) { console.log("type: " + data.type + ", deviceId: " + data.deviceId);}// 單獨取消listener的監(jiān)聽。inputDevice.off("change", this.listener);// 取消所有監(jiān)聽inputDevice.off("change");//取消監(jiān)聽后,軟鍵盤默認都彈出

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

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

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

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

審核編輯 :李倩

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

    關注

    1

    文章

    32

    瀏覽量

    11187
  • OpenHarmony
    +關注

    關注

    33

    文章

    3952

    瀏覽量

    21104

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

文章出處:【微信號:gh_e4f28cfa3159,微信公眾號:OpenAtom OpenHarmony】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    使用簡儀科技產(chǎn)品構建高速數(shù)據(jù)流盤與回放系統(tǒng)解決方案

    本案例面向國產(chǎn)自主可控PXI軟硬件平臺,構建了一套運行于銀河麒麟實時操作系統(tǒng)環(huán)境下的高速數(shù)據(jù)流盤與回放系統(tǒng)。系統(tǒng)以高速數(shù)字化儀為核心,實現(xiàn)多通道高速信號的實時采集、連續(xù)盤存儲及離線回放分析,保障
    的頭像 發(fā)表于 12-30 10:52 ?541次閱讀
    使用簡儀科技產(chǎn)品構建高速<b class='flag-5'>數(shù)據(jù)流</b>盤與回放系統(tǒng)解決方案

    四維圖新入選第二批數(shù)據(jù)流通安全治理典型案例

    日前,在2025年“數(shù)據(jù)要素×”大賽全國總決賽頒獎儀式暨2025全球數(shù)商大會開幕式上,國家數(shù)據(jù)局正式發(fā)布了第二批數(shù)據(jù)流通安全治理典型案例,四維圖新“基于智駕數(shù)據(jù)閉環(huán)應用場景的汽車
    的頭像 發(fā)表于 12-11 16:52 ?1338次閱讀

    歐姆龍推出全新數(shù)據(jù)流邊緣控制器DX1

    2025年11月,歐姆龍自動化(中國)有限公司發(fā)布新品【數(shù)據(jù)流控制器DX1】。DX1作為一款數(shù)據(jù)流邊緣控制器,面對生產(chǎn)現(xiàn)場數(shù)據(jù)采集與活用困難、數(shù)據(jù)需求因人/
    的頭像 發(fā)表于 11-26 18:02 ?1269次閱讀
    歐姆龍推出全新<b class='flag-5'>數(shù)據(jù)流</b>邊緣控制器DX1

    在以下嵌入式軟件設計模型中,屬于數(shù)據(jù)流模型的是,哪里有設計模型的介紹?

    在以下嵌入式軟件設計模型中,屬于數(shù)據(jù)流模型的是()。A. CCSB. CSPC. FSMD. Petri Net
    發(fā)表于 11-24 15:55

    串口空閑中斷與串口超時中斷介紹

    STM32的接收超時功能RTO)。 特點 基于時間閾值,與總線狀態(tài)無關。 可靈活配置超時時間。 需在每次收到數(shù)據(jù)時重置超時計數(shù)器。 應用場景 數(shù)據(jù)分段接收:處理間歇性數(shù)據(jù)流(如GP
    發(fā)表于 11-21 08:31

    語音芯片BUSY狀態(tài)指示功能詳解:提升體驗與穩(wěn)定的關鍵 | 語音IC廠家

    機制。其中,BUSY狀態(tài)指示功能扮演著至關重要的角色,如同系統(tǒng)內(nèi)的“交通信號燈”,指揮著數(shù)據(jù)流的有序通行,是提升用戶體驗與保障系統(tǒng)穩(wěn)定的關鍵。一、核心概念:何為BU
    的頭像 發(fā)表于 11-07 08:57 ?315次閱讀
    語音芯片BUSY<b class='flag-5'>狀態(tài)</b>指示功能詳解:提升體驗與穩(wěn)定的關鍵 | 語音IC廠家

    如何根據(jù)設備健康狀態(tài)數(shù)據(jù)進行分析決策?

    要根據(jù)設備健康狀態(tài)數(shù)據(jù)做好分析決策,需先明確數(shù)據(jù)核心價值,再通過 “數(shù)據(jù)預處理→多維度分析→風險評估→決策落地” 的閉環(huán)流程推進,既依托技術
    的頭像 發(fā)表于 08-20 10:07 ?761次閱讀
    如何根據(jù)<b class='flag-5'>設備</b>健康<b class='flag-5'>狀態(tài)</b><b class='flag-5'>數(shù)據(jù)</b>進行分析決策?

    可信數(shù)據(jù)空間解鎖數(shù)據(jù)流新范式

    在數(shù)字經(jīng)濟時代,數(shù)據(jù)已成為關鍵生產(chǎn)要素和戰(zhàn)略性資源。而可信數(shù)據(jù)空間作為實現(xiàn)數(shù)據(jù)要素安全流通和價值釋放的新型基礎設施,正受到國家政策的高度重視和產(chǎn)業(yè)界的廣泛關注。什么是可信數(shù)據(jù)空間可信
    的頭像 發(fā)表于 08-12 09:37 ?2011次閱讀
    可信<b class='flag-5'>數(shù)據(jù)</b>空間解鎖<b class='flag-5'>數(shù)據(jù)流</b>新范式

    求助,關于stm32H7多DMA數(shù)據(jù)流問題求解

    情況如下:stm32H7配置了一個adc進行采樣,通過dma進行數(shù)據(jù)傳輸,串口接收和發(fā)送命令,用兩個dma數(shù)據(jù)流通道,采用的空閑中斷。 問題:adc一直在中斷中,調試未進入串口中斷,關閉adc后串口
    發(fā)表于 07-29 15:02

    PCIe協(xié)議分析儀能測試哪些設備

    ) 測試場景:驗證CPU與PCIe設備(如GPU、FPGA)之間的數(shù)據(jù)流,優(yōu)化任務調度和數(shù)據(jù)流。 應用價值:在異構計算環(huán)境中平衡計算資源,減少數(shù)據(jù)傳輸瓶頸。 二、存儲
    發(fā)表于 07-25 14:09

    用IS8000軟件和WT5000功率分析儀的DS波形數(shù)據(jù)流功能分析形數(shù)據(jù)

    橫河IS8000集成軟件平臺,將功率分析儀的波形采集與示波器的波形數(shù)據(jù)分析融為一體,提高測試效率。下面我們將為您揭曉如何通過IS8000軟件和WT5000的DS波形數(shù)據(jù)流功能輕松保存并分析相關波形數(shù)據(jù)
    的頭像 發(fā)表于 07-03 18:30 ?638次閱讀
    用IS8000軟件和WT5000功率分析儀的DS波形<b class='flag-5'>數(shù)據(jù)流</b>功能分析形<b class='flag-5'>數(shù)據(jù)</b>

    AD7401A隔離式Σ-Δ調制器技術手冊

    AD7401A是一款二階Σ-Δ調制器,片上的數(shù)字隔離采用ADI公司的**i**Coupler ^?^ 技術,能將模擬輸入信號轉換為高速1位數(shù)據(jù)流。AD7401A采用5 V電源供電,可輸入±250
    的頭像 發(fā)表于 06-04 11:16 ?1224次閱讀
    AD7401A隔離式Σ-Δ調制器技術手冊

    FX3板是否兼容2k和4k分辨率的視頻數(shù)據(jù)流?

    ,實現(xiàn)了 1920 * 1080 @ 60 fps 的設計,但現(xiàn)在我想檢查與上述更高分辨率的兼容性。 關于這一點,我有幾個問題 1.FX3 板是否兼容 2k 和 4k 分辨率的視頻數(shù)據(jù)流? 2.視頻數(shù)據(jù)流
    發(fā)表于 05-23 06:35

    通過 FX3 以 5200*3900 分辨率、15fps 的速度從我的 fpga 傳輸視頻數(shù)據(jù)流,但無法設置最小/最大比特率描述符值,怎么解決?

    我正試圖通過 FX3 以 5200*3900 分辨率、15fps 的速度從我的 fpga 傳輸視頻數(shù)據(jù)流,但無法設置最小/最大比特率描述符值,因為描述符大小只有 32 位。 描述符的預期值應該是
    發(fā)表于 05-23 06:35

    使用FX3測試程序中的數(shù)據(jù)流時,遇到了每8個字節(jié)重復的場景,是什么原因導致的?

    我在使用 FX3 測試程序中的數(shù)據(jù)流時,遇到了每 8 個字節(jié)重復的場景。
    發(fā)表于 05-21 06:59