news 2026/4/16 19:45:34

鸿蒙动画系统解密:实现一个“果冻回弹”效果,彻底搞懂属性动画与转场动画

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
鸿蒙动画系统解密:实现一个“果冻回弹”效果,彻底搞懂属性动画与转场动画

🎢 前言:为什么你的动画看起来很“假”?

很多开发者写动画喜欢用默认的EaseInOut
但在真实物理世界中,物体运动是有惯性的。

  • 假的动画:A 点匀速移动到 B 点,像个机器人。
  • 真的动画:启动有加速,停止有减速,撞击有回弹(Overshoot)。

鸿蒙的 ArkUI 提供了curves.interpolatingSpring(插值弹簧),它模拟了真实的物理弹簧系统。我们不需要算复杂的微积分,只需要调节“硬度”和“阻尼”。


🏗️ 一、 核心概念:属性动画 vs 转场动画

在写代码前,必须分清这两个概念,否则你的动画要么不跑,要么乱跑。

动画原理对比 (Mermaid):

转场动画 (.transition)

修改变量 this.show = true

播放 Opacity/Scale 变化

组件不存在 (if false)

触发入场动画

组件存在 (UI树中)

用于: 组件的出现 (Insert) 和消失 (Remove)

属性动画 (.animation)

修改变量 this.w = 200

自动生成中间帧

状态 A (宽 100)

触发补间计算

状态 B (宽 200)

用于: 已经在屏幕上的组件发生变化


🍮 二、 实战 1:制作“果冻”按钮 (属性动画)

我们要实现的效果:

  1. 按压时:按钮缩小到 90%,有点“紧绷”的感觉。
  2. 松开时:按钮恢复到 100%,并带有“Duang Duang”的回弹。
1. 核心代码

ArkUI 的核心是“状态驱动 UI”。我们只需要改变scaleOptions的数值,配合.animation()属性,剩下的交给系统。

import{curves}from'@kit.ArkUI';@Entry@Componentstruct JellyButton{// 1. 定义状态:缩放比例@StatescaleValue:number=1;build(){Column(){// 一个看起来很好吃的按钮Button("按我体验果冻效果").width(200).height(60).backgroundColor('#FF6B6B').fontSize(20).borderRadius(30)// 2. 绑定状态:UI 随状态变化.scale({x:this.scaleValue,y:this.scaleValue})// 3. 【关键】添加属性动画// 只要上面的 scale 发生变化,这个动画就会触发.animation({// 使用插值弹簧曲线// velocity: 初始速度// mass: 质量 (越重回弹越慢)// stiffness: 刚度 (越硬回弹越快,像强力弹簧)// damping: 阻尼 (越小回弹次数越多,像果冻;越大越不弹)curve:curves.interpolatingSpring(10,1,228,15)})// 4. 交互逻辑.onTouch((event:TouchEvent)=>{if(event.type===TouchType.Down){// 按下:缩小,模拟受力this.scaleValue=0.9;}elseif(event.type===TouchType.Up){// 松开:恢复,触发弹簧回弹this.scaleValue=1;}})}.width('100%').height('100%').justifyContent(FlexAlign.Center)}}
💡 调参秘籍
  • 想让果冻更软、晃动更久?减小damping(阻尼),比如设为 8。
  • 想让按键反应更灵敏?增加stiffness(刚度),比如设为 300。

🚪 三、 实战 2:丝滑的入场 (转场动画)

当你点击果冻按钮后,弹出一张卡片。这时候就要用转场动画 (transition)
在鸿蒙 Next 中,推荐使用TransitionEffect组合链式语法。

@StateshowCard:boolean=false;// ... 在 build 中if(this.showCard){Text("我是弹出的卡片").width(300).height(200).backgroundColor('#4ECDC4').borderRadius(20).textAlign(TextAlign.Center).fontSize(24).fontColor(Color.White)// 【关键】定义入场和出场效果// 1. 初始状态:透明度为0,缩放为0.5,且向下偏移 50vp.transition(TransitionEffect.OPACITY.combine(TransitionEffect.scale({x:0.5,y:0.5})).combine(TransitionEffect.translate({y:50}))// 2. 动画参数:同样可以使用弹簧曲线!.animation({curve:curves.springMotion(0.6,0.8)}))}Button("切换显示").onClick(()=>{// animateTo 是为了让 if/else 的渲染过程也有动画animateTo({curve:curves.springMotion()},()=>{this.showCard=!this.showCard;})})

🎨 四、 显式动画 (animateTo) vs 属性动画 (.animation)

很多新手会晕:到底该用哪个?

场景推荐方式代码特征
单个组件的简单交互属性动画 (.animation)写在组件链式调用的末尾,随 State 变化自动触发。
多个组件联动 / 复杂逻辑显式动画 (animateTo)animateTo({ duration: 1000 }, () => { this.w = 200 })
组件的出现/消失转场动画 (.transition)必须配合if/elseVisibility控制。

🎯 总结

鸿蒙的动画系统并不神秘,它其实比 Android 原生的ObjectAnimator更直观。
你不需要去计算每一帧的坐标,你只需要告诉系统:

  1. 开始是什么样(State A)。
  2. 结束是什么样(State B)。
  3. 中间怎么走(Curve 曲线)。

只要你用好了curves.interpolatingSpring,你的 App 瞬间就能拥有“果冻般”的高级质感。

Next Step:
把上面的代码复制到 DevEco Studio 中。尝试修改interpolatingSpring的第 4 个参数(阻尼),将其从15改为5,看看按钮会不会像疯狂的果冻一样弹个不停!

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 19:03:38

腾讯开源HY-MT1.5值不值?两大版本部署体验全面评测

腾讯开源HY-MT1.5值不值?两大版本部署体验全面评测 随着多语言交流需求的不断增长,高质量、低延迟的翻译模型成为AI应用落地的关键组件。腾讯近期开源了其混元翻译大模型1.5版本(HY-MT1.5),包含两个参数量级的模型&am…

作者头像 李华
网站建设 2026/4/16 15:03:46

HY-MT1.5-7B企业级部署案例:跨国会议同声传译系统搭建实录

HY-MT1.5-7B企业级部署案例:跨国会议同声传译系统搭建实录 随着全球化进程加速,跨国会议对高质量、低延迟的同声传译需求日益增长。传统商业翻译API在隐私保护、定制化支持和部署灵活性方面存在局限,难以满足企业级高安全、高实时性的场景要…

作者头像 李华
网站建设 2026/4/16 12:03:02

如何实现中文人名地名自动抽取?RaNER部署实战案例详解

如何实现中文人名地名自动抽取?RaNER部署实战案例详解 1. 引言:AI 智能实体侦测服务的现实需求 在当今信息爆炸的时代,非结构化文本数据(如新闻、社交媒体、文档)占据了数据总量的80%以上。如何从这些杂乱无章的文字…

作者头像 李华
网站建设 2026/4/16 13:36:42

10.2 磁悬浮轴承:智能控制与扰动抑制

10.2 智能控制与扰动抑制 磁悬浮轴承系统在复杂工程环境(如航空航天、车载储能、精密加工装备)中运行时,会面临远超实验室条件的各类复杂外部与内部扰动。这些扰动通常具有宽频谱、强耦合、非线性、时变甚至部分不可测等特征,严重挑战基于线性定常模型的经典PID控制(第7.…

作者头像 李华
网站建设 2026/4/16 13:36:39

AI智能实体侦测服务在电商商品描述分析中的应用

AI智能实体侦测服务在电商商品描述分析中的应用 1. 引言:AI 智能实体侦测服务的业务价值 在电商平台中,每天都有海量的商品描述文本被创建和更新。这些文本通常是非结构化的自由描述,包含品牌名、产地、适用人群、材质成分等关键信息。传统…

作者头像 李华