在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

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

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

3天內不再提示

HarmonyOS系統中基礎UI組件

HarmonyOS開發者 ? 來源:HarmonyOS開發者 ? 作者:HarmonyOS開發者 ? 2021-09-16 09:39 ? 次閱讀

一、UI組件概述

UI組件(以下簡稱“組件”),是構建界面的核心。

應用中所有的界面元素都是由組件(Component)和組件容器(ComponentContainer)對象構成。UI界面的構成如下圖所示:

Component是繪制在屏幕上的一個對象,用戶能與之交互。Java UI框架提供了創建UI界面的各類組件,比如:文本、按鈕、圖片、列表等。每個組件通過對數據和方法的簡單封裝,實現獨立的可視、可交互功能單元。

ComponentContainer是一個用于容納其他Component和ComponentContainer對象的容器。Java UI框架提供了一些標準布局功能的容器,它們繼承自ComponentContainer,一般以“Layout”結尾,如DirectionalLayout、DependentLayout等(由此可以看出,其實布局就是ComponentContainer,同時布局也是一種組件)。

二、基礎UI組件

Java UI框架提供了一部分Component和ComponentContainer的具體子類,即用于創建用戶界面的各類組件,用戶可通過組件進行交互操作,并獲得響應。根據組件的功能,可以將組件分為布局類、顯示類、交互類三類:

1. 布局類組件

布局類組件是提供了不同布局規范的組件容器,例如以單一方向排列的DirectionalLayout、以相對位置排列的DependentLayout、以確切位置排列的PositionLayout等。

常見的布局類組件如表1所示:

表1 常見的布局類組件

97830ee4-1634-11ec-8fb8-12bb97331649.png

2. 顯示類組件

顯示類組件提供了單純的內容顯示,例如用于文本顯示的Text,用于圖像顯示的Image等。

常見的顯示類組件如表2所示:

表2 常見的顯示類組件

97c12850-1634-11ec-8fb8-12bb97331649.png

3. 交互類組件

交互類組件提供了具體場景下與用戶交互響應的功能,例如Button提供了點擊響應功能,Slider提供了進度選擇功能等。

常見的交互類組件如表3所示:

表3 常見的交互類組件

97d543e4-1634-11ec-8fb8-12bb97331649.png

關于基礎UI組件的開發,開發者可點擊下方官網鏈接進行學習

官網鏈接:

https://developer.harmonyos.com/cn/docs/documentation/doc-guides/ui-java-overview-0000000000500404

三、自定義UI組件

當Java UI框架提供的組件無法滿足設計需求時,開發者就可以創建自定義組件,根據設計需求添加繪制任務,并定義組件的屬性及事件響應,完成組件的自定義。目前,已有300+的自定義UI組件在碼云社區開源,開發者可根據自己的需求,點擊下方鏈接下載使用:

下載鏈接:

https://gitee.com/openharmony-tpc/tpc_resource

同基礎UI組件一樣,本文將自定義UI組件分為布局類、顯示類、交互類三類。下面的章節將著重介紹自定義UI組件的使用。

1. 自定義布局類UI組件

自定義布局類組件是由開發者定義的具有特定布局規則的容器類組件,通過擴展ComponentContainer或其子類實現,將各子組件擺放到指定的位置,響應用戶的滑動、拖拽等事件。

小編在碼云社區找了一些較為常見的自定義布局類組件供大家參考,如表4所示:

表4 常見的自定義布局類組件

97ec598a-1634-11ec-8fb8-12bb97331649.png

本文將例舉ShadowLayout布局,闡述自定義布局類組件的使用。

ShadowLayout是一個可以控制界面元素的陰影顏色、范圍及顯示邊界的布局。效果展示如下:

依賴

開發者需在build.gradle中配置如下信息,引入組件庫

1.在項目根目錄下的build.gradle文件中,需進行如下配置:

allprojects { repositories { maven { url ‘https://s01.oss.sonatype.org/content/repositories/releases/’ } }}

2.在entry模塊的build.gradle文件中,需進行如下配置:

dependencies { implementation(‘com.gitee.chinasoft_ohos1.0.0’)}

使用步驟

1.對布局的基礎屬性進行初始化,比如設置陰影半徑范圍、陰影顏色,及陰影大小等。

《com.lijiankun24.shadowlayout.v2.ShadowLayout ohos:height=“match_content” ohos:width=“match_content” ohos:layout_alignment=“center” ohos:shadowColor=“#660000” ohos:shadowDx=“0” ohos:shadowDy=“0” ohos:shadowRadius=“50” ohos:shadowSide=“0x1111” 》 《Image ohos:id=“$+id:image” ohos:height=“50vp” ohos:width=“50vp” ohos:layout_alignment=“center” ohos:background_element=“$graphic:background_ability_show” ohos:image_src=“$media:icon” ohos:scale_mode=“zoom_center” /》《/com.lijiankun24.shadowlayout.v2.ShadowLayout》

ShadowLayout屬性說明如表5所示:

表5 ShadowLayout自定義屬性

2.通過initComponent()方法初始化組件界面,并設置點擊事件監聽器,監聽界面點擊事件。

private void initComponent() { ShadowLayout slOval = (ShadowLayout) findComponentById(ResourceTable.Id_sl_oval); ShadowLayout slRectangle = (ShadowLayout) findComponentById(ResourceTable.Id_sl_rectangle); ShadowLayout slRadius = (ShadowLayout) findComponentById(ResourceTable.Id_sl_radius); slOval.setShadowColor(Color.getIntColor(“#FE3311F3”)); slRectangle.setShadowColor(Color.getIntColor(“#EE000000”)); slRadius.setShadowRadius(DEFAULT_RADIUS); Text textOval = (Text) findComponentById(ResourceTable.Id_text_oval); Text textRectangle = (Text) findComponentById(ResourceTable.Id_text_rectangle); Text textRadius = (Text) findComponentById(ResourceTable.Id_text_radius);

textOval.setClickedListener(new Component.ClickedListener() { @Override public void onClick(Component component) { slOval.setShadowColor(Color.getIntColor(“#FEFFD700”)); } }); textRectangle.setClickedListener(new Component.ClickedListener() { @Override public void onClick(Component component) { slRectangle.setShadowColor(Color.getIntColor(“#EE00FF7F”)); } });

textRadius.setClickedListener(new Component.ClickedListener() { @Override public void onClick(Component component) { slRadius.setShadowRadius(RADIUS); } });}

photoView組件完整代碼下載鏈接:

https://gitee.com/openharmony-tpc/PhotoView

2. 自定義顯示類UI組件

自定義顯示類UI組件是開發者定義的具有內容顯示特性的組件,通過擴展Component或其子類實現。可將富文本、圖片、進度條等內容,通過自定義的方式直觀地顯示給用戶。較為常見的自定義顯示類組件,如表6所示:

表6 常見的自定義顯示類組件

本文通過例舉PhotoView組件來闡述自定義顯示類組件的使用方法。

PhotoView組件是一個帶圖片縮放的功能的圖片播放器,效果展示如下,通過雙擊屏幕實現圖片的縮放功能。

依賴

開發者需在build.gradle中配置如下信息,引入組件庫

dependencies { implementation ‘io.openharmony.tpc.thirdlib1.1.1’}

使用步驟

1.在xml文件中創建布局,對組件的基礎屬性進行初始化。

《?xml version=“1.0” encoding=“utf-8”?》《DirectionalLayoutxmlns:ohos=“http://schemas.huawei.com/res/ohos”xmlns:photo=“http://schemas.huawei.com/res/photo”ohos:height=“match_parent”ohos:width=“match_parent”ohos:id=“$+id:container”ohos:orientation=“vertical”》

《com.github.chrisbanes.photoview.PhotoView ohos:id=“$+id:photo_v” ohos:height=“match_parent” ohos:width=“match_parent” photo:image=“$media:wallpaper” /》《/DirectionalLayout》

2.初始化photoView

PhotoView photoView = (PhotoView) findComponentById (ResourceTable.Id_photo_v);photoView.setPixelMap(ResourceTable.Media_wallpaper);

3.創建photoView容器

/**創建頁面容器 * */@Overridepublic Object createPageInContainer(ComponentContainer componentContainer, int i) { final int data = list.get(i); PhotoView view = new PhotoView(context); view.setPixelMap(data); // 設置組件的布局參數 view.setLayoutConfig(new ComponentContainer.LayoutConfig( ComponentContainer.LayoutConfig.MATCH_PARENT, ComponentContainer.LayoutConfig.MATCH_PARENT )); view.setPageSlider(slider); // 將組件添加到指定位置。 componentContainer.addComponent(view); return view;}

photoView組件完整代碼下載鏈接:

https://gitee.com/openharmony-tpc/PhotoView

3. 自定義交互類UI組件

自定義交互類UI組件是開發者定義具有交互特性的組件,通過擴展Component或其子類實現,可以響應用戶的點擊、觸摸、長按等操作,實現與用戶的交互。較為常見的自定義交互類組件,如表7所示:

表7 常見的自定義交互類組件

986b27b0-1634-11ec-8fb8-12bb97331649.png

本文通過SlideSwitch組件,來闡述自定義交互類組件的使用方法。

SlideSwitch在功能上屬于交互類組件。展示了不同樣式的開關按鈕,可以滑動它來打開或關閉按鈕開關。

依賴

開發者需在build.gradle中配置如下信息,引入組件庫:

allprojects{ repositories{ mavenCentral() }}implementation ‘io.openharmony.tpc.thirdlib1.0.3’

使用步驟

1.在xml文件中創建布局,對組件的基礎屬性進行設置。

《com.leaking.slideswitch.SlideSwitchohos:id=“$+id:swit2”ohos:width=“190vp”ohos:height=“100vp”ohos:top_margin=“30vp”slideswitch:is_open=“true”slideswitch:shape=“2”slideswitch:theme_color=“#0a5a00”/》

2.監聽滑動開關的變化,并通過setState()方法設置開關的默認狀態。

@Overridepublic void onStart(Intent intent) { super.onStart(intent); setUIContent(ResourceTable.Layout_ability_main); mSlideSwitch = (SlideSwitch) findComponentById(ResourceTable.Id_swit1); mSlideSwitch2 = (SlideSwitch) findComponentById(ResourceTable.Id_swit2); mText = (Text) findComponentById(ResourceTable.Id_text); mSlideSwitch.setSlideListener(this); // 控制開關按鈕的默認狀態 mSlideSwitch.setState(false);}

@Overridepublic void open(SlideSwitch slideSwitch) { if (slideSwitch.getId() == ResourceTable.Id_swit1) { mText.setText(“first switch is opend,and set the second one is ‘slideable’”); mSlideSwitch2.setSlideable(true); }}

@Overridepublic void close(SlideSwitch slideSwitch) { if (slideSwitch.getId() == ResourceTable.Id_swit1) { mText.setText(“first switch is closed,and set the second one is ‘unslideable’”); mSlideSwitch2.setSlideable(false); }}

SlideSwitch組件完整代碼下載鏈接:

https://gitee.com/openharmony-tpc/slideview

至此,就完成了自定義UI組件的使用。是不是超級方便呀!趕快到碼云社區下載源碼學習吧~

責任編輯:haq

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

    關注

    37

    文章

    6850

    瀏覽量

    123432
  • ui
    ui
    +關注

    關注

    0

    文章

    204

    瀏覽量

    21389
  • HarmonyOS
    +關注

    關注

    79

    文章

    1980

    瀏覽量

    30285

原文標題:一文帶你看懂HarmonyOS UI組件的使用

文章出處:【微信號:HarmonyOS_Dev,微信公眾號:HarmonyOS開發者】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    HarmonyOS開發指導類文檔更新速遞(上)

    伴隨著HarmonyOS 5.0.0 Release版本的發布,HarmonyOS官網文檔也帶來了不少上新內容。本期HarmonyOS NEXT開發者資料直通車將從文檔更新角度為開發者推薦應用框架
    的頭像 發表于 12-30 09:50 ?103次閱讀
    <b class='flag-5'>HarmonyOS</b>開發指導類文檔更新速遞(上)

    計算機系統的關鍵組件有哪些

    在計算機系統,關鍵組件的協同工作構成了其強大的數據處理和運算能力。這些組件不僅決定了計算機的性能,還影響著用戶的使用體驗。以下是對計算機系統
    的頭像 發表于 07-15 18:18 ?1688次閱讀

    HarmonyOS NEXT Developer Beta1最新術語表

    UIAbility Stage模型組件類型名,即UIAbility組件,包含UI,提供展示UI的能力,主要用于和用戶交互。 本文根據
    發表于 06-27 16:16

    HarmonyOS NEXT Developer Beta1的Kit

    HarmonyOS NEXT Developer Preview1(API 11)版本開始,HarmonyOS SDK以Kit維度提供豐富、完備的開放能力,涵蓋應用框架、系統、媒體、圖形、應用服務
    發表于 06-26 10:47

    鴻蒙開發:【PageAbility組件概述+配置】

    PageAbility是包含UI、提供展示UI能力的應用組件,主要用于與用戶交互。
    的頭像 發表于 06-17 18:05 ?506次閱讀

    鴻蒙Ability Kit(程序框架服務)【UIAbility組件UI的數據同步】

    基于當前的應用模型,可以通過以下幾種方式來實現UIAbility組件UI之間的數據同步。
    的頭像 發表于 06-03 10:26 ?509次閱讀
    鴻蒙Ability Kit(程序框架服務)【UIAbility<b class='flag-5'>組件</b>與<b class='flag-5'>UI</b>的數據同步】

    鴻蒙Ability Kit(程序框架服務)【UIAbility組件概述】

    UIAbility組件是一種包含UI的應用組件,主要用于和用戶交互。
    的頭像 發表于 05-30 20:17 ?454次閱讀
    鴻蒙Ability Kit(程序框架服務)【UIAbility<b class='flag-5'>組件</b>概述】

    HarmonyOS開發案例:【基礎組件Slider的使用】

    學習如何使用聲明式UI編程框架的基礎組件。本篇Codelab將會使用Image組件、Slider組件、Text組件共同實現一個可調節的風車動
    的頭像 發表于 05-10 16:01 ?685次閱讀
    <b class='flag-5'>HarmonyOS</b>開發案例:【基礎<b class='flag-5'>組件</b>Slider的使用】

    HarmonyOS開發案例:【常用組件與布局】

    HarmonyOS ArkUI提供了豐富多樣的UI組件,您可以使用這些組件輕松地編寫出更加豐富、漂亮的界面。
    的頭像 發表于 05-09 18:20 ?1244次閱讀
    <b class='flag-5'>HarmonyOS</b>開發案例:【常用<b class='flag-5'>組件</b>與布局】

    HarmonyOS實戰開發-深度探索與打造個性化自定義組件

    今天分享一下 什么是自定義組件?及其自定義組件的實戰。 做過前端或者android開發的都知道自定義組件,鴻蒙顯示在界面上的UI都稱為
    發表于 05-08 16:30

    鴻蒙實戰開發ArkTS運用:【ai聊天框】

    用一個ArkTS編寫的HarmonyOS原生聊天UI框架,提供了開箱即用的聊天對話組件
    的頭像 發表于 03-08 15:38 ?991次閱讀
    鴻蒙實戰開發ArkTS運用:【ai聊天框】

    HarmonyOS開發技術全面分析

    系統能力、適配多種終端形態的分布式理念,能夠支持多種終端設備。 ? 對消費者而言, HarmonyOS 能夠將生活場景的各類終端進行能力整合,形成一個“ 超級虛擬終端 ” ,可以實現不同的終端設備之間
    發表于 02-21 16:31

    深入理解HarmonyOS UIAbility:生命周期、WindowStage與啟動模式探析

    UIAbility組件概述 UIAbility組件HarmonyOS中一種包含UI界面的應用組件,主要用于與用戶進行交互。每個UIAbil
    的頭像 發表于 02-17 15:33 ?1502次閱讀
    深入理解<b class='flag-5'>HarmonyOS</b> UIAbility:生命周期、WindowStage與啟動模式探析

    鴻蒙開發-HarmonyOS UI架構

    填充數據,就能正常顯示一個列表了。 數據從哪來 可以看到上面的代碼里是沒有數據的,只有一個空數組。我們想要從網絡獲取數據。那么,數據怎么來呢?最簡單粗暴的寫法就是在aboutToAppear()異步
    發表于 02-16 16:38

    HT UI 5.0,前端組件圖撲是認真的!

    為順應數字時代的不斷發展,圖撲 HT UI 5.0 在原有功能強大的界面組件庫的基礎上進行了全面升級,融入了更先進的技術、創新的設計理念以及更加智能的功能。
    的頭像 發表于 01-30 10:17 ?534次閱讀
    HT <b class='flag-5'>UI</b> 5.0,前端<b class='flag-5'>組件</b>圖撲是認真的!
    主站蜘蛛池模板: 国内夫妇交换性经过实录| 老师在办公室被躁得舒服小说| 天天摸夜夜添夜夜添国产| 天天都色| 国产免费一级在线观看| 201天天爱天天做| 色视频在线观看网站| 午夜美女写真福利写视频| 色婷五月| 男女做视频网站免费观看| 狠狠色狠狠色综合日日32| 爆操极品美女| 人人公开免费超级碰碰碰视频| 国产午夜精品理论片免费观看| 欧美人与zoxxxx| 老司机色网| 色哥网站| 国产主播在线播放| 午夜片在线观看| 国产成人精品影视| 亚洲免费不卡| 亚洲成人高清在线| 欧美婷婷六月丁香综合色| 四虎影永久在线观看精品| 欧美性色欧美a在线观看| 国产亚洲新品一区二区| 午夜精品网站| a资源在线观看| 美女被异性狂揉下部羞羞视频| 五月婷婷六月综合| 久久h| 午夜精品久久久久久91| 91无毒不卡| 在线免费观看一级毛片| 欧美一卡二三卡四卡不卡| www.色日本| 国内精品第一页| 狠狠gao| 男人的天堂天堂网| 亚洲aa| h网站在线观看|