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

Flutter中动画的实现

       动画三要素

        控制动画的三要素:Animation、Tween、和AnmaitionController

        Animation: 产生的值的序列,有CurveAnimation等子类,, 可以将值赋值给Widget的宽高或其他属性,进而控制widget发生变化

        Tween:可以定义值的变化范围,  继承自Animatable<T>,每个类都有begin和end两个属性,同时有CurveTween等子类,可以定义值在begin和end间的变化方式。

        AnimationController: 动画的控制器,可以设置动画的时长,控制动画开始或者结束等

        有两种方式生成Animation:

      (1)_controller.drive(_curveTween)

      (2)_curveTween.animate(_controller)     

       

        Widget动画相关属性

        (1)Container的width、height, 控制Widget大小

        (2)SlideTransition 的position, 通过Tween<Offset>控制Widget的位移

        (3) Align的heightFactor, 控制Widget的展开或收起

        (4) AnimatedOpacity的opacity属性,控制Widget的渐隐渐显

        两种动画实现方式

         Flutter中动画主要有两种实现方式,即通过addListener监听Animation的值的变化, 或者用AnimationBuilder来构建参与动画的Widget。

        下面看一个通过addListener实现动画的例子

//动画控制器
final AnimationController controller = new AnimationController(duration: const Duration(milliseconds: 500), vsync: this);
//创建一个值的序列,其变化方式为Curve中的淡出效果
final Animation curve =new CurvedAnimation(parent: controller, curve: Curves.easeOut);
//通过tween指定值的变化范围为0~255
Animation<int> animation = new IntTween(begin: 0, end: 255).animate(curve);
//监听动画状态的变化: 动画是否结束
..addStatusListener((status) {if (status == AnimationStatus.completed) {controller.reverse();} else if (status == AnimationStatus.dismissed) {controller.forward();}})
//监听Animation的值的变化,更新UI
..addListener(() {setState(() {// 将animation.value赋值给指定的Widget的属性_opacity = animation.value.toDouble() / 255;});      });//动画开始    
controller.forward();

        再看下如何通过AnimationBuilder构建动画:

Widget build(BuildContext context) => Center(child: AnimatedBuilder(animation: animation,builder: (context, child) => Container(height: animation.value,width: animation.value,child: child,),child: child),);
}

        不难看出,使用AnimationBuilder来实现动画效果,代码要简洁的多,是更为推荐的实现方式。

相关文章:

Flutter中动画的实现

动画三要素 控制动画的三要素&#xff1a;Animation、Tween、和AnmaitionController Animation&#xff1a; 产生的值的序列&#xff0c;有CurveAnimation等子类&#xff0c;&#xff0c; 可以将值赋值给Widget的宽高或其他属性&#xff0c;进而控制widget发生变化 Tween&#…...

Elasticsearch从入门到精通-03基本语法学习

Elasticsearch从入门到精通-03基本语法学习 &#x1f44f;作者简介&#xff1a;大家好&#xff0c;我是程序员行走的鱼 &#x1f4d6; 本篇主要介绍和大家一块学习一下ES基本语法,主要包括索引管理、文档管理、映射管理等内容 1.1 了解Restful ES对数据进行增、删、改、查是以…...

【黑马程序员】STL实战--演讲比赛管理系统

文章目录 演讲比赛管理系统需求说明比赛规则程序功能 创建管理类功能描述创建演讲比赛管理类 菜单功能添加菜单成员函数声明菜单成员函数实现菜单功能测试 退出功能添加退出功能声明退出成员函数实现退出功能测试 演讲比赛功能功能分析创建选手类比赛成员属性添加初始化属性创建…...

一文帮助快速入门Django

文章目录 创建django项目应用app配置pycharm虚拟环境打包依赖 路由传统路由include路由分发namenamespace 视图中间件orm关系对象映射操作表数据库配置model常见字段及参数orm基本操作 cookie和sessiondemo类视图 创建django项目 指定版本安装django&#xff1a;pip install dj…...

基于springboot实现图书推荐系统项目【项目源码+论文说明】计算机毕业设计

基于springboot实现图书馆推荐系统演示 摘要 时代的变化速度实在超出人类的所料&#xff0c;21世纪&#xff0c;计算机已经发展到各行各业&#xff0c;各个地区&#xff0c;它的载体媒介-计算机&#xff0c;大众称之为的电脑&#xff0c;是一种特高速的科学仪器&#xff0c;比…...

微信小程序实现上拉加载更多

一、前情提要 微信小程序中实现上拉加载更多&#xff0c;其实就是pc端项目的分页。使用的是scroll-view&#xff0c;scroll-view详情在微信开发文档/开发/组件/视图容器中。每次上拉&#xff0c;就是在原有数据基础上&#xff0c;拼接/合并上本次上拉请求得到的数据。这里采用…...

计算机网络——概述

计算机网络——概述 计算机网络的定义互连网&#xff08;internet&#xff09;互联网&#xff08;Internet&#xff09;互联网基础结构发展的三个阶段第一个阶段——APPANET第二阶段——商业化和三级架构第三阶段——全球范围多层次的ISP结构 ISP的作用终端互联网的组成边缘部分…...

kafka Interceptors and Listeners

Interceptors ProducerInterceptor https://www.cnblogs.com/huxi2b/p/7072447.html Producer拦截器(interceptor)是个相当新的功能&#xff0c;它和consumer端interceptor是在Kafka 0.10版本被引入的&#xff0c;主要用于实现clients端的定制化控制逻辑。 对于producer而言&…...

【面试题】mysql常见面试题及答案总结

事务中的ACID原则是什么? Mysql是如何实现或者保障ACID的? ACID原则是数据库事务管理中必须满足的四个基本属性&#xff0c;确保了数据库事务的可靠性和数据完整性。 简写全称解释实现A原子性&#xff08;Atomicity&#xff09;一个事务被视为一个不可分割的操作序列&#…...

C++ 类的前向声明的用法

我们知道C的类应当是先定义&#xff0c;然后使用。但在处理相对复杂的问题、考虑类的组合时&#xff0c;很可能遇到俩个类相互引用的情况&#xff0c;这种情况称为循环依赖。 例如&#xff1a; class A { public:void f(B b);//以B类对象b为形参的成员函数//这里编译错位&…...

二分查找(c语言)

二分查找 一.什么是二分查找二.代码实现 一.什么是二分查找 在⼀个升序的数组中查找制定的数字n&#xff0c;很容易想到的⽅法就是遍历数组&#xff0c;但是这种⽅法效率⽐较低&#xff0c; ⽐如我买了⼀双鞋&#xff0c;你好奇问我多少钱&#xff0c;我说不超过300元。你还是好…...

【记录31】elementUI el-tree 虚线、右键、拖拽

父组件 <eltree :treeData"treeData"></eltree>import eltree from "../../components/tree.vue"; export default {name: ,components: { // org_tree ,eltree},watch: {},data() {return {orgFormchoose: {},orgForm: { type: 0, limits: 1…...

【C++】函数重载

&#x1f984;个人主页:修修修也 &#x1f38f;所属专栏:C ⚙️操作环境:Visual Studio 2022 目录 &#x1f4cc;函数重载的定义 &#x1f4cc;函数重载的三种类型 &#x1f38f;参数个数不同 &#x1f38f;参数类型不同 &#x1f38f;参数类型顺序不同 &#x1f4cc;重载…...

【深度学习模型】6_3 语言模型数据集

注&#xff1a;本文为《动手学深度学习》开源内容&#xff0c;部分标注了个人理解&#xff0c;仅为个人学习记录&#xff0c;无抄袭搬运意图 6.3 语言模型数据集&#xff08;周杰伦专辑歌词&#xff09; 本节将介绍如何预处理一个语言模型数据集&#xff0c;并将其转换成字符级…...

技术选型思考:分库分表和分布式DB(TiDB/OceanBase) 的权衡与抉择

码到三十五 &#xff1a; 个人主页 心中有诗画&#xff0c;指尖舞代码&#xff0c;目光览世界&#xff0c;步履越千山&#xff0c;人间尽值得 ! 在当今数据爆炸的时代&#xff0c;数据库作为存储和管理数据的核心组件&#xff0c;其性能和扩展性成为了企业关注的重点。随着业…...

React改变数据【案例】

State传统方式 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>React Demo</title> <!--…...

ChatGPT Plus 自动扣费失败,如何续订

ChatGPT Plus 自动扣费失败&#xff0c;如何续订 如果您的 ChatGPT Plus 订阅过期或扣费失败&#xff0c;本教程将指导您如何重新订阅。 本周更新 ChatGPT Plus 是一种每月20美元的订阅服务。扣费会自动进行&#xff0c;如果您的账户余额不足&#xff0c;OpenAI 将在一次扣费…...

Rust: Channel 代码示例

在 Rust 中&#xff0c;通道&#xff08;Channel&#xff09;通常使用 std::sync::mpsc&#xff08;多生产者单消费者&#xff09;或 tokio::sync::mpsc&#xff08;在异步编程中&#xff0c;特别是使用 Tokio 运行时&#xff09;来创建。下面是一个使用 std::sync::mpsc 的简单…...

基于华为atlas的unet分割模型探索

Unet模型使用官方基于kaggle Carvana Image Masking Challenge数据集训练的模型。 模型输入为572*572*3&#xff0c;输出为572*572*2。分割目标分别为&#xff0c;0&#xff1a;背景&#xff0c;1&#xff1a;汽车。 Pytorch的pth模型转化onnx模型&#xff1a; import torchf…...

机器学习--循环神经网络(RNN)1

一、简介 循环神经网络&#xff08;Recurrent Neural Network&#xff09;是深度学习领域中一种非常经典的网络结构&#xff0c;在现实生活中有着广泛的应用。以槽填充&#xff08;slot filling&#xff09;为例&#xff0c;如下图所示&#xff0c;假设订票系统听到用户说&…...

告别串口调试乱码!深入理解波特率、时钟与SBUF的避坑实战指南

串口通信乱码全解析&#xff1a;从时钟源到SBUF的精准调试手册 当你盯着屏幕上那一串毫无意义的乱码字符时&#xff0c;内心是否充满了挫败感&#xff1f;串口通信作为嵌入式开发中最基础却又最常出问题的环节&#xff0c;其稳定性直接影响着整个系统的可靠性。本文将带你深入串…...

Mac Mouse Fix:让普通鼠标在macOS上拥有触控板般的流畅体验

Mac Mouse Fix&#xff1a;让普通鼠标在macOS上拥有触控板般的流畅体验 【免费下载链接】mac-mouse-fix Mac Mouse Fix - Make Your $10 Mouse Better Than an Apple Trackpad! 项目地址: https://gitcode.com/GitHub_Trending/ma/mac-mouse-fix 你是否曾经在macOS上使用…...

rust 1.95.0 最新版发布:语言特性、编译器、平台支持、标准库、Rustdoc 与兼容性变更全解析

rust 1.95.0 最新版发布&#xff1a;语言特性、编译器、平台支持、标准库、Rustdoc 与兼容性变更全解析 2026年4月16日&#xff0c;Rust 1.95.0 正式发布。作为一次重要版本更新&#xff0c;这一版在语言层、编译器、平台支持、标准库、Rustdoc 以及兼容性方面都带来了相当丰富…...

别再死记硬背LSTM公式了!用PyTorch手写一个BiLSTM,从代码里看懂数据怎么‘流’

从零实现BiLSTM&#xff1a;用PyTorch代码透视数据流动本质 当你第一次看到LSTM那复杂的门控结构图时&#xff0c;是否曾被各种箭头和符号搞得晕头转向&#xff1f;作为NLP领域的核心模型之一&#xff0c;双向长短期记忆网络(BiLSTM)在文本分类、命名实体识别等任务中表现出色&…...

从理论到实践:在PyTorch 2.8镜像中复现经典算法论文

从理论到实践&#xff1a;在PyTorch 2.8镜像中复现经典算法论文 1. 引言&#xff1a;算法复现的价值与挑战 复现经典论文算法是每个深度学习研究者的必修课。最近我在星图GPU平台上使用PyTorch 2.8镜像&#xff0c;尝试复现了一篇关于高效Transformer的论文&#xff0c;整个过…...

10分钟搞定《Degrees of Lewdity》中文本地化:从零开始到完整汉化体验

10分钟搞定《Degrees of Lewdity》中文本地化&#xff1a;从零开始到完整汉化体验 【免费下载链接】Degrees-of-Lewdity-Chinese-Localization Degrees of Lewdity 游戏的授权中文社区本地化版本 项目地址: https://gitcode.com/gh_mirrors/de/Degrees-of-Lewdity-Chinese-Lo…...

MySQL AUDIT_LOG_FORMAT_UNIX_TIMESTAMP_ONLY_WHEN_JSON报错

SET GLOBAL audit_log_format JSON; SET GLOBAL audit_log_policy ALL; FLUSH BINARY LOGS; 这就是远程修复的核心命令&#xff0c;确保在JSON格式下只使用Unix时间戳&#xff0c;避免报错。备份数据后执行&#xff1a;mysql -h host -u user -p -e "SET GLOBAL audit_l…...

Z-Image Turbo免配置环境实战:快速搭建个人绘画平台

Z-Image Turbo免配置环境实战&#xff1a;快速搭建个人绘画平台 1. 项目概述 Z-Image Turbo是一个基于Gradio和Diffusers构建的高性能AI绘图Web界面&#xff0c;专门为Z-Image-Turbo模型优化设计。这个平台最大的特点就是开箱即用&#xff0c;无需复杂的环境配置&#xff0c;…...

深度解析ncmdump:高效破解网易云音乐NCM加密格式实战指南

深度解析ncmdump&#xff1a;高效破解网易云音乐NCM加密格式实战指南 【免费下载链接】ncmdump 项目地址: https://gitcode.com/gh_mirrors/ncmd/ncmdump 还在为网易云音乐下载的NCM格式文件无法在第三方播放器播放而烦恼吗&#xff1f;ncmdump作为一款专业的NCM格式解…...

全网最简:应届生面试通关手册

文章目录前言一、面试前&#xff1a;简历是你的第一张脸&#xff0c;千万别瞎写1.1 简历的核心逻辑&#xff1a;用数据说话&#xff0c;拒绝假大空1.2 技术栈选择&#xff1a;贴合2026年招聘需求&#xff0c;不追冷门1.3 项目经历&#xff1a;挑“能讲清楚”的&#xff0c;别贪…...