本項目Gitee倉地址:深入淺出eTs學習: 帶大家深入淺出學習eTs (gitee.com)
一、ArkUI介紹
框架介紹
方舟開發(fā)框架(簡稱:ArkUI),是一套UI開發(fā)框架,提供開發(fā)者進行應用UI開發(fā)時所必需的能力。
基本概念
- 組件:組件是界面搭建與顯示的最小單位。開發(fā)者通過多種組件的組合,構建出滿足自身應用訴求的完整界面。
- 頁面:page頁面是方舟開發(fā)框架最小的調度分割單位。開發(fā)者可以將應用設計為多個功能頁面,每個頁面進行單獨的文件管理,并通過路由API實現(xiàn)頁面的調度管理,以實現(xiàn)應用內功能的解耦。
主要特征
- UI組件:方舟開發(fā)框架不僅提供了多種基礎組件,如文本顯示、圖片顯示、按鍵交互等,也提供了支持視頻播放能力的媒體組件。并且針對不同類型設備進行了組件設計,提供了組件在不同平臺上的樣式適配能力,此種組件稱為“多態(tài)組件”。
- 布局:UI界面設計離不開布局的參與。方舟開發(fā)框架提供了多種布局方式,不僅保留了經(jīng)典的彈性布局能力,也提供了列表、宮格、柵格布局和適應多分辨率場景開發(fā)的原子布局能力。
- 動畫:方舟開發(fā)框架對于UI界面的美化,除了組件內置動畫效果外,也提供了屬性動畫、轉場動畫和自定義動畫能力。
- 繪制:方舟開發(fā)框架提供了多種繪制能力,以滿足開發(fā)者繪制自定義形狀的需求,支持圖形繪制、顏色填充、文本繪制、圖片繪制等。
- 交互事件:方舟開發(fā)框架提供了多種交互能力,滿足應用在不同平臺通過不同輸入設備均可正常進行UI交互響應,默認適配了觸摸手勢、遙控器、鼠標等輸入操作,同時也提供事件通知能力。
- 平臺API通道:方舟開發(fā)框架提供了API擴展機制,平臺能力通過此種機制進行封裝,提供風格統(tǒng)一的JS接口。
二、常見布局
彈性布局
Flex組件用于創(chuàng)建彈性布局,開發(fā)者可以通過Flex的接口創(chuàng)建容器組件,進而對容器內的其他元素進行彈性布局,例如:使三個元素在容器內水平居中,垂直等間隔分散。
柵格布局
柵格系統(tǒng)作為一種輔助布局的定位工具,在平面設計和網(wǎng)站設計都起到了很好的作用,對移動設備的界面設計有較好的借鑒作用??偨Y柵格系統(tǒng)對于移動設備的優(yōu)勢主要有:
- 給布局提供一種可循的規(guī)律,解決多尺寸多設備的動態(tài)布局問題。
- 給系統(tǒng)提供一種統(tǒng)一的定位標注,保證各模塊各設備的布局一致性。
- 給應用提供一種靈活的間距調整方法,滿足特殊場景布局調整的可能性。
媒體查詢
媒體查詢(Media Query)在移動設備上應用十分廣泛,開發(fā)者經(jīng)常需要根據(jù)設備的大致類型或者特定的特征和設備參數(shù)(例如屏幕分辨率)來修改應用的樣式。為此媒體查詢提供了如下功能:
- 針對設備和應用的屬性信息,可以設計出相匹配的布局樣式。
- 當屏幕發(fā)生動態(tài)改變時(比如分屏、橫豎屏切換),應用頁面布局同步更新。
本教程主要涉及彈性布局和柵格布局的講解和演示
三、彈性布局
Flex:官方文檔
應用彈性方式布局子組件的容器組件。
參數(shù)
參數(shù)名 | 參數(shù)類型 | 必填 | 默認值 | 參數(shù)描述 |
---|---|---|---|---|
direction | FlexDirection | 否 | FlexDirection.Row | 子組件在Flex容器上排列的方向,即主軸的方向。 |
wrap | FlexWrap | 否 | FlexWrap.NoWrap | Flex容器是單行/列還是多行/列排列。 |
justifyContent | FlexAlign | 否 | FlexAlign.Start | 子組件在Flex容器主軸上的對齊格式。 |
alignItems | 否 | ItemAlign.Stretch | 子組件在Flex容器交叉軸上的對齊格式。 | |
alignContent | FlexAlign | 否 | FlexAlign.Start | 交叉軸中有額外的空間時,多行內容的對齊方式。僅在wrap為Wrap或WrapReverse下生效。 |
在Super Visual中導入一個flex布局,在右側可以看到如上的參數(shù)
- FlexDirection枚舉說明
名稱 | 描述 |
---|---|
Row | 主軸與行方向一致作為布局模式。 |
RowReverse | 與Row方向相反方向進行布局。 |
Column | 主軸與列方向一致作為布局模式。 |
ColumnReverse | 與Column相反方向進行布局。 |
在flex中放置兩個標簽,通過修改該參數(shù)可以實現(xiàn)橫向和豎向的顯示
如上圖,是direction的演示,F(xiàn)lex還有其它參數(shù)
FlexWrap枚舉說明
名稱 | 描述 |
---|---|
NoWrap | Flex容器的元素單行/列布局,子項不允許超出容器。 |
Wrap | Flex容器的元素多行/列排布,子項允許超出容器。 |
WrapReverse | Flex容器的元素反向多行/列排布,子項允許超出容器。 |
FlexAlign枚舉說明
名稱 | 描述 |
---|---|
Start | 元素在主軸方向首端對齊,第一個元素與行首對齊,同時后續(xù)的元素與前一個對齊。 |
Center | 元素在主軸方向中心對齊,第一個元素與行首的距離與最后一個元素與行尾距離相同。 |
End | 元素在主軸方向尾部對齊,最后一個元素與行尾對齊,其他元素與后一個對齊。 |
SpaceBetween | Flex主軸方向均勻分配彈性元素,相鄰元素之間距離相同。第一個元素與行首對齊,最后一個元素與行尾對齊。 |
SpaceAround | Flex主軸方向均勻分配彈性元素,相鄰元素之間距離相同。第一個元素到行首的距離和最后一個元素到行尾的距離是相鄰元素之間距離的一半。 |
SpaceEvenly | Flex主軸方向元素等間距布局,相鄰元素之間的間距、第一個元素與行首的間距、最后一個元素到行尾的間距都完全一樣。 |
大家可以自己自由測試,這里就不一一演示了
四、柵格布局
柵格系統(tǒng)
柵格系統(tǒng)有Column、Margin、Gutter三個概念
- Gutter: 用來控制元素與元素之間距離關系??梢愿鶕?jù)設備的不同尺寸,定義不同的gutter值,作為柵格布局的統(tǒng)一規(guī)范。為了保證較好的視覺效果,通常gutter的取值不會大于margin的取值。
- Margin: 離柵格容器邊緣的距離。可以根據(jù)設備的不同尺寸,定義不同的margin值,作為柵格布局的統(tǒng)一規(guī)范。
- Column: 柵格布局的主要定位工具。根據(jù)設備的不同尺寸,把柵格容器分割成不同的列數(shù),在保證margin和gutter符合規(guī)范的情況下,根據(jù)總Column的個數(shù)計算每個Column列的寬度。
系統(tǒng)柵格斷點
系統(tǒng)根據(jù)不同水平寬度設備對應Column的數(shù)量關系,形成了一套斷點規(guī)則定義。
系統(tǒng)以設備的水平寬度的屏幕密度像素值作為斷點依據(jù),根據(jù)當前設備水平寬度所在的斷點范圍,定義了設備的寬度類型。系統(tǒng)的柵格斷點范圍、設備寬度類型及其描述,以及對應的默認總列數(shù)(column),邊距(margin),間隔(gutter)定義如下:
設備水平寬度斷點范圍 | 設備寬度類型 | 描述 | columns | gutter | margin |
---|---|---|---|---|---|
0<水平寬度<320vp | XS | 最小寬度類型設備。 | 2 | 12vp | 12vp |
320vp<=水平寬度<600vp | SM | 小寬度類型設備。 | 4 | 24vp | 24vp |
600vp<=水平寬度<840vp | MD | 中等寬度類型設備。 | 8 | 24vp | 32vp |
840<=水平分辨率 | LG | 大寬度類型設備。 | 12 | 24vp | 48vp |
這里以兩層嵌套為例:形成一個田字格
中間是經(jīng)過多層嵌套形成的田字格,左邊是如何進行嵌套的層級展示,Row為豎向,Column為橫向,如果大家要做一個計算器或者任意形式的布局,使用Row和Column基本都可以實現(xiàn)。
編輯:黃飛
-
ets
+關注
關注
0文章
20瀏覽量
1623 -
OpenHarmony
+關注
關注
25文章
3727瀏覽量
16380
發(fā)布評論請先 登錄
相關推薦
評論