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

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

3天內不再提示

HarmonyOS開發案例:【動畫】

jf_46214456 ? 來源:jf_46214456 ? 作者:jf_46214456 ? 2024-04-25 15:13 ? 次閱讀

介紹

本篇Codelab使用動畫樣式,實現幾種常見動畫效果:平移、旋轉、縮放以及透明度變化。

相關概念

  • [自定義組件]:自定義組件是用戶根據業務需求,將已有的組件組合,封裝成的新組件,可以在工程中多次調用,從而提高代碼的可讀性。
  • [動畫樣式]:組件支持動態的旋轉、平移、縮放效果,可在style或css中設置。

環境搭建

軟件要求

  • [DevEco Studio]版本:DevEco Studio 3.1 Release及以上版本。
  • OpenHarmony SDK版本:API version 9及以上版本。

硬件要求

  • 開發板類型:[潤和RK3568開發板]。
  • OpenHarmony系統:3.2 Release及以上版本。

環境搭建

完成本篇Codelab我們首先要完成開發環境的搭建,本示例以RK3568開發板為例,參照以下步驟進行:

  1. [獲取OpenHarmony系統版本]:標準系統解決方案(二進制)。以3.2 Release版本為例:
  2. 搭建燒錄環境。
    1. [完成DevEco Device Tool的安裝]
    2. [完成RK3568開發板的燒錄]
  3. 搭建開發環境。
    1. 開始前請參考[工具準備],完成DevEco Studio的安裝和開發環境配置。
    2. 開發環境配置完成后,請參考[使用工程向導]創建工程(模板選擇“Empty Ability”)。
    3. 工程創建完成后,選擇使用[真機進行調測]。
    4. 鴻蒙開發指導文檔:[gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md]

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

代碼結構解讀

本篇Codelab只對核心代碼進行講解,對于完整代碼,我們會在gitee中提供。

`HarmonyOS與OpenHarmony鴻蒙文檔籽料:mau123789是v直接拿`

├──entry/src/main/js	             // 代碼區
│  └──MainAbility
│     ├──common
│     │  └──images
│     │     └──ic_windmill.png       // 風車圖標
│     ├──component
│     │  └──animatedCards
│     │     ├──animatedCards.css     // 自定義動畫組件樣式
│     │     ├──animatedCards.hml     // 自定義動畫組件頁面
│     │     └──animatedCards.js      // 自定義動畫組件邏輯
│     ├──i18n
│     │  ├──en-US.json               // 英文國際化
│     │  └──zh-CN.json               // 中文國際化
│     ├──pages
│     │  └──animation
│     │     ├──animation.css   	     // 動畫頁面樣式
│     │     ├──animation.hml         // 動畫頁面
│     │     └──animation.js          // 動畫頁面邏輯
│     └──app.js                      // 程序入口
└──entry/src/main/resources          // 應用資源目錄

頁面構建

頁面展示幾種常見動畫效果:平移、旋轉、縮放以及透明度變化,界面主要由image組件和text組件組成,效果如圖所示:

< !-- animation.hml -- >
< element name='animated-cards' src="../../component/animatedCards/animatedCards.hml" >< /element >
< div class="container" >
    < div class="animation-box" for="{{ value in animationList }}" >
        < animated-cards icon="{{ windmillIcon }}" animation-list="{{ value }}" >< /animated-cards >
    < /div >
< /div >

animation.js文件中,animationList是展示動畫效果的列表數據,windmillIcon是頁面動畫的圖片。

// animation.js
export default {
  data: {
    // 動畫列表
    animationList: [
      {
        animationName: 'Translate',
        animationStyle: 'img-translate'
      },
      {
        animationName: 'Rotate',
        animationStyle: 'img-rotate'
      },
      {
        animationName: 'RotateY',
        animationStyle: 'img-rotateY'
      },
      {
        animationName: 'Scale',
        animationStyle: 'img-scale'
      },
      {
        animationName: 'Opacity',
        animationStyle: 'img-opacity'
      }
    ],
    // 動畫圖片
    windmillIcon: '/common/images/ic_windmill.png'
  }
}

動畫實現

圖片的平移、旋轉、縮放以及透明度變化都是在animatedCards自定義組件中進行實現,界面主要由image組件和text組件組成。

< !--animatedCards.hml-- >
< div class="container" >
    < div class="box" >
        < text class="text" >{{ animationList.animationName }}< /text >
        < div class="windmill-box" >
            < image class="img {{ animationList.animationStyle }}" src="{{ icon }}" >< /image >
        < /div >
    < /div >
< /div >

聲明類型為Array的props,父組件可以通過設置props屬性向子組件傳遞參數。

// animatedCards.js
export default {
  props: ['icon', 'animationList']
}

通過css樣式,實現風車的平移、旋轉、縮放以及透明度的變化。

/* animatedCards.css */
/* 平移動畫 */
.img-translate {
    animation-name: translateAnim;
}

/* 順時針旋轉 */
.img-rotate {
    animation-name: rotateAnim;
}

/* Y軸方向旋轉 */
.img-rotateY {
    animation-name: rotateYAnim;
}

/* 縮放動畫 */
.img-scale {
    animation-name: scaleAnim;
}
/* 透明度變化 */
.img-opacity {
    animation-name: opacityAnim;
}

/* 從-100vp平移到100vp */
@keyframes translateAnim {
    from {
        transform: translate(-100vp);
    }
    to {
        transform: translate(100vp);
    }
}
/* 從0°旋轉到360° */
@keyframes rotateAnim {
    from {
        transform: rotate(0deg);
    }
    to {
        transform: rotate(360deg);
    }
}

/* 沿Y軸旋轉,從0°旋轉到360° */
@keyframes rotateYAnim {
    from {
        transform: rotateY(0deg);
    }
    to {
        transform: rotateY(360deg);
    }
}

/* 從0倍縮放到1.2倍大小 */
@keyframes scaleAnim {
    from {
        transform: scale(0);
    }
    to {
        transform: scale(1.2);
    }
}

/* 不透明度值從0變化到1 */
@keyframes opacityAnim {
    from {
        opacity: 0;
    }
    to {
        opacity: 1;
    }
}

審核編輯 黃宇

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

    關注

    55

    文章

    1967

    瀏覽量

    42222
  • HarmonyOS
    +關注

    關注

    79

    文章

    1910

    瀏覽量

    29498
  • OpenHarmony
    +關注

    關注

    24

    文章

    3443

    瀏覽量

    15332
收藏 人收藏

    評論

    相關推薦

    3568F-視頻開發案

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

    HarmonyOS開發案例:【購物車app】

    OpenHarmony ArkUI框架提供了豐富的動畫組件和接口,開發者可以根據實際場景和開發需求,選用豐富的動畫組件和接口來實現不同的動畫
    的頭像 發表于 05-14 18:19 ?735次閱讀
    <b class='flag-5'>HarmonyOS</b><b class='flag-5'>開發案</b>例:【購物車app】

    HarmonyOS開發案例:【轉場動畫

    在本教程中,我們將會通過一個簡單的樣例,學習如何基于ArkTS的聲明式開發范式開發轉場動畫。其中包含頁面間轉場、組件內轉場以及共享元素轉場。
    的頭像 發表于 05-06 15:42 ?526次閱讀
    <b class='flag-5'>HarmonyOS</b><b class='flag-5'>開發案</b>例:【轉場<b class='flag-5'>動畫</b>】

    HarmonyOS開發案例:【動效】

    利用ArkUI組件不僅可以實現局部屬性變化產生的屬性動畫,也可以實現父組件屬性變化引起子組件產生過渡效果式的全局動畫即顯式動畫
    的頭像 發表于 04-29 22:10 ?1881次閱讀
    <b class='flag-5'>HarmonyOS</b><b class='flag-5'>開發案</b>例:【動效】

    HarmonyOS開發案例:【抽獎轉盤】

    基于畫布組件、顯式動畫,實現的一個自定義抽獎圓形轉盤。
    的頭像 發表于 05-07 10:10 ?480次閱讀
    <b class='flag-5'>HarmonyOS</b><b class='flag-5'>開發案</b>例:【抽獎轉盤】

    HarmonyOS IoT 硬件開發案例分享

    ``許思維老師HiSpark Wi-Fi IoT 開發案例分享:案例一:AHT20溫濕度傳感器開發、調試;案例二:oled屏驅動庫移植,調試;案例三:用OLED屏播放視頻,Wi-Fi 和 TCP/IP 綜合應用。 ``
    發表于 10-27 17:30

    【潤和直播課預告@華為開發者學院】HarmonyOS設備開發基礎課程|HiSpark WiFi-IoT 智能小車套件開發案

    `【潤和直播課預告@華為開發者學院】HarmonyOS設備開發基礎課程|HiSparkWiFi-IoT 智能小車套件開發案例,3月18日(周四) 19:00-21:00,讓你的
    發表于 03-16 15:01

    直播預告丨Hello HarmonyOS進階課程第四課——ArkUI動畫開發

    HarmonyOS開發up主九弓子給大家帶來真實的上架應用開發案例分享,教你從 Canvas繪圖學到CSS應用,再到聲明式UI動畫API應用。ArkUI中的Canvas
    發表于 05-23 10:34

    【直播回顧】Hello HarmonyOS進階課程第四課——ArkUI動畫開發

    ,反響熱烈,本節課知名HarmonyOS開發up主九弓子給大家帶來真實的上架應用開發案例分享,教你從 Canvas繪圖學到CSS應用,再到聲明式UI動畫API應用,一整節課下來除了充實
    發表于 05-26 12:01

    HarmonyOS/OpenHarmony應用開發-屬性動畫

    、translate等。說明: 從API Version 7開始支持。開發語言ets.參數:名稱參數類型必填描述durationnumber否設置動畫時長。單位為毫秒,默認動畫時長為1000毫秒。默認值
    發表于 01-03 10:51

    HarmonyOS屬性動畫開發示例(ArkTS)

    源碼下載 動效示例(ArkTS).zip 環境搭建 我們首先需要完成 HarmonyOS 開發環境搭建,可參照如圖步驟進行。 軟件要求 DevEco Studio版本:DevEco Studio
    發表于 11-23 15:31

    許思維老師HarmonyOS IoT硬件開發案例分享

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

    數碼播放器的開發案

    數碼播放器的開發案例說明。
    發表于 05-19 11:07 ?6次下載

    華為開發者分論壇HarmonyOS學生公開課-OpenHarmony Codelabs開發案

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

    HarmonyOS開發案例:【自定義下拉刷新動畫

    主要介紹組件動畫animation屬性設置。當組件的某些通用屬性變化時,可以通過屬性動畫實現漸變效果,提升用戶體驗。
    的頭像 發表于 04-29 16:06 ?213次閱讀
    <b class='flag-5'>HarmonyOS</b><b class='flag-5'>開發案</b>例:【自定義下拉刷新<b class='flag-5'>動畫</b>】
    亚洲欧美日韩精品久久_久久精品AⅤ无码中文_日本中文字幕有码在线播放_亚洲视频高清不卡在线观看
    <acronym id="s8ci2"><small id="s8ci2"></small></acronym>
    <rt id="s8ci2"></rt><rt id="s8ci2"><optgroup id="s8ci2"></optgroup></rt>
    <acronym id="s8ci2"></acronym>
    <acronym id="s8ci2"><center id="s8ci2"></center></acronym>