鴻蒙Next自定義組件的布局

一僵缺、引言

在鴻蒙Next開發(fā)中,當(dāng)需要通過精確測算的方式來布局自定義組件內(nèi)子組件的位置時,可以使用特定的接口來實現(xiàn)啡专。本文將詳細(xì)介紹如何使用onMeasureSizeonPlaceChildren接口來完成自定義組件的布局,包括接口的功能制圈、使用示例以及實現(xiàn)效果等方面的內(nèi)容们童。

二、布局接口介紹

  1. onMeasureSize接口
    • 功能:組件每次布局時觸發(fā)鲸鹦,用于計算子組件的尺寸慧库。其執(zhí)行時間先于onPlaceChildren接口。
    • 參數(shù):
      • selfLayoutInfo:類型為GeometryInfo馋嗜,提供組件自身的布局信息齐板。
      • children:類型為Array<Measurable>,是可測量的子組件數(shù)組。
      • constraint:類型為ConstraintSizeOptions甘磨,用于約束子組件的尺寸橡羞。
  2. onPlaceChildren接口
    • 功能:組件每次布局時觸發(fā),用于設(shè)置子組件的起始位置济舆。
    • 參數(shù):
      • selfLayoutInfo:同onMeasureSize接口中的selfLayoutInfo卿泽。
      • children:類型為Array<Layoutable>,是可布局的子組件數(shù)組滋觉。
      • constraint:同onMeasureSize接口中的constraint签夭。

三、使用示例

(一)整體結(jié)構(gòu)

  1. Index.ets文件
    • 包含@Entry裝飾的Index組件椎侠,在其build方法中使用Column組件包裹了一個自定義布局組件CustomLayout覆致,并通過builder方式傳入子組件。
  2. 自定義組件相關(guān)代碼
    • CustomLayout組件實現(xiàn)了自定義布局功能肺蔚,包括onMeasureSizeonPlaceChildren方法的定義煌妈,以及build方法來構(gòu)建組件。

(二)具體實現(xiàn)步驟

  1. 計算子組件大行颉(onMeasureSize方法)
    • CustomLayout組件的onMeasureSize方法中璧诵,首先初始化一個size變量為100。然后遍歷傳入的子組件數(shù)組children仇冯,對于每個子組件之宿,使用measure方法測量其尺寸,并將測量結(jié)果的寬度的一半累加到size變量上苛坚。最后設(shè)置this.result.width為100比被,this.result.height為400,并返回this.result泼舱,從而實現(xiàn)組件大小遞增的效果等缀。例如,第一個子組件大小為100娇昙,第二個子組件大小為100加上第一個子組件寬度100的一半(即50)尺迂,以此類推。
  2. 放置子組件位置(onPlaceChildren方法)
    • onPlaceChildren方法中冒掌,定義startPos為300噪裕。然后遍歷子組件數(shù)組children,對于每個子組件股毫,計算其位置posstartPos減去子組件自身的高度膳音。最后使用layout方法將子組件布局到計算得到的位置(pos, pos),使得所有子組件的右下角在頂點位置(300, 300)铃诬,實現(xiàn)了一個從右下角開始展示組件的類似Stack組件的效果祭陷。

(三)子組件傳遞方式

Index組件中苍凛,通過@Builder裝飾的ColumnChildren函數(shù)來構(gòu)建子組件。使用ForEach循環(huán)遍歷一個數(shù)組[1, 2, 3]颗胡,對于每個元素創(chuàng)建一個Text組件毫深,并設(shè)置其樣式(如字體大小吩坝、寬度毒姨、高度、邊框?qū)挾榷で蕖⑵屏康龋┗∧拧H缓髮⑦@個ColumnChildren函數(shù)作為builder參數(shù)傳遞給CustomLayout組件。

四嵌纲、總結(jié)

通過使用onMeasureSizeonPlaceChildren接口俘枫,開發(fā)者可以根據(jù)自己的需求精確計算和設(shè)置自定義組件內(nèi)子組件的大小和位置,實現(xiàn)各種復(fù)雜的布局效果逮走。這種方式提供了更大的靈活性和控制力鸠蚪,有助于打造出更加美觀、高效的用戶界面师溅。在實際開發(fā)中茅信,可以根據(jù)具體的布局需求靈活運用這些接口,實現(xiàn)個性化的組件布局設(shè)計墓臭。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末蘸鲸,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子窿锉,更是在濱河造成了極大的恐慌酌摇,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,919評論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件嗡载,死亡現(xiàn)場離奇詭異窑多,居然都是意外死亡,警方通過查閱死者的電腦和手機洼滚,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,567評論 3 392
  • 文/潘曉璐 我一進店門怯伊,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人耿芹,你說我怎么就攤上這事∨埠澹” “怎么了吧秕?”我有些...
    開封第一講書人閱讀 163,316評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長迹炼。 經(jīng)常有香客問我砸彬,道長颠毙,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,294評論 1 292
  • 正文 為了忘掉前任砂碉,我火速辦了婚禮蛀蜜,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘增蹭。我一直安慰自己滴某,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 67,318評論 6 390
  • 文/花漫 我一把揭開白布滋迈。 她就那樣靜靜地躺著霎奢,像睡著了一般。 火紅的嫁衣襯著肌膚如雪饼灿。 梳的紋絲不亂的頭發(fā)上幕侠,一...
    開封第一講書人閱讀 51,245評論 1 299
  • 那天,我揣著相機與錄音碍彭,去河邊找鬼晤硕。 笑死,一個胖子當(dāng)著我的面吹牛庇忌,可吹牛的內(nèi)容都是我干的舞箍。 我是一名探鬼主播,決...
    沈念sama閱讀 40,120評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼漆枚,長吁一口氣:“原來是場噩夢啊……” “哼创译!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起墙基,我...
    開封第一講書人閱讀 38,964評論 0 275
  • 序言:老撾萬榮一對情侶失蹤软族,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后残制,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體立砸,經(jīng)...
    沈念sama閱讀 45,376評論 1 313
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,592評論 2 333
  • 正文 我和宋清朗相戀三年初茶,在試婚紗的時候發(fā)現(xiàn)自己被綠了颗祝。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,764評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡恼布,死狀恐怖螺戳,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情折汞,我是刑警寧澤倔幼,帶...
    沈念sama閱讀 35,460評論 5 344
  • 正文 年R本政府宣布,位于F島的核電站爽待,受9級特大地震影響损同,放射性物質(zhì)發(fā)生泄漏翩腐。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,070評論 3 327
  • 文/蒙蒙 一膏燃、第九天 我趴在偏房一處隱蔽的房頂上張望茂卦。 院中可真熱鬧,春花似錦组哩、人聲如沸等龙。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,697評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽而咆。三九已至霍比,卻和暖如春幕袱,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背悠瞬。 一陣腳步聲響...
    開封第一講書人閱讀 32,846評論 1 269
  • 我被黑心中介騙來泰國打工们豌, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人浅妆。 一個月前我還...
    沈念sama閱讀 47,819評論 2 370
  • 正文 我出身青樓望迎,卻偏偏與公主長得像,于是被迫代替她去往敵國和親凌外。 傳聞我的和親對象是個殘疾皇子辩尊,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,665評論 2 354

推薦閱讀更多精彩內(nèi)容