HarmonyOS--属性动画和显示动画

动画-组件参考(基于ArkTS的声明式开发范式)-ArkTS API参考 | 华为开发者联盟 (huawei.com)

在HarmonyOS的ArkUI开发框架中,动画主要分为两种类型:属性动画(Property Animation)和显示动画(Explicit Animation)。

属性动画

属性动画 是通过直接修改组件的样式属性并应用animation属性来实现动画效果。当开发者动态地更改一个组件(如Button、Image等)的尺寸、透明度、背景颜色等样式属性时,如果设置了相应的动画配置,ArkUI会自动填充这些属性变化过程中的每一帧画面,形成平滑的过渡效果。

例如,可以通过设置组件的animation属性来指定动画的执行方式,比如淡入淡出、大小变化等,并且可以控制动画的执行时长、缓动函数等参数。

TypeScript 复制代码
// ArkUI示例代码
//btn:动画start//  
Button('动画按钮')  
   .onClick(() => {  
      if (this.flag) {  
         this.btnWidth = 200  
         this.btnHeight = 50  
      }  
      else {  
         this.btnWidth = 100  
         this.btnHeight = 20  
      }  
      this.flag = !this.flag  // 调转标志位 实现动画循环  
  
   })  
   .width(this.btnWidth) // 改变宽度  
   .height(this.btnHeight) // 改变高度  
   .animation({  // 动画属性  
      duration:2000,  
      curve: Curve.EaseOut,  
      iterations: 1,  
      playMode: PlayMode.Normal,  
      tempo:2  
   })  
//btn:动画end//

但是需要注意的是,animation属性最好写在整体属性之后,尤其是设置动画的属性之后,属性动画-动画-组件参考(基于ArkTS的声明式开发范式)-ArkTS API参考 | 华为开发者联盟 (huawei.com)

显式动画

显示动画 则是通过调用全局动画方法如animateTo来明确指定一组动画操作。这种情况下,开发者需要手动编写动画序列,并明确开始和结束的状态,以及动画的具体行为。

TypeScript 复制代码
// ArkUI 示例代码(伪代码)
import { animateTo } from '@ohos/anim';

// 使用显式动画改变组件宽度
async function animateWidthChange(elementRef) {
  const startSize = elementRef.getWidth();
  const endSize = 200;

  // 创建动画参数对象
  const params = {
    duration: 500,
    timingFunction: 'linear',
    curve: '', // 可选的贝塞尔曲线
    delay: 0,
    iterations: 1,
    fillMode: '',
    direction: '',
    animations: [{
      property: 'width',
      value: [startSize, endSize],
    }],
  };

  // 执行动画
  await animateTo(elementRef, params);
}

总结来说,在ArkUI中,属性动画主要用于简单直观地处理单个或多个样式属性的变化,而显示动画则提供了更多的自定义选项和精细控制,能够创建更复杂的动画场景。

相关推荐
蓝婷儿14 分钟前
每天一个前端小知识 Day 28 - Web Workers / 多线程模型在前端中的应用实践
前端
琹箐15 分钟前
Ant ASpin自定义 indicator 报错
前端·javascript·typescript
小小小小小惠19 分钟前
Responsetype blob会把接口接收的二进制文件转换成blob格式
前端·javascript
爱电摇的小码农19 分钟前
【深度探究系列(5)】:前端开发打怪升级指南:从踩坑到封神的解决方案手册
前端·javascript·css·vue.js·node.js·html5·xss
kymjs张涛44 分钟前
零一开源|前沿技术周报 #7
android·前端·ios
爱编程的喵1 小时前
React入门实战:从静态渲染到动态状态管理
前端·javascript
Tttian6221 小时前
npm init vue@latestnpm error code ETIMEDOUT
前端·vue.js·npm
L_autinue_Star1 小时前
手写vector容器:C++模板实战指南(从0到1掌握泛型编程)
java·c语言·开发语言·c++·学习·stl
患得患失9491 小时前
【前端】【组件库开发】【原理】【无框架开发】现代网页弹窗开发指南:从基础到优化
前端
运维咖啡吧1 小时前
给朋友们分享个好消息 7天时间23.5k
前端·程序员·ai编程