![](https://s5-media.51cto.com/ost/pc/static/noavatar.gif)
HarmonyOS API:动画
版本:v3.1 Beta
属性动画
更新时间: 2023-02-17 09:19
组件的某些通用属性变化时,可以通过属性动画实现渐变过渡效果,提升用户体验。支持的属性包括width、height、backgroundColor、opacity、scale、rotate、translate等。
说明
从API Version 7开始支持。后续版本如有新增内容,则采用上角标单独标记该内容的起始版本。
animation(value: {duration?: number, tempo?: number, curve?: string | Curve | ICurve, delay?:number, iterations: number, playMode?: PlayMode, onFinish?: () => void})
参数:
名称 | 参数类型 | 必填 | 描述 |
duration | number | 否 | 设置动画时长。单位为毫秒,默认动画时长为1000毫秒。 默认值:1000 |
tempo | number | 否 | 动画播放速度。数值越大,动画播放速度越快,数值越小,播放速度越慢 值为0时,表示不存在动画。 默认值:1 |
curve | string | Curve | ICurve9+ | 否 | 设置动画曲线。默认曲线为线性。 默认值:Curve.Linear |
delay | number | 否 | 设置动画延迟执行的时长。单位为毫秒,默认不延时播放。 默认值:0 |
iterations | number | 否 | 设置播放次数。默认播放一次,设置为-1时表示无限次播放。 默认值:1 |
playMode | 否 | 设置动画播放模式,默认播放完成后重头开始播放。 默认值:PlayMode.Normal | |
onFinish | () => void | 否 | 状态回调,动画播放完成时触发。 |
示例
显式动画
更新时间: 2023-02-17 09:19
提供全局animateTo显式动画接口来指定由于闭包代码导致的状态变化插入过渡动效。
说明
从API Version 7开始支持。后续版本如有新增内容,则采用上角标单独标记该内容的起始版本。
animateTo(value: AnimateParam, event: () => void): void
参数 | 类型 | 是否必填 | 描述 |
value | AnimateParam | 是 | 设置动画效果相关参数。 |
event | () => void | 是 | 指定显示动效的闭包函数,在闭包函数中导致的状态变化系统会自动插入过渡动画。 |
AnimateParam对象说明
名称 | 类型 | 描述 |
duration | number | 动画持续时间,单位为毫秒。 默认值:1000 |
tempo | number | 动画的播放速度,值越大动画播放越快,值越小播放越慢,为0时无动画效果。 默认值:1.0 |
curve | 动画曲线。 默认值:Curve.Linear | |
delay | number | 单位为ms(毫秒),默认不延时播放。 默认值:0 |
iterations | number | 默认播放一次,设置为-1时表示无限次播放。 默认值:1 |
playMode | 设置动画播放模式,默认播放完成后重头开始播放。 默认值:PlayMode.Normal | |
onFinish | () => void | 动效播放完成回调。 |
示例
示意图:
点击第一个按钮播放改变按钮大小的动画,点击第二个按钮播放按钮顺时针旋转90度的动画。
路径动画
更新时间: 2023-02-17 09:19
设置组件进行位移动画时的运动路径。
说明
从API Version 7开始支持。后续版本如有新增内容,则采用上角标单独标记该内容的起始版本。
属性
名称 | 参数类型 | 默认值 | 描述 |
motionPath | { path: string, from?: number, to?: number, rotatable?: boolean } 说明: path中支持使用start和end进行起点和终点的替代,如: 'Mstart.x start.y L50 50 Lend.x end.y Z',更多说明请参考绘制路径。 | { '', 0.0, 1.0, false } | 设置组件的运动路径,入参说明如下: - path:位移动画的运动路径,使用svg路径字符串。 - from:运动路径的起点,默认为0.0。 - to:运动路径的终点,默认为1.0。 - rotatable:是否跟随路径进行旋转。 |
示例
![](https://s5-media.51cto.com/ost/pc/static/noavatar.gif)