当前位置: 首页 > article >正文

flutter常用动画

Flutter 动画基础概念

术语解释
Animation表示动画的值,通常是一个 double (0.0 ~ 1.0) 或其他数值。
AnimationController管理动画的时间进度和状态。需要 Ticker (vsync) 来驱动。
Tween定义动画的取值范围,如从 0.0 到 1.0,从红色到蓝色。
Curve定义动画的加速度曲线,如线性、加速、减速、弹性等。
AnimatedWidget封装了动画的 Widget,如 AnimatedBuilderAnimatedContainer
AnimatedBuilder监听动画状态并重建 UI。
setState手动刷新 UI,需要与 AnimationController 配合使用。

常用动画类型

类型特点示例
隐式动画 (Implicit Animation)简单、易用,适合简单场景AnimatedContainerAnimatedOpacityAnimatedAlign
显式动画 (Explicit Animation)灵活、强大,适合复杂场景AnimationController + Tween + AnimatedBuilder
交织动画 (TweenSequence)多段组合动画,控制更复杂的曲线多阶段颜色、位置、缩放的渐变
物理动画 (Physics-based)仿真效果,如弹簧、惯性SpringSimulationFrictionSimulation
Hero 动画页面跳转时的共享元素动画Hero 小部件

示例代码

1️⃣ 隐式动画 - AnimatedContainer

class MyImplicitAnimation extends StatefulWidget {@override_MyImplicitAnimationState createState() => _MyImplicitAnimationState();
}class _MyImplicitAnimationState extends State<MyImplicitAnimation> {double _size = 100;@overrideWidget build(BuildContext context) {return Center(child: GestureDetector(onTap: () {setState(() {_size = _size == 100 ? 200 : 100;});},child: AnimatedContainer(duration: Duration(seconds: 1),width: _size,height: _size,color: Colors.blue,curve: Curves.easeInOut,),),);}
}

2️⃣ 显式动画 - AnimationController + Tween

class MyExplicitAnimation extends StatefulWidget {@override_MyExplicitAnimationState createState() => _MyExplicitAnimationState();
}class _MyExplicitAnimationState extends State<MyExplicitAnimation> with SingleTickerProviderStateMixin {late AnimationController _controller;late Animation<double> _animation;@overridevoid initState() {super.initState();_controller = AnimationController(duration: Duration(seconds: 2),vsync: this,)..repeat(reverse: true);_animation = Tween<double>(begin: 100, end: 200).animate(CurvedAnimation(parent: _controller, curve: Curves.easeInOut),);}@overridevoid dispose() {_controller.dispose();super.dispose();}@overrideWidget build(BuildContext context) {return Center(child: AnimatedBuilder(animation: _animation,builder: (context, child) {return Container(width: _animation.value,height: _animation.value,color: Colors.red,);},),);}
}
http://www.lryc.cn/news/2394403.html

相关文章:

  • Windows10下使用QEMU安装Ubuntu20.04虚拟机,并启用硬件加速
  • 《ChatGPT o3抗命:AI失控警钟还是成长阵痛?》
  • 题目 3293: 蓝桥杯2024年第十五届决赛真题-数位翻转
  • Reactor 和 Preactor
  • 【sa-token】 sa-token非 web 上下文无法获取 HttpServletRequest。
  • 论爱情《态度》
  • 多台电脑共用一个ip地址可以吗?会怎么样
  • 线程(上)【Linux操作系统】
  • FPGA中的“BPI“指什么
  • Splunk Validated Architecture (SVA):构建企业级可观测性与安全的基石
  • Python爬虫(40)基于Selenium与ScrapyRT构建高并发动态网页爬虫架构:原理、实现与性能优化
  • 深入解析 Python 字典:从基础到高级应用
  • 进程同步:生产者-消费者 题目
  • Linux轻量级文件传输——tftp命令
  • JavaSwing之--为组件添加背景
  • MySQL项目实战演练:搭建用户管理系统的完整数据库结构【MySQL系列】
  • 展会聚焦丨漫途科技亮相2025西北水务博览会!
  • 【数据结构初阶】顺序表的应用
  • 抽象工厂模式与策略模式结合使用小案例
  • C#数字图像处理(一)
  • 麻省理工新突破:家庭场景下机器人实现精准控制,real-to-sim-to-real学习助力
  • 从零实现本地语音识别(FunASR)
  • Vue 项目中 Sass 与 Less 的对比
  • Python爬虫实战:研究CherryPy库相关技术
  • 已解决:.NetCore控制台程序(WebAPI)假死,程序挂起接口不通
  • Excel如何分开查看工作表方便数据撰写
  • 微软技术赋能:解锁开发、交互与数据潜力,共探未来创新路
  • VR看房系统,新生代看房新体验
  • 【Linux笔记】Shell-脚本(下)|(常用命令详细版)
  • 钉钉热点实时推送助理-思路篇