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

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

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

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

HarmonyOS開(kāi)發(fā)案例:【動(dòng)效】

jf_46214456 ? 來(lái)源:jf_46214456 ? 作者:jf_46214456 ? 2024-04-29 22:10 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

介紹

利用ArkUI組件不僅可以實(shí)現(xiàn)局部屬性變化產(chǎn)生的屬性動(dòng)畫(huà),也可以實(shí)現(xiàn)父組件屬性變化引起子組件產(chǎn)生過(guò)渡效果式的全局動(dòng)畫(huà)即顯式動(dòng)畫(huà)。效果如圖所示:

相關(guān)概念

  • [顯式動(dòng)畫(huà)]:提供全局animateTo顯式動(dòng)畫(huà)接口來(lái)指定有閉包代碼導(dǎo)致的狀態(tài)變化插入過(guò)渡動(dòng)畫(huà)效果。
  • [屬性動(dòng)畫(huà)]:組件的通用屬性發(fā)生變化時(shí),可以創(chuàng)建屬性動(dòng)畫(huà)進(jìn)行漸變,提升用戶(hù)體驗(yàn)。
  • [Slider]:滑動(dòng)條組件,用來(lái)快速調(diào)節(jié)設(shè)置值,如音量、亮度等。

環(huán)境搭建

軟件要求

  • [DevEco Studio]版本:DevEco Studio 3.1。
  • OpenHarmony SDK版本:API version 9。

硬件要求

  • 開(kāi)發(fā)板類(lèi)型:[潤(rùn)和RK3568開(kāi)發(fā)板]。
  • OpenHarmony系統(tǒng):3.2 Release。

環(huán)境搭建

完成本篇Codelab我們首先要完成開(kāi)發(fā)環(huán)境的搭建,本示例以RK3568開(kāi)發(fā)板為例,參照以下步驟進(jìn)行:

  1. [獲取OpenHarmony系統(tǒng)版本]:標(biāo)準(zhǔn)系統(tǒng)解決方案(二進(jìn)制)。以3.2 Release版本為例:
  2. 搭建燒錄環(huán)境。
    1. [完成DevEco Device Tool的安裝]
    2. [完成RK3568開(kāi)發(fā)板的燒錄](méi)
  3. 搭建開(kāi)發(fā)環(huán)境。
    1. 開(kāi)始前請(qǐng)參考[工具準(zhǔn)備],完成DevEco Studio的安裝和開(kāi)發(fā)環(huán)境配置。
    2. 開(kāi)發(fā)環(huán)境配置完成后,請(qǐng)參考[使用工程向?qū)創(chuàng)建工程(模板選擇“Empty Ability”),選擇JS或者eTS語(yǔ)言開(kāi)發(fā)。
    3. 工程創(chuàng)建完成后,選擇使用[真機(jī)進(jìn)行調(diào)測(cè)]。
    4. 鴻蒙開(kāi)發(fā)指導(dǎo)文檔:qr23.cn/FBD4cY點(diǎn)擊或者復(fù)制轉(zhuǎn)到。

代碼結(jié)構(gòu)解讀

本篇Codelab只對(duì)核心代碼進(jìn)行講解,完整代碼可以直接從gitee獲取。

├──entry/src/main/ets                // 代碼區(qū)
│  ├──common
│  │  └──constants
│  │     └──Const.ets                // 常量類(lèi)
│  ├──entryability
│  │  └──EntryAbility.ts             // 程序入口類(lèi)
│  ├──pages
│  │  └──Index.ets                   // 動(dòng)效頁(yè)面入口
│  ├──view
│  │  ├──AnimationWidgets.ets        // 動(dòng)畫(huà)組件
│  │  ├──CountController.ets         // 圖標(biāo)數(shù)量控制組件
│  │  └──IconAnimation.ets           // 圖標(biāo)屬性動(dòng)畫(huà)組件
│  └──viewmodel
│     ├──IconItem.ets                // 圖標(biāo)類(lèi)
│     ├──IconsModel.ets              // 圖標(biāo)數(shù)據(jù)模型
│     └──Point.ets                   // 圖標(biāo)坐標(biāo)類(lèi)
└──entry/src/main/resources          // 資源文件

`HarmonyOSOpenHarmony鴻蒙文檔籽料:mau123789v直接拿`

搜狗高速瀏覽器截圖20240326151450.png

頁(yè)面入口

頁(yè)面入口由AnimationWidgets(動(dòng)效組件)、CountController(動(dòng)效圖標(biāo)數(shù)量控制組件)組成。

其中CountController通過(guò)Slider滑動(dòng)控制quantity(動(dòng)效圖標(biāo)數(shù)量);AnimationWidgets根據(jù)quantity展示相應(yīng)數(shù)量的圖標(biāo),點(diǎn)擊組件按鈕后通過(guò)在animateTo的event閉包函數(shù)中改變mainFlag狀態(tài),跟mainFlag相關(guān)的樣式屬性的變化都會(huì)產(chǎn)生動(dòng)畫(huà)效果,代碼如下所示:

// Index.ets
@Entry
@Component
struct Index {
  @State quantity: number = Common.IMAGES_MIN;
  @Provide iconModel: IconsModel = new IconsModel(this.quantity, Common.OFFSET_RADIUS);

  build() {
    Column() {
      // 動(dòng)畫(huà)組件
      AnimationWidgets({
        quantity: $quantity
      })
      // 圖標(biāo)數(shù)量控制組件
      CountController({
        quantity: $quantity
      })
    }
...
  }
}

CountController組件通過(guò)Slilder滑動(dòng)控制動(dòng)效圖標(biāo)的數(shù)量,最少3個(gè)圖標(biāo),最多6個(gè)圖標(biāo),示例代碼如下所示:

// CountController.ets
@Component
export struct CountController {
  @Link quantity: number;

  build() {
    Column() {
      Row() {
        Text($r('app.string.count'))
          .textStyle()

        Text(this.quantity)
          .textStyle()
      }
      ...

      Slider({
        value: this.quantity,
        min: Common.IMAGES_MIN,
        max: Common.IMAGES_TOTAL,
        step: 1,
        style: SliderStyle.InSet
      })
        .blockColor(Color.White)
        .selectedColor('#007DFF')
        .showSteps(true)
        .trackThickness($r('app.float.size_20'))
        .onChange((value: number) = > {
          this.quantity = value;
        })
        ...
    }
  }
}

顯式動(dòng)畫(huà)

點(diǎn)擊AnimationWidgets組件的中心圖標(biāo),調(diào)用animateTo方法,在event回調(diào)方法中改變狀態(tài),從而對(duì)組件本身產(chǎn)生縮放動(dòng)畫(huà),和圖標(biāo)位置變化的動(dòng)畫(huà)效果,效果如下所示:

在animationTo的回調(diào)中修改mainFlag狀態(tài),所有跟mainFlag狀態(tài)相關(guān)的屬性變化都會(huì)產(chǎn)生過(guò)渡動(dòng)畫(huà)效果。代碼如下所示:

// AnimationWidgets.ets
import { IconsModel } from '../viewmodel/IconsModel';
import { IconAnimation } from './IconAnimation';
import Common from '../common/constants/Const';
import IconItem from '../viewmodel/IconItem';

@Component
export struct AnimationWidgets {
  @State mainFlag: boolean = false;
  @Link @Watch('onQuantityChange') quantity: number;
  @Consume iconModel: IconsModel;

  onQuantityChange() {
    this.iconModel.addImage(this.quantity);
  }

  aboutToAppear() {
    this.onQuantityChange();
  }
    
  animate() {
    animateTo(
      {
        delay: Common.DELAY_10,
        tempo: Common.TEMPO,
        iterations: 1,
        duration: Common.DURATION_500,
        curve: Curve.Smooth,
        playMode: PlayMode.Normal
      }, () = > {
        this.mainFlag = !this.mainFlag;
      })
    }
    
  build() {
    Stack() {
      Stack() {
        ForEach(this.iconModel.imagerArr, (item: IconItem) = > {
          IconAnimation({
            item: item,
            mainFlag: $mainFlag
          })
        }, (item: IconItem) = > JSON.stringify(item.index))
      }
      .width(Common.DEFAULT_FULL_WIDTH)
      .height(Common.DEFAULT_FULL_HEIGHT)
      .rotate({
        x: 0,
        y: 0,
        z: 1,
        angle: this.mainFlag ? Common.ROTATE_ANGLE_360 : 0
      })
    
    Image(
      this.mainFlag
        ? $r("app.media.imgActive")
        : $r("app.media.imgInit")
    )
    .width($r('app.float.size_64'))
    .height($r('app.float.size_64'))
    .objectFit(ImageFit.Contain)
    .scale({
      x: this.mainFlag ? Common.INIT_SCALE : 1,
      y: this.mainFlag ? Common.INIT_SCALE : 1
    })
    .onClick(() = > {
      this.iconModel.reset();
      this.animate();
    })
    
    Text($r('app.string.please_click_button'))
      .fontSize($r('app.float.size_16'))
      .opacity(Common.OPACITY_06)
      .fontColor($r('app.color.fontGrayColor'))
      .fontWeight(Common.FONT_WEIGHT_500)
      .margin({
        top: $r('app.float.size_100')
      })
    }
    .width(Common.DEFAULT_FULL_WIDTH)
    .layoutWeight(1)
    
  }
}

屬性動(dòng)畫(huà)

組件的通用屬性發(fā)生變化時(shí),可以創(chuàng)建屬性動(dòng)畫(huà)進(jìn)行漸變,提升用戶(hù)體驗(yàn)。示例效果如下所示:

當(dāng)組件由animation動(dòng)畫(huà)屬性修飾時(shí),如果自身屬性發(fā)生變化會(huì)產(chǎn)生過(guò)渡動(dòng)畫(huà)效果。本示例中當(dāng)點(diǎn)擊小圖標(biāo)時(shí)會(huì)觸發(fā)自身clicked狀態(tài)的變化,所有跟clicked相關(guān)的屬性變化(如translate、rotate、scale、opacity)都會(huì)被增加動(dòng)畫(huà)效果。代碼如下所示:

// IconAnimation.ets
export struct IconAnimation {
  @Link mainFlag: boolean;
  @ObjectLink item: IconItem;

  build() {
    Image(this.item.image)
      .width(Common.ICON_WIDTH)
      .height(Common.ICON_HEIGHT)
      .objectFit(ImageFit.Contain)
      .translate(
          this.mainFlag
            ? { x: this.item.point.x, y: this.item.point.y }
            : { x: 0, y: 0 }
      )
      .rotate({
        x: 0,
        y: 1,
        z: 0,
        angle: this.item.clicked ? Common.ROTATE_ANGLE_360 : 0
      })
      .scale(
          this.item.clicked
          ? { x: Common.SCALE_RATIO, y: Common.SCALE_RATIO }
          : { x: 1, y: 1 }
      )
      .opacity(this.item.clicked ? Common.OPACITY_06 : 1)
      .onClick(() = > {
        this.item.clicked = !this.item.clicked;
      })
      .animation(
        {
          delay: Common.DELAY_10,
          duration: Common.DURATION_1000,
          iterations: 1,
          curve: Curve.Smooth,
          playMode: PlayMode.Normal
        }
      )
  }
}

根據(jù)圖標(biāo)數(shù)量計(jì)算圖標(biāo)位置代碼如下所示:

// IconsModel.ets
import Common from '../common/constants/Const';
import IconItem from './IconItem';
import Point from './Point';

const TWO_PI: number = 2 * Math.PI;

@Observed
export class IconsModel {
  public imagerArr: Array< IconItem > = [];
  private num: number = Common.IMAGES_MIN;
  private radius: number;

  constructor(num: number, radius: number) {
    this.radius = radius;
    this.addImage(num);
  }

  public addImage(num: number) {
    this.num = num;
    if (this.imagerArr.length == num) {
      return;
    }
    if (this.imagerArr.length > num) {
      this.imagerArr.splice(num, this.imagerArr.length - num);
    } else {
      for (let i = this.imagerArr.length; i < num; i++) {
        const point = this.genPointByIndex(i);
        this.imagerArr.push(new IconItem(i, Common.IMAGE_RESOURCE[i], false, point));
      }
    }

    this.refreshPoint(num);
  }

  public refreshPoint(num: number) {
    for (let i = 0; i < num; i++) {
      this.imagerArr[i].point = this.genPointByIndex(i);
    }
  }

  public genPointByIndex(index: number): Point {
    const x = this.radius * Math.cos(TWO_PI * index / this.num);
    const y = this.radius * Math.sin(TWO_PI * index / this.num);
    return new Point(x, y);
  }

  public reset() {
    for (let i = 0; i < this.num; i++) {
      if (this.imagerArr[i].clicked) {
        this.imagerArr[i].clicked = false;
      }
    }
  }
}

審核編輯 黃宇

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

    關(guān)注

    60

    文章

    3012

    瀏覽量

    46154
  • HarmonyOS
    +關(guān)注

    關(guān)注

    80

    文章

    2156

    瀏覽量

    36271
  • OpenHarmony
    +關(guān)注

    關(guān)注

    33

    文章

    3970

    瀏覽量

    21339
  • RK3568
    +關(guān)注

    關(guān)注

    5

    文章

    654

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評(píng)論

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

    TL3588-視頻開(kāi)發(fā)案

    TL3588-視頻開(kāi)發(fā)案
    的頭像 發(fā)表于 01-24 16:29 ?1288次閱讀
    TL3588-視頻<b class='flag-5'>開(kāi)發(fā)案</b>例

    TLT507-Linux-RT應(yīng)用開(kāi)發(fā)案

    TLT507-Linux-RT應(yīng)用開(kāi)發(fā)案
    的頭像 發(fā)表于 01-26 09:46 ?1520次閱讀
    TLT507-Linux-RT應(yīng)用<b class='flag-5'>開(kāi)發(fā)案</b>例

    TLT507-視頻開(kāi)發(fā)案

    TLT507-視頻開(kāi)發(fā)案
    的頭像 發(fā)表于 01-26 10:50 ?1664次閱讀
    TLT507-視頻<b class='flag-5'>開(kāi)發(fā)案</b>例

    3568F-視頻開(kāi)發(fā)案

    3568F-視頻開(kāi)發(fā)案
    的頭像 發(fā)表于 04-12 13:51 ?1464次閱讀
    3568F-視頻<b class='flag-5'>開(kāi)發(fā)案</b>例

    HarmonyOS開(kāi)發(fā)案例:【首選項(xiàng)】

    基于HarmonyOS的首選項(xiàng)能力實(shí)現(xiàn)的一個(gè)簡(jiǎn)單示例。
    的頭像 發(fā)表于 04-19 16:20 ?2267次閱讀
    <b class='flag-5'>HarmonyOS</b><b class='flag-5'>開(kāi)發(fā)案</b>例:【首選項(xiàng)】

    HarmonyOS開(kāi)發(fā)案例:【image、image-animator組件】

    OpenHarmony提供了常用的圖片、圖片幀動(dòng)畫(huà)播放器組件,開(kāi)發(fā)者可以根據(jù)實(shí)際場(chǎng)景和開(kāi)發(fā)需求,實(shí)現(xiàn)不同的界面交互效果,包括:點(diǎn)擊陰影效果、點(diǎn)擊切換狀態(tài)、點(diǎn)擊動(dòng)畫(huà)效果、點(diǎn)擊切換動(dòng)。
    的頭像 發(fā)表于 04-26 17:32 ?2398次閱讀
    <b class='flag-5'>HarmonyOS</b><b class='flag-5'>開(kāi)發(fā)案</b>例:【image、image-animator組件】

    HarmonyOS IoT 硬件開(kāi)發(fā)案例分享

    ``許思維老師HiSpark Wi-Fi IoT 開(kāi)發(fā)案例分享:案例一:AHT20溫濕度傳感器開(kāi)發(fā)、調(diào)試;案例二:oled屏驅(qū)動(dòng)庫(kù)移植,調(diào)試;案例三:用OLED屏播放視頻,Wi-Fi 和 TCP/IP 綜合應(yīng)用。 ``
    發(fā)表于 10-27 17:30

    【潤(rùn)和直播課預(yù)告@華為開(kāi)發(fā)者學(xué)院】HarmonyOS設(shè)備開(kāi)發(fā)基礎(chǔ)課程|HiSpark WiFi-IoT 智能小車(chē)套件開(kāi)發(fā)案

    `【潤(rùn)和直播課預(yù)告@華為開(kāi)發(fā)者學(xué)院】HarmonyOS設(shè)備開(kāi)發(fā)基礎(chǔ)課程|HiSparkWiFi-IoT 智能小車(chē)套件開(kāi)發(fā)案例,3月18日(周四) 19:00-21:00,讓你的
    發(fā)表于 03-16 15:01

    HarmonyOS NEXT新能力,一站式高效開(kāi)發(fā)HarmonyOS應(yīng)用

    提供了全棧式的設(shè)計(jì)架構(gòu),豐富的設(shè)計(jì)資源以及更高效的設(shè)計(jì)工具,將華為在人因研究上面的成果,以及包括動(dòng)、音效、主題、交互等多種能力融入到這些資源中,幫助應(yīng)用開(kāi)發(fā)者快速精致的HarmonyOS
    發(fā)表于 08-14 15:08

    許思維老師HarmonyOS IoT硬件開(kāi)發(fā)案例分享

    許思維老師HiSpark Wi-Fi IoT 開(kāi)發(fā)案例分享:案例一:AHT20溫濕度傳感器開(kāi)發(fā)、調(diào)試;案例二:oled屏驅(qū)動(dòng)庫(kù)移植,調(diào)試;案例三:用OLED屏播放視頻,Wi-Fi 和 TCP/IP 綜合應(yīng)用。
    發(fā)表于 10-29 10:39 ?39次下載
    許思維老師<b class='flag-5'>HarmonyOS</b> IoT硬件<b class='flag-5'>開(kāi)發(fā)案</b>例分享

    數(shù)碼播放器的開(kāi)發(fā)案

    數(shù)碼播放器的開(kāi)發(fā)案例說(shuō)明。
    發(fā)表于 05-19 11:07 ?6次下載

    華為開(kāi)發(fā)者分論壇HarmonyOS學(xué)生公開(kāi)課-OpenHarmony Codelabs開(kāi)發(fā)案

    2021華為開(kāi)發(fā)者分論壇HarmonyOS學(xué)生公開(kāi)課-OpenHarmony Codelabs開(kāi)發(fā)案
    的頭像 發(fā)表于 10-24 11:25 ?2609次閱讀
    華為<b class='flag-5'>開(kāi)發(fā)</b>者分論壇<b class='flag-5'>HarmonyOS</b>學(xué)生公開(kāi)課-OpenHarmony Codelabs<b class='flag-5'>開(kāi)發(fā)案</b>例

    華為圖像服務(wù)場(chǎng)景動(dòng)Java示例代碼

    使用。 提供9種效果炫酷的高級(jí)動(dòng),并支持用戶(hù)交互。 開(kāi)發(fā)準(zhǔn)備 檢查Android Studio開(kāi)發(fā)環(huán)境是否就緒。將示例工程導(dǎo)入Android Studio(3.0及以上版本)中。 在
    發(fā)表于 03-23 11:06 ?0次下載

    如何在OpenHarmony上實(shí)現(xiàn)?翻頁(yè)動(dòng)呢?

    翻頁(yè)動(dòng)是應(yīng)用開(kāi)發(fā)中常見(jiàn)的動(dòng)場(chǎng)景,常見(jiàn)的如書(shū)籍翻頁(yè)、日歷翻頁(yè)等。
    的頭像 發(fā)表于 06-11 15:15 ?1668次閱讀
    如何在OpenHarmony上實(shí)現(xiàn)?翻頁(yè)<b class='flag-5'>動(dòng)</b><b class='flag-5'>效</b>呢?

    RK3568---NPU開(kāi)發(fā)案

    RK3568---NPU開(kāi)發(fā)案
    的頭像 發(fā)表于 01-19 13:50 ?2063次閱讀
    RK3568---NPU<b class='flag-5'>開(kāi)發(fā)案</b>例