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

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

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

3天內不再提示

什么是CircleIndicator?CircleIndicator的源碼實現

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

掃碼添加小助手

加入工程師交流群

UI界面是應用程序可視化必不可少的部分。設計精致的UI界面可以使得整個可視化應用程序給用戶留下深刻的印象,是改善用戶界面體驗最直接的方式。

ArkUI開發框架為開發者提供了豐富的UI原生組件,如Navigation(Page頁面的根容器)、ScrollBar(滾動條組件)、Swiper(滑動容器)及Tabs(通過頁簽進行內容視圖切換的容器組件)等。其中,Swiper組件和Tabs組件在應用程序開發中對于指示器的使用引入較多,但是直接使用原生的Swiper組件和Tabs組件不適用于表現復雜的UI指示器交互變化。因此,我們針對Swiper組件和Tabs組件在指示器應用方向做了一個簡單的封裝,以CiecleIndicator三方組件的形式提供應用程序依賴使用,從而提升了ArkUI開發框架的UI界面之指示器風格多樣化的能力。

CircleIndicator介紹

CircleIndicator組件UI效果展示

圓形指示器:

43bfd5b6-08f6-11ed-ba43-dac502259ad0.gif

長條指示器:

43d86de2-08f6-11ed-ba43-dac502259ad0.gif

橫幅指示器:

440b5036-08f6-11ed-ba43-dac502259ad0.gif

三角指示器:

4442946a-08f6-11ed-ba43-dac502259ad0.gif

圖標指示器:

4453fbba-08f6-11ed-ba43-dac502259ad0.gif

攜帶中央視圖的Tabs指示器:

446f79a8-08f6-11ed-ba43-dac502259ad0.gif

固定位置Tabs指示器:

44951fe6-08f6-11ed-ba43-dac502259ad0.gif

固定位置Tabs指示器(膠囊風格):

44b9837c-08f6-11ed-ba43-dac502259ad0.gif

固定位置Tabs指示器(攜帶角標):

44e57ac2-08f6-11ed-ba43-dac502259ad0.gif

可滑動Tabs指示器:

4502913e-08f6-11ed-ba43-dac502259ad0.gif

可滑動Tabs指示器(水滴滑塊):

453a41ec-08f6-11ed-ba43-dac502259ad0.gif

可滑動Tabs指示器(首列固定):

4559933a-08f6-11ed-ba43-dac502259ad0.gif

titles指示器:

4589f840-08f6-11ed-ba43-dac502259ad0.gif

什么是CircleIndicator?

CircleIndicator顧名思義,它指的是圓形指示器。不過在我們OpenHarmony三方組件中的CircleIndicator組件不再是狹義的圓形指示器,而是將多種表現形式的指示器匯集為一體的歸一化指示器合集組件。

CircleIndicator的源碼實現

這里我們以CircleIndicator組件源碼中的TriangularIndicator.ets文件為源碼解析樣例對象展開分析。首先創建TriangularIndicator.ets文件,使用命名空間建立TriangularIndicator初始化模型:
 
namespace TriangularIndicator {  export class Model {//設置指示器高度    mHeight: number = 18//設置指示器寬度    mWidth: number = lpx2px(720)//設置指示器背景色    mBackgroundColor: string//字段過多,此處進行省略//各字段set與get方法,此處只以height字段為例    public getHeight(): number {      return this.mHeight    }    public setHeight(height: number): Model {      this.mHeight = height      return this    }    //觸摸事件攔截    onPageTouch: (event: TouchEvent, currentIndicator: number) => void    public notifyTouch(event: TouchEvent, currentIndex: number) {      this.onPageTouch(event, currentIndex)    }    //設置構造器    private tabsController: TabsController        (tabsController: TabsController) {      this.tabsController = tabsController    }    //頁面切換監聽    indexChange: (itemIndex: number) => void    public setChangeListener(callback: (index: number) => void): Model{      this.indexChange = callback      return this    }}

將TriangularIndicator應用組件化:
@Componentstruct TriangularIndicator {//獲取TriangularIndicator實例  @State model: TriangularIndicator.Model = new TriangularIndicator.Model(null)//初始化指示器當前index  @Link @Watch("itemIndexChange") itemIndex: number//設置指示器總條數  @State count: number = 0//再分別實現itemIndexChange、aboutToAppear、onTouch、getOffset方法,此處實現不做展示//再在build方法里面描述UI結構    build() {      Column() {        Rect({ width: this.model.mWidth, height:     this.model.mLineHeight }).fill(this.model.mLineColor)        Polygon()          .points(this.model.mReverse ?        [[px2vp(this.model.mWidth) / (this.count * 2) - this.model.mTriangleWidth / 2, this.model.mLineHeight - this.model.mYOffset],        [px2vp(this.model.mWidth) / (this.count * 2), this.model.mLineHeight + this.model.mTriangleHeight - this.model.mYOffset],        [px2vp(this.model.mWidth) / (this.count * 2) + this.model.mTriangleWidth / 2, this.model.mLineHeight - this.model.mYOffset]] :        [[px2vp(this.model.mWidth) / (this.count * 2) - this.model.mTriangleWidth / 2, -this.model.mYOffset],  [px2vp(this.model.mWidth) / (this.count * 2), -this.model.mTriangleHeight - this.model.mYOffset],        [px2vp(this.model.mWidth) / (this.count * 2) + this.model.mTriangleWidth / 2, -this.model.mYOffset]])          .offset(this.model.mStartInterpolator ?            { x: px2vp(this.model.mWidth) / this.count * (this.itemIndex -     this.model.mStartInterpolator.interpolate(Math.abs(this.model.offs    et / this.model.mWidth)) * Math.sign(this.model.offset)),              y: 0 } :            { x: px2vp(this.model.mWidth) / this.count * (this.itemIndex - this.model.offset / this.model.mWidth),              y: 0 })          .fill(this.model.mLineColor)          .height(this.model.mHeight)          .width(this.model.mWidth)      }.width('100%').height(this.model.mHeight)      .backgroundColor(this.model.mBackgroundColor)    }}
最后將TriangularIndicator暴露出來供外部引用:
export default TriangularIndicator

CircleIndicator實戰

創建項目

如圖所示,在DevEco Studio中新建CircleIndicator_Test項目,項目類型選擇Application,語言選擇eTS,點擊Finish完成創建。

459baf4a-08f6-11ed-ba43-dac502259ad0.png

創建工程

添加依賴

成功創建項目后,接下來就是將CircleIndicator組件下載至項目中。請在添加依賴之前參考如何安裝OpenHarmony npm包(https://gitee.com/openharmony-tpc/docs/blob/master/OpenHarmony_npm_usage.md)完成OpenHarmony npm環境配置。完成OpenHarmony npm環境配置之后,在DevEco Studio的底部導航欄,點擊“Terminal”(快捷鍵Alt+F12), 鍵入命令:npm install @ohos/circle-indicator --save并回車,此時CircleIndicator組件會自動下載至項目中。下載完成后工程根目錄下會生成node_modules/@ohos/CircleIndicator目錄。

編寫邏輯代碼

提供多種Indicator,使用方法類似,以TriangularIndicator為例

1.初始化:實例化TabsController和對應的Indicator.Model 對象, 并添加number類型成員以記錄當前頁下標


private controller: TabsController = new TabsController()@State model: TriangularIndicator.Model = new TriangularIndicator.Model(this.controller)@StateitemIndex:number=0
2.屬性設置:通過Model類對象設置UI屬性來自定義所需風格,也可以添加所需的回調
aboutToAppear() {  this.model    .setReverse(true)    .setLineHeight(4)    .setTriangleHeight(10)    .setLineColor("#e94220")    .setBackgroundColor("#eeeeee")    .setChangeListener((itemIndex) => {      console.info("change page to " + this.data[itemIndex])    })}
3.界面繪制:在Tabs組件旁放置Indicator組件,注意需要關閉原生的bar。并監聽Tabs組件的touch事件,通知給Model類,以統一處理滑動邏輯
build() {  Column() {    TriangularIndicator({ itemIndex: $itemIndex, count: this.data.length, model: this.model })    Tabs({ index: this.itemIndex, controller: this.controller }) {      ……    }    .barWidth(0)    .onTouch((event: TouchEvent) => {      this.model.notifyTouch(event, this.itemIndex)    })  }.padding({ top: 40 })  .backgroundColor("#eeeeee")}
本期基于OpenHarmony API8的CircleIndicator組件1.0.3(https://gitee.com/openharmony-sig/CircleIndicator/tree/1.0.3)就為大家介紹到這,歡迎大家積極參與貢獻。了解更多三方組件動態,請關注三方組件資源匯總(https://gitee.com/openharmony-tpc/tpc_resource),更多優秀的組件等你來發現!
審核編輯 :李倩


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

    關注

    8

    文章

    685

    瀏覽量

    31323
  • 應用程序
    +關注

    關注

    38

    文章

    3344

    瀏覽量

    60262

原文標題:CircleIndicator組件,使指示器風格更加多樣化

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

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

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    SaaS云門診系統源碼,診所his系統源碼

    一套成熟的SaaS云門診系統源碼,采用B/S架構,基于SpringBoot+Vue.js技術棧開發。 云門診系統支持醫保結算,包含預約掛號、醫生工作站、收費管理、藥房發藥、庫存管理、會員管理等核心
    的頭像 發表于 11-19 15:51 ?397次閱讀
    SaaS云門診系統<b class='flag-5'>源碼</b>,診所his系統<b class='flag-5'>源碼</b>

    一款基于Java+Spring Boot+Vue的智慧隨訪管理系統源碼

    智慧隨訪管理系統源碼,一款基于Java+Spring Boot+Vue的B/S架構醫院隨訪管理系統源碼,采用前后端分離技術(Ant-Design+MySQL5),具有自主版權和落地案例。 隨訪管理
    的頭像 發表于 11-13 15:38 ?402次閱讀
    一款基于Java+Spring Boot+Vue的智慧隨訪管理系統<b class='flag-5'>源碼</b>

    醫院隨訪管理系統源碼,三級隨訪系統源碼,Java+Springboot,Vue,Ant-Design+MySQL5

    Java版隨訪系統源碼,醫院隨訪管理系統源碼,三級隨訪系統源碼,B/S前后端分離架構,自主版權,落地案例。 技術框架:Java+Springboot,Vue,Ant-Design+MySQL5 開發
    的頭像 發表于 11-08 14:48 ?533次閱讀
    醫院隨訪管理系統<b class='flag-5'>源碼</b>,三級隨訪系統<b class='flag-5'>源碼</b>,Java+Springboot,Vue,Ant-Design+MySQL5

    E203工程源碼時鐘樹解析

    的system.v文件以及引腳約束文件,和rtl文件夾內的源碼,我們參考源碼繪制了E203在MCU200T的時鐘樹,方便我們團隊對E203源碼的時鐘進行修改,分享如下:
    發表于 10-29 07:25

    智能小車設計源碼和圖紙資料

    智能小車設計源碼和圖紙
    發表于 08-25 15:38 ?1次下載

    揭秘Air780EGH定位功能:源碼開放助力極速開發 !

    例,帶你快速上手定位功能的基本使用方法,可根據實際需求靈活擴展和應用。 ? 一、Air780EGH定位示例源碼開放 Air780EGH示例持續更新中,本文將講解Air780EGH核心板實現定位功能
    的頭像 發表于 07-29 16:11 ?693次閱讀
    揭秘Air780EGH定位功能:<b class='flag-5'>源碼</b>開放助力極速開發 !

    RTsmart源碼編譯錯誤,提醒我缺少文件導致make失敗,為什么?

    最近重新拉取Gitee的源碼,根據官網文檔來操作的 選擇的硬件配置是k230_rtos_01studio_defconfig 一直到執行make,都是和以前一樣可以實現的,但是在配置了
    發表于 06-20 06:25

    單片機常用算法源碼下載!

    單片機常用算法源碼下載!
    發表于 06-10 20:44

    【經驗分享】在Omni3576上編譯Redis-8.0.2源碼,并安裝及性能測試

    本文首先介紹Redis是什么,然后介紹如何在Omni3576上編譯Redis-8.0.2源碼,以及從源碼編譯、安裝Redis,最后介紹如何在Omni3576上運行Redis性能測試,并與樹莓派5上的結果進行對比。一、Redis是什么維基百科的介紹是:Redi
    的頭像 發表于 06-05 08:05 ?981次閱讀
    【經驗分享】在Omni3576上編譯Redis-8.0.2<b class='flag-5'>源碼</b>,并安裝及性能測試

    基于stm32 nucleo_L476的智能燈(操作說明+源碼

    基于stm32 nucleo_L476的智能燈(操作說明+源碼)推薦下載!
    發表于 05-28 21:29

    【每周推薦】基于STM32開發項目實例下載(含PCB、原理圖、源碼等)

    1、手機APP遠程控制,智能家居監測、智能控制系統(含源碼)手機APP遠程控制,智能家居監測、智能控制系統(STM32L4、服務器、安卓源碼)項目實例下載!2、基于STM32藍牙控制小車系統
    的頭像 發表于 05-27 08:05 ?1246次閱讀
    【每周推薦】基于STM32開發項目實例下載(含PCB、原理圖、<b class='flag-5'>源碼</b>等)

    每周推薦!基于STM32開發項目實例下載(含PCB、原理圖、源碼等)

    1、手機APP遠程控制,智能家居監測、智能控制系統(含源碼) 手機APP遠程控制,智能家居監測、智能控制系統(STM32L4、服務器、安卓源碼) 項目實例下載! 2、基于STM32藍牙控制小車系統
    發表于 05-26 14:01

    云MES系統源碼,支持 SaaS 多租戶,支持二次開發

    萬界星空科技MES生產制造執行系統源碼,有演示,多個項目應用案例,成熟穩定。支持二次開發,商業授權后可商用。
    的頭像 發表于 05-07 11:14 ?794次閱讀
    云MES系統<b class='flag-5'>源碼</b>,支持 SaaS 多租戶,支持二次開發

    STC單片機聲卡PCB和源碼資料

    STC單片機聲卡PCB和源碼資料
    發表于 04-03 11:14 ?0次下載

    STM32CubeMX生成的FreeRTOS源碼格式如何優化?

    如圖,STM32CubeMX生成的FreeRTOS源碼格式有待優化,空格都是以箭頭的方式呈現,觀感很差。FreeRTOS官方下載的源碼則不存在這個問題,說明是STM32CubeMX生成源碼的過程出現的格式問題,希望ST官方能對
    發表于 03-10 08:04