一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

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

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

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

OpenHarmony ACE 代碼框架總結(jié)

電子發(fā)燒友開源社區(qū) ? 來源:未知 ? 2022-12-30 19:05 ? 次閱讀

一:ACE_Engine框架概述:

ACE_Engine框架是OpenHarmony 的UI開發(fā)框架,提供開發(fā)者在進行應(yīng)用UI開發(fā)時所必需的各種組件,以及定義這些組件的屬性,樣式,事件及方法。通過這些組件可以很方便的進行OpenHarmony上UI應(yīng)用的開發(fā)。 ACE_Engine提供的組件分為兩種類型,即:類Web開發(fā)范式類型和聲明式開發(fā)范式類型。其中類Web開發(fā)范式中定義一個頁面需要三個文件,html,css和js文件。html文件負責(zé)頁面布局,css文件負責(zé)定義組件的樣式,js文件負責(zé)業(yè)務(wù)邏輯實現(xiàn)。而聲明式范式僅需要1個ets文件,頁面布局和組件的樣式以及業(yè)務(wù)邏輯實現(xiàn)都在此文件中。如圖:c7ab3cee-8830-11ed-bfe3-dac502259ad0.png ?二:ACE_Engine框架模塊劃分對于類Web開發(fā)范式組件,根據(jù)組件從前端到后端的過程,可以將整個框架劃分為JsFrameWork,DomNode, ComPonent, RenderNode四個模塊。其作用分別如下:
  • JsFrameWork:
負責(zé)解析前端html和css文件,創(chuàng)建出DomNode樹。該樹的結(jié)構(gòu)和前端頁面是一一對應(yīng)的。2. DomNode: 負責(zé)將Dom樹轉(zhuǎn)換為Component樹。注意一個Dom節(jié)點轉(zhuǎn)換過后的Component節(jié)點實際上并不是一個單獨的節(jié)點,而是一顆以rootComponent為跟節(jié)點的組件樹。該樹中逐層包裹了對應(yīng)的功能組件,最內(nèi)部才是真正的主節(jié)點(這樣的作用是功能解耦合,將某一特定的功能放到對應(yīng)的組件中去)。如BoxComponet負責(zé)組件的邊框繪制,DisplayComponent負責(zé)組件透明度繪制,TouchComponent負責(zé)組件觸摸時間的處理等。,一個詳細過程見DOMNode::GenerateComponentNode函數(shù)。3. ComPonent: 負責(zé)將Component樹中所有繼承自RenderComponent的節(jié)點(可繪制節(jié)點)創(chuàng)建對應(yīng)的RendNode節(jié)點,生成對應(yīng)的RendNode樹。見RenderComponent ::CreateRenderNode虛函數(shù),4. RenderNode: RenderNode即可繪制的節(jié)點,負責(zé)組件的最終布局和繪制。其中布局函數(shù)為PerformLayout虛函數(shù),由每個組件對應(yīng)的實現(xiàn)類Render***類來實現(xiàn)。繪制函數(shù)為Paint虛函數(shù),由每個組件對應(yīng)的子類FlutterRender***類來實現(xiàn)。 對于聲明式開發(fā)范式組件,根據(jù)組件從前端到后端的過程,可以將整個框架劃分為EtsLoader,JsView, ComPonent, RenderNode四個模塊。其作用分別如下:
  • EtsLoader
負責(zé)解析ets頁面,根據(jù)組件的tag標簽創(chuàng)建對應(yīng)的JsView對象,生成jsView樹。2. JsView 負責(zé)處理組件的屬性,方法和事件。并通過Create函數(shù)創(chuàng)建對應(yīng)的Component樹。3. ComPonent: 同Web開發(fā)范式組件中的Component4. RenderNode: 同Web開發(fā)范式組件中的RenderNode 各模塊創(chuàng)建示意圖如下圖所示:c7c84d84-8830-11ed-bfe3-dac502259ad0.png ?各模塊見的調(diào)用關(guān)系及主要函數(shù)如下:c7eb86aa-8830-11ed-bfe3-dac502259ad0.png ?三:組件的屬性/樣式的傳遞過程
  1. 組件的屬性和樣式是保存在前端頁面的,通過JsframeWork解析頁面,并調(diào)用JsEngine的CreateDomNode接口創(chuàng)建Dom節(jié)點的同時傳遞新節(jié)點屬性和樣式。 如果頁面中屬性樣式發(fā)生變化,則單獨調(diào)用SetAttr或SetStyle來更新屬性和樣式。
  2. DomNode收到屬性和樣式之后,會將通用屬性保存在Declation類中,將組件特有的屬性通過SetSpecialAttr和SetSpectialStyle函數(shù)保存在自身。
  3. DomNode調(diào)用對應(yīng)Component類的Set***函數(shù),將所有屬性和樣式設(shè)置到Component中。
  4. RenderNode創(chuàng)建后,會調(diào)用其Update函數(shù)。 該函數(shù)內(nèi)調(diào)用對應(yīng)Component的Get***函數(shù),來接收組件的所有屬性和樣式。
  5. PipeLine中會遍歷每個RenderNode進行布局和繪制,此時,就依據(jù)RenderNode中接收的屬性和樣式,進行布局并繪制。
c80423ae-8830-11ed-bfe3-dac502259ad0.png ? ?四:總結(jié)ACE_Engine框架整體代碼較復(fù)雜,涉及的類也比較多。本文簡單介紹了一個ACE組件從前端的頁面描述,到中間層三棵樹的創(chuàng)建和屬性傳遞,以及最終進行UI布局和繪制的整個過程。該過程簡單總結(jié)一下就是:JS頁面 —> Dom樹 —> Component樹 —> Render樹,最后繪制Render樹。大家只要理解這個基本過程,在結(jié)合代碼關(guān)注重點流程。相信一定能夠?qū)CE_Engine框架的代碼有整體的理解。再此基礎(chǔ)上可以進行ACE組件的增強功能開發(fā),包括新增一個ACE組件等。 文章轉(zhuǎn)自:鴻湖萬聯(lián) 參考:新增一個類Web范式組件開發(fā)指南:https://gitee.com/yan-shuifeng/arkui_docs/blob/master/wiki/Ace1.0前端新增組件開發(fā)指南%EF%BC%9A以新增MyCircle組件為例_ver1.0.md 新增一個聲明式范式組件開發(fā)指南https://gitee.com/yan-shuifeng/arkui_docs/blob/master/wiki/Ace2.0前端新增組件開發(fā)指南%EF%BC%9A以新增MyCircle組件為例_ver1.0.md 更多熱點文章閱讀
  • 玩轉(zhuǎn)OpenHarmony PID:教你打造兩輪平衡車
  • 基于 OpenHarmony 的智聯(lián)北斗海防系統(tǒng)
  • 玩轉(zhuǎn)OpenHarmony智能家居:如何實現(xiàn)樹莓派“碰一碰”設(shè)備控制
  • 帶你玩轉(zhuǎn)OpenHarmony AI:基于Seetaface2的人臉識別
  • 帶你玩轉(zhuǎn)OpenHarmony AI:打造智能語音子系統(tǒng)

提示:本文由電子發(fā)燒友社區(qū)發(fā)布,轉(zhuǎn)載請注明以上來源。如需社區(qū)合作及入群交流,請?zhí)砑游⑿臙EFans0806,或者發(fā)郵箱liuyong@huaqiu.com。


原文標題:OpenHarmony ACE 代碼框架總結(jié)

文章出處:【微信公眾號:電子發(fā)燒友開源社區(qū)】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。


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

    關(guān)注

    33

    文章

    558

    瀏覽量

    33342
  • 開源社區(qū)
    +關(guān)注

    關(guān)注

    0

    文章

    95

    瀏覽量

    580

原文標題:OpenHarmony ACE 代碼框架總結(jié)

文章出處:【微信號:HarmonyOS_Community,微信公眾號:電子發(fā)燒友開源社區(qū)】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦
    熱點推薦

    請問下,openharmony支持哪一款龍芯的開發(fā)板?有沒有開源的龍芯的openharmony源碼?

    想買個2k0300的開發(fā)板學(xué)習(xí)龍芯和openharmony,愣是沒有看到提供openharmony源碼的,也沒與看到開源的代碼。gitee上,openharmony的龍芯sig倉庫也是
    發(fā)表于 04-26 13:06

    北京迅為RK3568開發(fā)板OpenHarmony系統(tǒng)南向驅(qū)動開發(fā)內(nèi)核HDF驅(qū)動框架架構(gòu)

    北京迅為RK3568開發(fā)板OpenHarmony系統(tǒng)南向驅(qū)動開發(fā)內(nèi)核HDF驅(qū)動框架架構(gòu)
    的頭像 發(fā)表于 03-11 14:13 ?901次閱讀
    北京迅為RK3568開發(fā)板<b class='flag-5'>OpenHarmony</b>系統(tǒng)南向驅(qū)動開發(fā)內(nèi)核HDF驅(qū)動<b class='flag-5'>框架</b>架構(gòu)

    基于Django89的web框架代碼

    基于Django89的web框架代碼,超詳細
    發(fā)表于 02-10 15:38 ?0次下載

    迅為RK3568開發(fā)板篇OpenHarmony實操HDF驅(qū)動控制LED-編寫內(nèi)核 LED HDF 驅(qū)動程序

    接下來編譯 LED 驅(qū)動,該驅(qū)動用于在基于華為設(shè)備框架(HDF)的系統(tǒng)中控制 LED 燈的開關(guān),完整代碼如下所示: 更多內(nèi)容可以關(guān)注:迅為RK3568開發(fā)板篇OpenHarmony
    發(fā)表于 01-17 15:13

    OpenHarmony程序分析框架論文入選ICSE 2025

      近日,ICSE 2025軟件工程實踐Track放榜,面向OpenAtom OpenHarmony(以下簡稱“OpenHarmony”)的ArkTS程序分析基礎(chǔ)框架--方舟程序分析器(論文題目為
    的頭像 發(fā)表于 01-02 13:41 ?816次閱讀
    <b class='flag-5'>OpenHarmony</b>程序分析<b class='flag-5'>框架</b>論文入選ICSE 2025

    一加Ace 5系列正式發(fā)布

    一加 Ace 5系列正式發(fā)布。該系列中,一加 Ace 5 Pro搭載全新的驍龍8至尊版移動平臺,一加 Ace 5則搭載第三代驍龍8移動平臺。兩款新機在性能、屏幕、設(shè)計以及影像等方面帶來全方位升級,為用戶打造出更加硬核的電競傳奇體
    的頭像 發(fā)表于 12-27 11:52 ?859次閱讀

    游戲體驗天花板,一加 Ace 5 系列售價 2299 元起

    2024年12月26日,一加正式發(fā)布游戲體驗天花板一加Ace5系列——一加Ace5及一加Ace5Pro。一加Ace5系列深度聚焦性能和游戲體驗,搭載驍龍8系旗艦平臺和行業(yè)首個自研芯片級
    的頭像 發(fā)表于 12-27 10:19 ?1153次閱讀
    游戲體驗天花板,一加 <b class='flag-5'>Ace</b> 5 系列售價 2299 元起

    第三屆OpenHarmony技術(shù)大會星光璀璨、致謝OpenHarmony社區(qū)貢獻者

    取得豐碩成果的TSG團隊、OpenHarmony技術(shù)俱樂部團隊及個人,本次大會特別舉辦了星光團隊和星光個人授牌儀式。共授牌4個星光TSG,分別是安全及機密計算TSG、跨平臺應(yīng)用開發(fā)框架TSG、編程語言
    的頭像 發(fā)表于 10-21 14:10 ?442次閱讀

    【龍芯2K0300蜂鳥板試用】OpenHarmony代碼

    收到龍芯2K0300蜂鳥開發(fā)板后,對開發(fā)板做了一些了解和研究,現(xiàn)將OpenHarmony代碼提供給大家測試,也希望大家能更多的認識龍芯2K0300蜂鳥開發(fā)板,下面先簡單介紹一下這塊開發(fā)板。 廣東
    發(fā)表于 09-18 11:42

    基于ArkTS語言的OpenHarmony APP應(yīng)用開發(fā):HelloOpenharmony

    1、程序簡介該程序是基于OpenHarmony標準系統(tǒng)編寫的UI應(yīng)用類:HelloOpenHarmony。本案例是基于API9接口開發(fā)。本案例已在OpenHarmony凌蒙派-RK3568開發(fā)
    的頭像 發(fā)表于 09-15 08:09 ?705次閱讀
    基于ArkTS語言的<b class='flag-5'>OpenHarmony</b> APP應(yīng)用開發(fā):Hello<b class='flag-5'>Openharmony</b>

    基于ArkTS語言的OpenHarmony APP應(yīng)用開發(fā):HelloOpenharmony

    開發(fā)板驗證通過,具體代碼可參考:https://gitee.com/Lockzhiner-Electronics/lockzhiner-rk3568-openharmony/tree/master
    發(fā)表于 09-14 12:47

    400萬!深開鴻OpenHarmony主倉代碼貢獻量再創(chuàng)里程碑!

    2024年7月8日,據(jù)OpenAtomOpenHarmony(以下簡稱“OpenHarmony”)官網(wǎng)顯示,深開鴻在OpenHarmony社區(qū)主倉代碼貢獻總量超過400萬行,在華為以外
    的頭像 發(fā)表于 07-09 08:33 ?516次閱讀
    400萬!深開鴻<b class='flag-5'>OpenHarmony</b>主倉<b class='flag-5'>代碼</b>貢獻量再創(chuàng)里程碑!

    鴻蒙開發(fā)ArkUI-X基礎(chǔ)知識:【ArkUI代碼工程及構(gòu)建介紹】

    ArkUI作為OpenHarmony的默認開發(fā)框架,在本項目(ArkUI-X)中需要做到一套代碼同時支持多平臺構(gòu)建,所以會采取共倉開發(fā)的方式,部分倉直接指向OpenHarmony相關(guān)開
    的頭像 發(fā)表于 05-25 16:45 ?2564次閱讀
    鴻蒙開發(fā)ArkUI-X基礎(chǔ)知識:【ArkUI<b class='flag-5'>代碼</b>工程及構(gòu)建介紹】

    鴻蒙ArkUI-X跨平臺開發(fā):【命令行工具(ACE Tools)】

    ACE Tools是一套為ArkUI-X項目跨平臺應(yīng)用開發(fā)者提供的命令行工具,支持在Windows/Ubuntu/macOS平臺運行,用于構(gòu)建OpenHarmony/HarmonyOS、Android和iOS平臺的應(yīng)用程序,其功能包括開發(fā)環(huán)境檢查,新建項目,編譯打包,安裝
    的頭像 發(fā)表于 05-21 17:39 ?2559次閱讀
    鴻蒙ArkUI-X跨平臺開發(fā):【命令行工具(<b class='flag-5'>ACE</b> Tools)】

    OpenHarmony 成功亮相國際學(xué)術(shù)會議 ASPLOS 2024

    OpenHarmony的分布式特性、并發(fā)驗證框架及可信執(zhí)行環(huán)境,并與來自全球各地的專家學(xué)者深入探討了其在移動操作系統(tǒng)、分布式系統(tǒng)、系統(tǒng)架構(gòu)設(shè)計、移動
    的頭像 發(fā)表于 05-16 09:28 ?644次閱讀
    <b class='flag-5'>OpenHarmony</b> 成功亮相國際學(xué)術(shù)會議 ASPLOS 2024