显式动画
参考文档:
https://gitee.com/openharmony/docs/blob/5654c2b940ab3e2f4f0baf435e630c4ef3536428/zh-cn/application-dev/reference/arkui-ts/ts-explicit-animation.md
来看一个简单的示例:
@Entry
@Component
structAnimationPage{
//位移属性
@State_translate:TranslateOptions={
x:0,
y:0,
z:0
}
build(){
Flex({
alignItems:ItemAlign.Center,
justifyContent:FlexAlign.Center,
direction:FlexDirection.Column
}){
Button('执行动画').margin({bottom:50}).onClick(()=>{
//添加一个简单显式动画
animateTo({
duration:1000,//动画时长
tempo:0.5,//播放速率
curve:Curve.EaseInOut,//动画曲线
delay:0,//动画延迟
iterations:1,//播放次数
playMode:PlayMode.Normal,//动画模式
},()=>{
//闭包内更改状态
this._translate={
x:0,
y:100,
z:0
}
})
})
Column(){
Text('Animate.css')
.fontSize(50)
.fontWeight(FontWeight.Bold)
.fontColor('#351c75')
.translate(this._translate)//位移变换
}
}
.width('100%')
.height('100%')
}
}

如果我们希望向下位移完成后,再向右位移,就需要在第一个动画完成后再进行第二个动画,即在第一个动画的 onFinish 函数中执行第二个动画。

这样组合起来可以构成一个更复杂的连续动画:
//单步动画执行函数
animationStep(value:AnimateParam,event:()=>void){
return()=>{
returnnewPromise((resolve)=>{
letonFinish=value.onFinish
value.onFinish=()=>{
if(onFinish)onFinish()
resolve(true)
}
animateTo(value,event)
})
}
}
创建 4 步动画:
aboutToAppear(){
//每步动画执行时长
lettime=200
this.step1=this.animationStep({
duration:time,//动画时长
tempo:0.5,//播放速率
curve:Curve.EaseInOut,//动画曲线
delay:0,//动画延迟
iterations:1,//播放次数
playMode:PlayMode.Normal,//动画模式
onFinish:()=>{
//动画执行完成
console.info('playend')
}
},()=>{
//闭包内更改状态
this._translate={
x:0,
y:100,
z:0
}
})
this.step2=this.animationStep({
duration:time,//动画时长
tempo:0.5,//播放速率
curve:Curve.EaseInOut,//动画曲线
delay:0,//动画延迟
iterations:1,//播放次数
playMode:PlayMode.Normal,//动画模式
onFinish:()=>{
//动画执行完成
console.info('playend')
}
},()=>{
//闭包内更改状态
this._translate={
x:100,
y:100,
z:0
}
})
this.step3=this.animationStep({
duration:time,//动画时长
tempo:0.5,//播放速率
curve:Curve.EaseInOut,//动画曲线
delay:0,//动画延迟
iterations:1,//播放次数
playMode:PlayMode.Normal,//动画模式
onFinish:()=>{
//动画执行完成
console.info('playend')
}
},()=>{
//闭包内更改状态
this._translate={
x:100,
y:0,
z:0
}
})
this.step4=this.animationStep({
duration:time,//动画时长
tempo:0.5,//播放速率
curve:Curve.EaseInOut,//动画曲线
delay:0,//动画延迟
iterations:1,//播放次数
playMode:PlayMode.Normal,//动画模式
onFinish:()=>{
//动画执行完成
console.info('playend')
}
},()=>{
//闭包内更改状态
this._translate={
x:0,
y:0,
z:0
}
})
}
顺序执行 4 步动画:
Button('执行动画').margin({bottom:50}).onClick(async()=>{
awaitthis.step1()
awaitthis.step2()
awaitthis.step3()
awaitthis.step4()
})
实现 AnimateCSS 动画
AnimateCSS:
https://cdn.bootcdn.net/ajax/libs/animate.css/4.1.1/animate.css
https://animate.style/
pulse 动画:
看下 pulse 动画样式代码:
.animate__pulse{
-webkit-animation-name:pulse;
animation-name:pulse;
-webkit-animation-timing-function:ease-in-out;
animation-timing-function:ease-in-out;
}
@keyframespulse{
from{
-webkit-transform:scale3d(1,1,1);
transform:scale3d(1,1,1);
}
50%{
-webkit-transform:scale3d(1.05,1.05,1.05);
transform:scale3d(1.05,1.05,1.05);
}
to{
-webkit-transform:scale3d(1,1,1);
transform:scale3d(1,1,1);
}
}
ETS 实现:
@State_scale:ScaleOptions={
x:1,
y:1,
z:1
}
...
Column(){
Text('Animate.css')
.fontSize(50)
.fontWeight(FontWeight.Bold)
.fontColor('#351c75')
.translate(this._translate)//位移变换
.scale(this._scale)//比例变化
}
动画方法:
-
传递一个动画总时长 time
-
第一步动画执行段为 0%-50%,所以动画执行时长为总时长time * 50%
- 第二步动画执行段为 50%-100%,所以动画执行时长为总时长time * 50%
asyncpulse(time){
//0%-50%
letstep1=this.animationStep({
duration:time*0.5,//动画时长
tempo:0.5,//播放速率
curve:Curve.EaseInOut,//动画曲线
delay:0,//动画延迟
iterations:1,//播放次数
playMode:PlayMode.Normal,//动画模式
},()=>{
this._scale={
x:1.05,
y:1.05,
z:1.05
}
})
//50%-100%
letstep2=this.animationStep({
duration:time*0.5,//动画时长
tempo:0.5,//播放速率
curve:Curve.EaseInOut,//动画曲线
delay:0,//动画延迟
iterations:1,//播放次数
playMode:PlayMode.Normal,//动画模式
},()=>{
this._scale={
x:1,
y:1,
z:1
}
})
awaitstep1()
awaitstep2()
}
执行动画:
Button('执行PULSE动画').margin({bottom:50}).onClick(async()=>{
this.pulse(500)
})

审核编辑 :李倩
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。
举报投诉
-
函数
+关注
关注
3文章
4406浏览量
66834 -
Harmony
+关注
关注
0文章
108浏览量
3491
原文标题:在鸿蒙上实现AnimateCSS动画
文章出处:【微信号:gh_834c4b3d87fe,微信公众号:OpenHarmony技术社区】欢迎添加关注!文章转载请注明出处。
发布评论请先 登录
相关推荐
热点推荐
SGTools--动画控件--屏幕实现动画显示 就是这么简单
详细步骤可以观看视频,
实现动画很简单,提前准备好gif文件和一个张背景图
使用SGTools工具,就可以制作动画界面啦
视频中屏幕型号是7寸 HMT070ATA-9C
发表于 09-16 10:29
【M-K1HSE开发板免费体验】相关源码之阅读和分析1-使用XComponent + Vsync 实现自定义动画
介绍
XComponent 提供了应用在 native 侧调用 OpenGLES 图形接口的能力,本文主要介绍如何配合 Vsync 事件,完成自定义动画。在这种实现方式下,自定义动画的绘制不在 UI
发表于 09-03 16:05
分享---储能UI界面能量流动动画实现方法
本文分享 工商业储能设备的UI界面中如何实现 能量流动的动画效果。
本例子效果 基于拓普微工业级 7寸屏电容串口屏(HMT070ETA-D型号)实现:
第1步:建立工程和页面
使用SGTools新建
发表于 09-02 18:22
【EASY EAI Orin Nano开发板试用体验】使用和LVGL的anim(简易动画)和animimg(图像动画)控件组合实现复杂的动画功能
在LVGL中,实现复杂的动画功能往往需要anim和animimg两个控件组合实现的,对于anim控件来说,可以实现对obj多边形的平移,缩放
发表于 08-09 21:37
【EASY EAI Orin Nano开发板试用体验】使用Linux posix文件读取接口和LVGL的animimg(图像动画)控件实现动画播放以及
)
甚至还可以在lv_animimg控件上添加互动控件比如button,实现动态背景效果:(置底视频)
lv_animimg实现没有任何问题,然后就是LVGL定时器
发表于 07-22 00:34
用DeepSeek-R1实现自动生成Manim动画
作者:算力魔方创始人/英特尔创新大使刘力 前面我们分享了在本地运行能与OpenAI-o1 能力相媲美的DeepSeek-R1 模型。本文将介绍如何使用DeepSeek-R1实现自动生成Manim

在Harmony上实现AnimateCSS动画
评论