chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

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

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

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

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

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

掃碼添加小助手

加入工程師交流群

前言

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

實(shí)現(xiàn)效果

需求分析

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

技術(shù)實(shí)現(xiàn)

  1. 鴻蒙原生開發(fā)中,為開發(fā)者提供了很多自由度高的控件,要想實(shí)現(xiàn)一個(gè)輪播圖,最簡(jiǎ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 類,實(shí)現(xiàn) IDataSource 接口,并實(shí)現(xiàn)其中的方法即可。

  1. 簡(jiǎn)單實(shí)現(xiàn)了展示功能后,接下來為輪播圖提供一些基本屬性。
.loop(true) //是否輪播
      .autoPlay(true) //是否自動(dòng)播放
      .interval(this.duration) //播放間隔時(shí)間
      .indicator(true) //是否顯示指示器
      .vertical(false) //是否豎向播放
      .indicatorStyle({selectedColor:this.bgColor,color:Color.White}) //指示器的相關(guān)配置
  1. 由于 Swiper 提供的默認(rèn)指示器可能不滿足實(shí)際的開發(fā)需求,這里實(shí)現(xiàn)一個(gè)自定義的指示器。首先將默認(rèn)指示器設(shè)置為 false,然后實(shí)現(xiàn) onChange 方法,用來獲取圖片切換的下標(biāo)。
.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)
  }

總結(jié)

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

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

    關(guān)注

    12

    文章

    4035

    瀏覽量

    134441
  • 應(yīng)用程序
    +關(guān)注

    關(guān)注

    38

    文章

    3346

    瀏覽量

    60407
  • HarmonyOS
    +關(guān)注

    關(guān)注

    80

    文章

    2156

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    使用Python/MyHDL創(chuàng)建自定義FPGA IP

    使用 Python/MyHDL 創(chuàng)建自定義 FPGA IP,與 Vivado 集成,并通過 PYNQ 進(jìn)行控制——實(shí)現(xiàn)軟件上的簡(jiǎn)單硬件設(shè)計(jì)。
    的頭像 發(fā)表于 04-09 09:53 ?187次閱讀
    使用Python/MyHDL創(chuàng)建<b class='flag-5'>自定義</b>FPGA IP

    MCUXpresso SDK創(chuàng)建自定義清單

    in the next step 創(chuàng)建自定義清單文件 - 在編輯器(例如 VS Code)中打開文件。 - 復(fù)制west.yml文件。為副本指定個(gè)相關(guān)
    發(fā)表于 04-07 07:11

    極海APM32F427如何實(shí)現(xiàn)自定義USB HID設(shè)備與PC進(jìn)行通信

    最近需要使用到 APM32F427 枚舉成Custom HID設(shè)備進(jìn)行用戶自定義通信,但是官方的例程只有提供的HID枚舉為鼠標(biāo)或者鍵盤類型的設(shè)備。這里記錄下,怎么使用Geehy官方的USB中間件,實(shí)現(xiàn)
    的頭像 發(fā)表于 03-30 09:30 ?2738次閱讀
    極海APM32F427如何<b class='flag-5'>實(shí)現(xiàn)</b><b class='flag-5'>自定義</b>USB HID設(shè)備與PC進(jìn)行通信

    極海APM32F427移植CherryUSB實(shí)現(xiàn)自定義USB HID設(shè)備

    最近需要使用到APM32F427枚舉成Custom HID設(shè)備進(jìn)行用戶自定義通信,但我又不想要使用官方的USB中間件去做一個(gè)USB Custom HID設(shè)備。了解到Cherry USB這個(gè)開源
    的頭像 發(fā)表于 01-20 09:52 ?4004次閱讀
    極海APM32F427移植CherryUSB<b class='flag-5'>實(shí)現(xiàn)</b><b class='flag-5'>自定義</b>USB HID設(shè)備

    電能質(zhì)量在線監(jiān)測(cè)裝置可自定義監(jiān)測(cè)時(shí)段嗎?

    存儲(chǔ)策略及周期性重復(fù)規(guī)則,滿足不同場(chǎng)景下的監(jiān)測(cè)需求。 、自定義監(jiān)測(cè)時(shí)段的核心能力 能力類型 具體說明 典型應(yīng)用 基礎(chǔ)時(shí)段設(shè)置 設(shè)定單次監(jiān)測(cè)的開始時(shí)間(精確到)、結(jié)束時(shí)間或持續(xù)時(shí)長(zhǎng) 特定設(shè)備投運(yùn)測(cè)試(如新增變頻器) 周期性重復(fù)
    的頭像 發(fā)表于 12-10 13:58 ?446次閱讀
    電能質(zhì)量在線監(jiān)測(cè)裝置可<b class='flag-5'>自定義</b>監(jiān)測(cè)時(shí)段嗎?

    無圖形界面模式下自定義檢查工具的應(yīng)用

    此前文章已介紹 ANSA 中的自定義檢查工具。本文將探討該功能在無圖形界面(No-GUI)模式下的應(yīng)用,旨在滿足標(biāo)準(zhǔn)化工作流程的需求,適用于需要高度自動(dòng)化的前處理場(chǎng)景。通過集成自定義檢查,用戶可實(shí)現(xiàn)工作流程的高效自動(dòng)化運(yùn)行。
    的頭像 發(fā)表于 11-30 14:13 ?749次閱讀
    無圖形界面模式下<b class='flag-5'>自定義</b>檢查工具的應(yīng)用

    軟硬件協(xié)同技術(shù)分享 - 任務(wù)劃分 + 自定義指令集

    利用定時(shí)器中斷,率先判斷該FIFO的值不為空,并且保證次讀取個(gè)幀長(zhǎng)(即10個(gè)周期)的數(shù)據(jù),能夠實(shí)現(xiàn)該FIFO內(nèi)數(shù)據(jù)即寫即讀,數(shù)據(jù)寫入不久
    發(fā)表于 10-28 08:03

    采用匯編指示符來使用自定義指令

    具體實(shí)現(xiàn) 1、采用.word .half .dword等匯編指示符直接插入自定義指令,這種方法需要自己指定寄存器。其中.word為插入一個(gè)字的數(shù)據(jù)即32位,.half為插入半字即16位
    發(fā)表于 10-28 06:02

    強(qiáng)實(shí)時(shí)運(yùn)動(dòng)控制內(nèi)核MotionRT750(九):內(nèi)置C語言的自定義機(jī)械手模型實(shí)現(xiàn)

    內(nèi)置C語言的自定義機(jī)械手模型實(shí)現(xiàn)
    的頭像 發(fā)表于 10-27 14:14 ?961次閱讀
    強(qiáng)實(shí)時(shí)運(yùn)動(dòng)控制內(nèi)核MotionRT750(九):內(nèi)置C語言的<b class='flag-5'>自定義</b>機(jī)械手模型<b class='flag-5'>實(shí)現(xiàn)</b>

    大彩講堂:VisualTFT軟件如何自定義圓形進(jìn)度條

    VisualTFT軟件如何自定義圓形進(jìn)度條
    的頭像 發(fā)表于 07-07 17:10 ?1874次閱讀
    大彩講堂:VisualTFT軟件如何<b class='flag-5'>自定義</b>圓形進(jìn)度條

    HarmonyOS實(shí)戰(zhàn):快速實(shí)現(xiàn)個(gè)上下滾動(dòng)的廣告控件

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

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

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

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

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

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

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

    HarmonyOS應(yīng)用自定義鍵盤解決方案

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