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

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

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

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

HarmonyOS實戰(zhàn):3秒實現(xiàn)一個自定義輪播圖

尤楓 ? 來源:jf_54996641 ? 2025-06-24 17:06 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

前言

輪播圖作為應用程序中最普通使用的控件被廣泛應用,相信對于來發(fā)者來說并不陌生。在 Android 中實現(xiàn)一個 輪播圖很多選擇使用第三方的插件,畢竟在有限的開發(fā)排期中自己動手去實現(xiàn)一個輪播圖 并不那么簡單,需要考慮的細節(jié)很多。不過在 HarmonyOS 中實現(xiàn)一個輪播圖卻是十分的簡單,本篇文章教你在最短的時間內(nèi)快速實現(xiàn)一個自定義的 輪播圖,建議點贊收藏!

實現(xiàn)效果

需求分析

  • 支持自定義循環(huán)播放,自動播放。
  • 支持自定義播放時間間隔。
  • 支持橫向和豎向輪播。
  • 支持自定義指示器。

技術實現(xiàn)

  1. 鴻蒙原生開發(fā)中,為開發(fā)者提供了很多自由度高的控件,要想實現(xiàn)一個輪播圖,最簡單的方式就是選擇合適的控件,這里使用的是官方提供的 Swiper 控件。Swiper 控件支持多種功能屬性。
swiperController: SwiperController = new SwiperController()

Swiper(this.swiperController)
  1. 選擇好 Swiper 控件后,需要為 Swiper 控件提供數(shù)據(jù)。這里使用 LazyForEach 懶加載的方式,提高性能。注意如果使用 LazyForEach 的 方式就需要搭配****IDataSource 使用 。
@State data: LazyData< PhotoData > = new LazyData()

Swiper(this.swiperController) {
        LazyForEach(this.data, (item: PhotoData, index: number) = > {
          Image($r(`app.media.` + item.id))
            .width('100%')
            .height('30%')
        }, (item: PhotoData) = > JSON.stringify(item))
      }
export class LazyData< T > implements IDataSource{
  // 監(jiān)聽器
  private listeners: DataChangeListener[] = []
  private array:Array< T > = []
  totalCount(): number {
   return this.array.length
  }

  getData(index: number): T {
    return this.array[index]
  }

  registerDataChangeListener(listener: DataChangeListener): void {
    if (this.listeners.indexOf(listener)< 0) {
      this.listeners.push(listener)
    }
  }

  unregisterDataChangeListener(listener: DataChangeListener): void {
    const index = this.listeners.indexOf(listener)
    if (index >=0) {
      this.listeners.splice(index,1)
    }
  }
  push(data:T){
    this.array.push(data)
  }

}

自定義LazyData 類,實現(xiàn) IDataSource 接口,并實現(xiàn)其中的方法即可。

  1. 簡單實現(xiàn)了展示功能后,接下來為輪播圖提供一些基本屬性。
.loop(true) //是否輪播
      .autoPlay(true) //是否自動播放
      .interval(this.duration) //播放間隔時間
      .indicator(true) //是否顯示指示器
      .vertical(false) //是否豎向播放
      .indicatorStyle({selectedColor:this.bgColor,color:Color.White}) //指示器的相關配置
  1. 由于 Swiper 提供的默認指示器可能不滿足實際的開發(fā)需求,這里實現(xiàn)一個自定義的指示器。首先將默認指示器設置為 false,然后實現(xiàn) onChange 方法,用來獲取圖片切換的下標。
.indicator(false)
.onChange((index:number)= >{
          this.currentIndex = index
        })
  1. 自定義指示器組件。
@Builder
  progressView() {
    Row({ space: 5 }) {
      LazyForEach(this.data, (item: PhotoData, index: number) = > {
        Stack({ alignContent: Alignment.Start }) {
          Row()
            .zIndex(1)
            .width(this.currentIndex >= index && !this.slide ? '100%' : '0')
            .height(2)
            .borderRadius(2)
            .backgroundColor(this.bgColor)
            .animation(!this.slide ? {
              duration: this.duration - 400,
              curve: Curve.Linear,
              iterations: 1,
              playMode: PlayMode.Normal,
              onFinish: () = > {
                if (this.currentIndex === this.data.totalCount() - 1) {
                  this.duration = 400;
                  this.currentIndex = -1;
                }
              }
            } : { duration: 0, iterations: 1 })
        }
        .width('100%')
        .height(2)
        .borderRadius(2)
        .backgroundColor(this.currentIndex >= index && this.slide ? this.bgColor : Color.Grey)
        .layoutWeight(1)
      }, (item: PhotoData) = > JSON.stringify(item))
    }
    .width('50%')
    .height(50)
  }

總結

在鴻蒙實際開發(fā)中,實現(xiàn)一個輪播圖是十分方便的,但是這并不是意味著所有功能都簡單,還有一些看似簡單的效果實現(xiàn)起來卻是十分的復雜。學會的小伙伴趕緊動手試試吧!

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

    關注

    12

    文章

    3971

    瀏覽量

    129877
  • 應用程序
    +關注

    關注

    38

    文章

    3328

    瀏覽量

    58872
  • HarmonyOS
    +關注

    關注

    80

    文章

    2145

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    HarmonyOS實戰(zhàn):快速實現(xiàn)上下滾動的廣告控件

    廣告功能基本上算是每個軟件的必備功能之,常見的除了輪播,列表之外,就是上下滾動的形式。廣告內(nèi)容不僅支持上下滾動,還需要支持手勢操作,以及關閉當前正在預覽的廣告內(nèi)容。在 Android 或 iOS
    的頭像 發(fā)表于 06-24 17:05 ?83次閱讀

    KiCad 中的自定義規(guī)則(KiCon 演講)

    “ ?Seth Hillbrand 在 KiCon US 2025 上為大家介紹了 KiCad 的規(guī)則系統(tǒng),并詳細講解了自定義規(guī)則的設計與實例。? ” ? 演講主要圍繞 加強 KiCad 中的自定義
    的頭像 發(fā)表于 06-16 11:17 ?225次閱讀
    KiCad 中的<b class='flag-5'>自定義</b>規(guī)則(KiCon 演講)

    HarmonyOS實戰(zhàn)自定義時間選擇器

    前言 最近在日常鴻蒙開發(fā)過程中,經(jīng)常會使用些時間選擇器,鴻蒙官方提供的時間選擇器滿足不了需求,所以自己動手自定義些經(jīng)常會使用到的時間選擇器,希望能幫到你,建議點贊收藏! 實現(xiàn)效果
    的頭像 發(fā)表于 06-09 15:51 ?136次閱讀
    <b class='flag-5'>HarmonyOS</b><b class='flag-5'>實戰(zhàn)</b>:<b class='flag-5'>自定義</b>時間選擇器

    HarmonyOS實戰(zhàn):高德地圖自定義定位圖標展示

    的問題,建議點贊收藏! 實現(xiàn)效果 需求分析 首先需要實現(xiàn)自定義的圖標替代系統(tǒng)默認的箭頭。 獲取定位權限與位置信息。 獲取定位結果并展示當
    的頭像 發(fā)表于 06-09 14:59 ?176次閱讀
    <b class='flag-5'>HarmonyOS</b><b class='flag-5'>實戰(zhàn)</b>:高德地圖<b class='flag-5'>自定義</b>定位圖標展示

    HarmonyOS應用自定義鍵盤解決方案

    自定義鍵盤是種替換系統(tǒng)默認鍵盤的解決方案,可實現(xiàn)鍵盤個性化交互。允許用戶結合業(yè)務需求與操作習慣,對按鍵布局進行可視化重構、設置多功能組合鍵位,使輸入更加便捷和舒適。在安全防護層面,自定義
    的頭像 發(fā)表于 06-05 14:19 ?541次閱讀

    LabVIEW運動控制(三):EtherCAT運動控制器的高效加工指令自定義封裝

    LabVIEW高效加工指令自定義封裝
    的頭像 發(fā)表于 04-08 13:49 ?2514次閱讀
    LabVIEW運動控制(三):EtherCAT運動控制器的高效加工指令<b class='flag-5'>自定義</b>封裝

    如何添加自定義單板

    在開發(fā)過程中,用戶有時需要創(chuàng)建自定義板配置。本節(jié)將通過實例講解用戶如何創(chuàng)建屬于自己的machine,下面以g2l-test.conf為例進行說明。
    的頭像 發(fā)表于 03-12 14:43 ?534次閱讀

    如何快速創(chuàng)建用戶自定義Board和App工程

    概述自HPM_SDKv1.7.0發(fā)布開始,在HPM_ENV中新增了user_template文件夾,以方便用戶快速創(chuàng)建自定義的Board和App工程。user_template是用戶模板工程,用戶
    的頭像 發(fā)表于 02-08 13:38 ?463次閱讀
    如何快速創(chuàng)建用戶<b class='flag-5'>自定義</b>Board和App工程

    Altium Designer 15.0自定義元件設計

    電子發(fā)燒友網(wǎng)站提供《Altium Designer 15.0自定義元件設計.pdf》資料免費下載
    發(fā)表于 01-21 15:04 ?0次下載
    Altium Designer 15.0<b class='flag-5'>自定義</b>元件設計

    think-cell:自定義think-cell(四)

    定義這些設置。 在 PowerPoint 幻燈片母版視圖中,創(chuàng)建新的自定義版式。您將復制與 think-cell 議程幻燈片的所需外觀最匹配的現(xiàn)有自定義布局之。 將新的
    的頭像 發(fā)表于 01-13 10:37 ?482次閱讀
    think-cell:<b class='flag-5'>自定義</b>think-cell(四)

    think-cell;自定義think-cell()

    本章介紹如何自定義 think-cell,即如何更改默認顏色和其他默認屬性;這是通過 think-cell 的樣式文件完成的,這些文件將在前四部分中進行討論。 第五部分 C.5 設置默認議程幻燈片
    的頭像 發(fā)表于 01-08 11:31 ?678次閱讀
    think-cell;<b class='flag-5'>自定義</b>think-cell(<b class='flag-5'>一</b>)

    創(chuàng)建自定義的基于閃存的引導加載程序(BSL)

    電子發(fā)燒友網(wǎng)站提供《創(chuàng)建自定義的基于閃存的引導加載程序(BSL).pdf》資料免費下載
    發(fā)表于 09-19 10:50 ?0次下載
    創(chuàng)建<b class='flag-5'>自定義</b>的基于閃存的引導加載程序(BSL)

    如何創(chuàng)建TestStand自定義步驟

    在之前的課程中簡單地介紹過TestStand自帶的些步驟類型,如測試、消息彈窗、賦值、標簽等等,這些簡單的步驟從TestStand的插入選版中就可以添加到序列中。那么在使用中如果碰到需要實現(xiàn)更加靈活、復雜的功能,使用自帶的
    的頭像 發(fā)表于 09-11 14:46 ?2360次閱讀
    如何創(chuàng)建TestStand<b class='flag-5'>自定義</b>步驟

    EtherCAT運動控制器PT/PVT實現(xiàn)用戶自定義軌跡規(guī)劃

    EtherCAT運動控制器PT/PVT實現(xiàn)用戶自定義軌跡規(guī)劃。
    的頭像 發(fā)表于 08-15 11:49 ?1176次閱讀
    EtherCAT運動控制器PT/PVT<b class='flag-5'>實現(xiàn)</b>用戶<b class='flag-5'>自定義</b>軌跡規(guī)劃

    NVIDIA NeMo加速并簡化自定義模型開發(fā)

    如果企業(yè)希望充分發(fā)揮出 AI 的力量,就需要根據(jù)其行業(yè)需求量身定制的自定義模型。
    的頭像 發(fā)表于 07-26 11:17 ?1193次閱讀
    NVIDIA NeMo加速并簡化<b class='flag-5'>自定義</b>模型開發(fā)
    主站蜘蛛池模板: 亚洲高清免费观看 | 毛片综合 | 性欧美乱又伦 | 1024 在线观看视频免费 | 99色视频在线 | 狼狼色丁香久久女婷婷综合 | 校园春色亚洲欧美 | 韩国韩宝贝2020vip福利视频 | 天天干国产 | ww欧洲ww在线视频看ww | 天天噜夜夜操 | 老师你好滑下面好湿h | 免费欧美黄色网址 | 亚洲日本一区二区三区 | 亚洲国产精品乱码一区二区三区 | 色婷五月 | 在线视频观看你懂的 | 人人天天爱天天做天天摸 | 免费能直接在线观看黄的视频 | 欧美另类高清xxxxx | 欧美精品久久天天躁 | 天堂黄网| 天天做天天爱天天爽天天综合 | 天天躁狠狠躁夜躁2021 | 久久综合九九亚洲一区 | 国产一级真人毛爱做毛片 | 婷婷99精品国产97久久综合 | 免费特黄视频 | 天天操天天舔天天射 | 国产男女怕怕怕免费视频 | 女人张开腿等男人桶免费视频 | 天堂网www在线资源网 | 喷潮白浆直流在线播放 | 黄视频在线免费看 | 黄篇网站在线观看 | 亚洲高清不卡视频 | 六月丁香婷婷天天在线 | 午夜免费片在线观看不卡 | 99香蕉国产 | 国产经典一区 | 黄色在线 |