<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-05-06 15:42 ? 次閱讀

介紹

在本教程中,我們將會通過一個簡單的樣例,學習如何基于ArkTS的聲明式開發范式開發轉場動畫。其中包含頁面間轉場、組件內轉場以及共享元素轉場。效果如圖所示:

說明: 本Codelab使用的display接口處于mock階段,在預覽器上使用會顯示白屏現象,可選擇在真機或模擬器上運行。

相關概念

  • [頁面間轉場]:頁面轉場通過在全局pageTransition方法內配置頁面入場組件和頁面退場組件來自定義頁面轉場動效。
  • [組件內轉場]:組件轉場主要通過transition屬性進行配置轉場參數,在組件插入和刪除時進行過渡動效,主要用于容器組件子組件插入刪除時提升用戶體驗(需要配合animateTo才能生效,動效時長、曲線、延時跟隨animateTo中的配置)。
  • [共享元素轉場]:通過修改共享元素的sharedTransition屬性設置元素在不同頁面之間過渡動效。例如,如果兩個頁面使用相同的圖片(但位置和大小不同),圖片就會在這兩個頁面之間流暢地平移和縮放。

環境搭建

軟件要求

  • [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]

代碼結構解讀

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

├──entry/src/main/ets                      // 代碼區
│  ├──common
│  │  ├──constants
│  │  │  └──CommonConstants.ets            // 公共常量類
│  │  └──utils           
│  │     ├──DimensionUtil.ets              // 屏幕適配工具類
│  │     └──GlobalContext.ets              // 全局上下文工具類
│  ├──entryability
│  │  └──EntryAbility.ets                  // 程序入口類
│  ├──pages
│  │  ├──BottomTransition.ets              // 底部滑出頁面
│  │  ├──ComponentTransition.ets           // 移動動畫轉場頁面
│  │  ├──CustomTransition.ets              // 放縮動畫轉場頁面
│  │  ├──FullCustomTransition.ets          // 旋轉動畫轉場頁面
│  │  ├──Index.ets                         // 應用首頁
│  │  ├──ShareItem.ets                     // 共享元素轉場部件
│  │  └──SharePage.ets                     // 共享元素轉場頁面
│  ├──view
│  │  ├──BackContainer.ets                 // 自定義頭部返回組件
│  │  └──TransitionElement.ets             // 自定義動畫元素
│  └──viewmodel
│     └──AnimationModel.ets                // 動畫封裝的model類
└──entry/src/main/resources                // 資源文件目錄

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

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

構建主界面

在這個任務中,我們將完成主界面的設計和開發,效果如圖所示:

從上面效果圖可以看出,主界面主要由5個相同樣式的功能菜單組成,我們可以將這些菜單抽取成一個子組件Item。

  1. 將所需要的圖片添加到resources > base > media目錄下。
  2. 在Index.ets中引入首頁所需要圖片和路由信息,聲明子組件的UI布局并添加樣式,使用ForEach方法循環渲染首頁列表常量數據“INDEX_ANIMATION_MODE”,其中imgRes是設置按鈕的背景圖片,url用于設置頁面路由的地址。
    // Index.ets
    import { INDEX_ANIMATION_MODE } from '../common/constants/CommonConstants';
    
    Column() {
      ForEach(INDEX_ANIMATION_MODE, (item: AnimationModel) = > {
        Row()
          .backgroundImage(item.imgRes)
          .backgroundImageSize(ImageSize.Cover)
          .backgroundColor($r('app.color.trans_parent'))
          .height(DimensionUtil.getVp($r('app.float.main_page_body_height')))
          .margin({ bottom: DimensionUtil.getVp($r('app.float.main_page_body_margin')) })
          .width(FULL_LENGTH)
          .borderRadius(BORDER_RADIUS)
          .onClick(() = > {
            router.pushUrl({ url: item.url })
              .catch((err: Error) = > {
                hilog.error(DOMAIN, PREFIX, FORMAT, err);
              });
          })
      }, (item: AnimationModel) = > JSON.stringify(item))
    }
    

頁面間轉場

實現“底部滑入”效果

在BottomTransition申明pageTransition方法配置轉場參數,其中PageTransitionEnter用于自定義當前頁面的入場效果,PageTransitionExit用于自定義當前頁面的退場效果。效果如圖所示:

通過設置PageTransitionEnter和PageTransitionExit的slide屬性為SlideEffect.Bottom,來實現BottomTransition入場時從底部滑入,退場時從底部滑出。

// BottomTransition.ets
@Entry
@Component
struct BottomTransition {
  build() {
    Column() {
      TransitionElement()
    }
  }

  /**
   * 頁面轉場通過全局pageTransition方法進行配置轉場參數
   *
   * SlideEffect.Bottom 入場時從屏幕下方滑入。
   * SlideEffect.Bottom 退場時從屏幕下方滑出。
   */
  pageTransition() {
    PageTransitionEnter({ duration: TRANSITION_ANIMATION_DURATION, curve: Curve.Smooth }).slide(SlideEffect.Bottom);
    PageTransitionExit({ duration: TRANSITION_ANIMATION_DURATION, curve: Curve.Smooth }).slide(SlideEffect.Bottom);
  }
}

實現”頁面轉場:自定義1“效果

本節實現的效果,頁面入場時為淡入和放大,退場時從右下角滑出。效果如圖所示:

在CustomTransition.ets的Column組件中添加TransitionElement組件,并且定義pageTransition方法。

// CustomTransition.ets
@Entry
@Component
struct CustomTransition {
  build() {
    Column() {
      TransitionElement()
    }
  }

  /**
   * 頁面轉場通過全局pageTransition方法進行配置轉場參數
   *
   * 進場時透明度設置從0.2到1;x、y軸縮放從0變化到1
   * 退場時x、y軸的偏移量為500
   */
  pageTransition() {
    PageTransitionEnter({ duration: TRANSITION_ANIMATION_DURATION, curve: Curve.Smooth })
      .opacity(CUSTOM_TRANSITION_OPACITY)
      .scale(CUSTOM_TRANSITION_SCALE)
    PageTransitionExit({ duration: TRANSITION_ANIMATION_DURATION, curve: Curve.Smooth })
      .translate(CUSTOM_TRANSITION_TRANSLATE)
  }
}

說明: translate設置頁面轉場時的平移效果,為入場時起點和退場時終點的值,和slide同時設置時默認生效slide。

實現”頁面轉場:自定義2“動效

本節實現的效果,頁面入場時淡入和放大,同時順時針旋轉;退場時淡出和縮小,同時逆時針旋轉。效果如圖所示:

在FullCustomTransition.ets的Column組件中添加TransitionElement組件,并且定義pageTransition方法。給Stack組件添加opacity、scale、rotate屬性,定義變量animValue用來控制Stack組件的動效,在PageTransitionEnter和PageTransitionExit組件中動態改變myProgress的值。

// FullCustomTransition.ets
@Entry
@Component
struct FullCustomTransition {
  @State animValue: number = FULL_CUSTOM_TRANSITION_DEFAULT_ANIM_VALUE;

  build() {
    Column() {
      TransitionElement()
    }
    .opacity(this.animValue)
    .scale({ x: this.animValue, y: this.animValue })
    .rotate({
      z: FULL_CUSTOM_TRANSITION_ROTATE_Z,
      angle: FULL_CUSTOM_TRANSITION_ANGLE * this.animValue
    })
  }

  /**
   * 頁面轉場通過全局pageTransition方法進行配置轉場參數
   *
   * 進場過程中會逐幀觸發onEnter回調,入參為動效的歸一化進度(0 - 1)
   * 進場過程中會逐幀觸發onExit回調,入參為動效的歸一化進度(0 - 1)
   */
  pageTransition() {
    PageTransitionEnter({ duration: TRANSITION_ANIMATION_DURATION, curve: Curve.Smooth })
      .onEnter((type?: RouteType, progress?: number) = > {
        if (!progress) {
          return;
        }
        this.animValue = progress;
      });
    PageTransitionExit({ duration: TRANSITION_ANIMATION_DURATION, curve: Curve.Smooth })
      .onExit((type?: RouteType, progress?: number) = > {
        if (!progress) {
          return;
        }
        this.animValue = FULL_CUSTOM_TRANSITION_DEFAULT_ANIM_VALUE - progress;
      });
  }
}

組件內轉場

本節實現組件內轉場動效,通過一個按鈕來控制組件的添加和移除,呈現容器組件子組件添加和移除時的動效。效果如圖所示:

組件轉場主要通過transition屬性方法配置轉場參數,在組件添加和移除時會執行過渡動效,需要配合animateTo才能生效。動效時長、曲線、延時跟隨animateTo中的配置。

  1. 在ComponentTransition.ets文件中,新建Image子組件,并添加兩個transition屬性,分別用于定義組件的添加動效和移除動效。
    // ComponentTransition.ets
    Image($r('app.media.bg_element'))
      .TransitionEleStyles()
      .transition({
        type: TransitionType.Insert,
        scale: COMPONENT_TRANSITION_SCALE,
        opacity: COMPONENT_TRANSITION_OPACITY
      })
      .transition({
        type: TransitionType.Delete,
        rotate: COMPONENT_TRANSITION_ROTATE,
        opacity: COMPONENT_TRANSITION_OPACITY
      })
    
  2. 在ComponentTransition代碼中,定義一個isShow變量,用于控制Image子組件的添加和移除,在Button組件的onClick事件中添加animateTo方法,來使Image子組件子組件動效生效。
    // ComponentTransition.ets
    @State isShow: boolean = false;
    
    Button($r('app.string.Component_transition_toggle'))
      .height(DimensionUtil.getVp($r('app.float.element_trans_btn_height')))
      .width(DimensionUtil.getVp($r('app.float.element_trans_btn_width')))
      .fontColor(Color.White)
      .backgroundColor($r('app.color.light_blue'))
      .onClick(() = > {
        animateTo({ duration: TRANSITION_ANIMATION_DURATION }, () = > {
          this.isShow = !this.isShow;
        })
      })
    

共享元素轉場

效果如圖所示:

共享元素轉場通過給組件設置sharedTransition屬性來實現,兩個頁面的組件配置為同一個id,則轉場過程中會執行共享元素轉場。sharedTransition可以設置動效的時長、動畫曲線和延時,實現步驟如下:

  1. 在ShareItem.ets中給Image組件設置sharedTransition屬性,組件轉場id設置為“SHARE_TRANSITION_ID”。
    // ShareItem.ets
    Image($r('app.media.bg_transition'))
      .width(FULL_LENGTH)
      .height(DimensionUtil.getVp($r('app.float.share_item_element_height')))
      .borderRadius(DimensionUtil.getVp($r('app.float.share_item_radius')))
      .margin({ bottom: DimensionUtil.getVp($r('app.float.share_item_element_margin_bottom')) })
      .sharedTransition(SHARE_TRANSITION_ID, {
        duration: TRANSITION_ANIMATION_DURATION,
        curve: Curve.Smooth,
        delay: SHARE_ITEM_ANIMATION_DELAY
      })
      .onClick(() = > {
        router.pushUrl({ url: SHARE_PAGE_URL })
          .catch((err: Error) = > {
            hilog.error(DOMAIN, PREFIX, FORMAT, err);
          });
      })
    
  2. 在SharePage.ets中給Image組件設置sharedTransition屬性,組件轉場id設置為“SHARE_TRANSITION_ID”。
    // SharePage.ets
    @Entry
    @Component
    struct SharePage {
      build() {
        Column() {
          TransitionElement({ imgFit: ImageFit.Cover })
            .sharedTransition(SHARE_TRANSITION_ID, {
              duration: SHARE_ITEM_DURATION,
              curve: Curve.Smooth,
              delay: SHARE_ITEM_ANIMATION_DELAY
            })
        }
      }
    }
    

審核編輯 黃宇

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

    關注

    25

    文章

    4504

    瀏覽量

    94454
  • HarmonyOS
    +關注

    關注

    79

    文章

    1875

    瀏覽量

    29333
  • OpenHarmony
    +關注

    關注

    23

    文章

    3375

    瀏覽量

    15194
  • RK3568
    +關注

    關注

    4

    文章

    441

    瀏覽量

    4223
收藏 人收藏

    評論

    相關推薦

    OpenHarmony實戰開發-如何實現模態轉場

    ,結合轉場動畫和共享元素動畫可實現復雜轉場動畫效果,如縮略圖片點擊后查看大圖。 bindSheet 彈出半模態組件。 用于半模態展示界面,如
    發表于 04-28 14:47

    HarmonyOS IoT 硬件開發案例分享

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

    【木棉花】ArkUI轉場動畫的使用——學習筆記

    看了官方文檔上“轉場動畫的使用(eTS)”的案例,也跟著學習了一下,順便做點筆記O(∩_∩)O正文1.新建項目DevEco Studio下載安裝成功后,打開DevEco Studio,點擊左上角
    發表于 12-19 18:00

    直播預告丨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應用開發-ACE 2.0轉場動畫體驗

    一、組件說明展現了ACE 2.0轉場動畫的使用。其中包含頁面間轉場、組件內轉場以及共享元素轉場。二、效果圖三、完整代碼地址https://g
    發表于 08-23 10:30

    開發者說】XstoryMaker快速書寫劇本場景動畫

    。 在參加HarmonyOS第二屆創新大賽時,我又用JS開發了服務卡片、Xbone 2D骨骼動畫等功能,經過多輪激烈角逐,榮膺本次開發者創新大賽一等獎。 XstoryMaker華為應
    發表于 09-14 12:04

    Harmony/OpenHarmony應用開發-轉場動畫頁面間轉場

    在全局pageTransition方法內配置頁面入場和頁面退場時的自定義轉場動效。說明: 從API Version 7開始支持。開發語言ets.名稱參數參數描述
    發表于 12-26 11:03

    Harmony/OpenHarmony應用開發-轉場動畫組件內轉場

    組件內轉場主要通過transition屬性配置轉場參數,在組件插入和刪除時顯示過渡動效,主要用于容器組件中的子組件插入和刪除時,提升用戶體驗(需要配合animateTo才能生效,動效時長、曲線、延時
    發表于 12-28 16:19

    HarmonyOS/OpenHarmony應用開發-轉場動畫共享元素轉場

    設置頁面間轉場時共享元素的轉場動效。說明: 從API Version 7開始支持。開發語言ets.示例代碼
    發表于 01-04 17:22

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

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

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

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

    HarmonyOS開發案例:【動畫

    使用動畫樣式,實現幾種常見動畫效果:平移、旋轉、縮放以及透明度變化。
    的頭像 發表于 04-25 15:13 ?111次閱讀
    <b class='flag-5'>HarmonyOS</b><b class='flag-5'>開發案</b>例:【<b class='flag-5'>動畫</b>】

    OpenHarmony實戰開發-如何實現組件動畫。

    ArkUI為組件提供了通用的屬性動畫轉場動畫能力的同時,還為一些組件提供了默認的動畫效果。例如,List的滑動動效,Button的點擊動效,是組件自帶的默認
    的頭像 發表于 04-28 15:49 ?147次閱讀
    OpenHarmony實戰<b class='flag-5'>開發</b>-如何實現組件<b class='flag-5'>動畫</b>。

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

    主要介紹組件動畫animation屬性設置。當組件的某些通用屬性變化時,可以通過屬性動畫實現漸變效果,提升用戶體驗。
    的頭像 發表于 04-29 16:06 ?129次閱讀
    <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>