国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

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

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

3天內不再提示

輸入事件和設備狀態數據流介紹

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

掃碼添加小助手

加入工程師交流群

一、 多模輸入概述

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

二、輸入事件和設備狀態數據流介紹

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

如下圖所示,包括兩類關鍵數據流:

●輸入設備狀態數據流:

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

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

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

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

三、多模輸入事件分發原則

1. 鼠標/觸摸屏事件分發原則

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

2. 按鍵事件分發原則

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

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

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

1. 多模輸入子系統新增接口說明

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

2. 新增接口接口參數說明

【DeviceListener】

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

【ChangeType】

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

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

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

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

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

// 輸入法在軟鍵盤顯示邏輯中通過訂閱物理鍵盤的狀態:插入/拔出// 根據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)通過取消監聽接口實現輸入設備熱插拔事件取消監聽:
listener: function(data) { console.log("type: " + data.type + ", deviceId: " + data.deviceId);}// 單獨取消listener的監聽。inputDevice.off("change", this.listener);// 取消所有監聽inputDevice.off("change");//取消監聽后,軟鍵盤默認都彈出

注:取消熱插拔事件監聽接口中,入參listener可選;當入參帶listener代表取消特定監聽回調。當入參不帶listener,代表取消所有監聽回調。

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

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

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

審核編輯 :李倩

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

    關注

    1

    文章

    32

    瀏覽量

    11187
  • OpenHarmony
    +關注

    關注

    33

    文章

    3952

    瀏覽量

    21106

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

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

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

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    使用簡儀科技產品構建高速數據流盤與回放系統解決方案

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

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

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

    歐姆龍推出全新數據流邊緣控制器DX1

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

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

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

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

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

    語音芯片BUSY狀態指示功能詳解:提升體驗與穩定的關鍵 | 語音IC廠家

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

    如何根據設備健康狀態數據進行分析決策?

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

    可信數據空間解鎖數據流新范式

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

    求助,關于stm32H7多DMA數據流問題求解

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

    PCIe協議分析儀能測試哪些設備

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

    用IS8000軟件和WT5000功率分析儀的DS波形數據流功能分析形數據

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

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

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

    FX3板是否兼容2k和4k分辨率的視頻數據流

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

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

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

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

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