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中,属性动画主要用于简单直观地处理单个或多个样式属性的变化,而显示动画则提供了更多的自定义选项和精细控制,能够创建更复杂的动画场景。

相关推荐
belldeep3 小时前
如何阅读、学习 Tcc (Tiny C Compiler) 源代码?如何解析 Tcc 源代码?
c语言·开发语言
LuckyTHP3 小时前
java 使用zxing生成条形码(可自定义文字位置、边框样式)
java·开发语言·python
水银嘻嘻4 小时前
12 web 自动化之基于关键字+数据驱动-反射自动化框架搭建
运维·前端·自动化
小嘟嚷ovo5 小时前
h5,原生html,echarts关系网实现
前端·html·echarts
十一吖i5 小时前
Vue3项目使用ElDrawer后select方法不生效
前端
只可远观5 小时前
Flutter目录结构介绍、入口、Widget、Center组件、Text组件、MaterialApp组件、Scaffold组件
前端·flutter
周胡杰5 小时前
组件导航 (HMRouter)+flutter项目搭建-混合开发+分栏效果
前端·flutter·华为·harmonyos·鸿蒙·鸿蒙系统
敲代码的小吉米5 小时前
前端上传el-upload、原生input本地文件pdf格式(纯前端预览本地文件不走后端接口)
前端·javascript·pdf·状态模式
是千千千熠啊5 小时前
vue使用Fabric和pdfjs完成合同签章及批注
前端·vue.js
bestadc5 小时前
鸿蒙 Core File Kit(文件基础服务)之简单使用文件
harmonyos