Flutter透明度渐变动画FadeTransition实现透明度渐变动画效果
时间:2022-07-23
本文章向大家介绍Flutter透明度渐变动画FadeTransition实现透明度渐变动画效果,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
题记
—— 执剑天涯,从你的点滴积累开始,所及之处,必精益求精,即是折腾每一天。
在Flutter 中实现透明度渐变效果的方式可通过以下
本文章将实现通过 FadeTransition 实现透明度渐变动画效果,实现效果如下
如上图所示效果,使用 FadeTransition 组件就的实现代码如下:
///构建渐变动画[FadeTransition]
Widget buildSlideTransition() {
///实现透明渐变动画
return FadeTransition(
///过渡
opacity: controller,
//将要执行动画的子view
child: Container(
width: 200,
height: 200,
color: Colors.red,
),
);
}
使用 FadeTransition 组件时,opacity 配置的是FadeTransition组件的透明度,在这里
opacity 属性配置的是 Animation<double> 类型。
AnimationController 继承于 Animation<double>,所以在这里声明了一个 AnimationController 来动态的控制 透明度动态变化规律。
一般在 initState 初始化函数中进行创建,创建 AnimationController 时需要绑定一个 Ticker 来实现动画刷新帧监听,所以一般 with TickerProviderStateMixin,代码如下(代码清单1-2):
///代码清单 1-2
class _FadeTransitionPageState extends State
with TickerProviderStateMixin {
//动画控制器
AnimationController controller;
@override
void initState() {
super.initState();
///在这里 controller 的值在2秒内从0过渡到1
controller = AnimationController(
///duration 为正向执行动画的时间
duration: Duration(seconds: 2),
///反向执行动画的时间
reverseDuration: Duration(milliseconds: 3000),
///controller的变化的最小值
lowerBound: 0.0,
///controller变化的最大值
upperBound: 1.0,
///绑定页面的Ticker
vsync: this);
}
... ... 省略
}
然后在点击按钮时开始动画 如下:
RaisedButton(
child: Text('正向开启动画'),
onPressed: () {
///重置动画
controller.reset();
///向前执行
controller.forward();
},
),
通过 forward 正向开启动画 ,是从 0.0 ~ 1.0 的过程,是由不透明变为透明的过渡,然后再由1.0~0.0 是由不透明变为透明的过渡 ,反向执行一下就可以,代码如下:
RaisedButton(
child: Text('反向开启动画'),
onPressed: () {
///反向前执行
controller.reverse();
},
)
完毕
- ZooKeeper 笔记(3) 实战应用之【统一配置管理】
- 3D游戏开发之在UE4中创建非玩家角色(NPC)
- VMware Fusion DHCP方式下如何指定虚拟机IP地址
- Visual Studio 2015正式发布
- 科技巨头纷纷入局 医疗人工智能需要奋起直追?
- Windows PowerShell 工具
- 游戏开发之在UE4中编写C++代码控制角色
- Visual Studio 64位应用程序编译
- Windows 7 上安装Visual Studio 2015 失败解决方案
- Silverlight调用本机exe程序
- 游戏开发之UE4添加角色到场景中
- 人工智能取代人类?高通副总裁这样说
- Disque:Redis之父新开源的分布式内存作业队列
- mac OS X Yosemite 上编译hadoop 2.6.0/2.7.0及TEZ 0.5.2/0.7.0 注意事项
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- python中tkinter窗口位置坐标大小等实现示例
- python os模块在系统管理中的应用
- Laravel路由研究之domain解决多域名问题的方法示例
- python GUI模拟实现计算器
- 详解php命令注入攻击
- PHP设计模式之策略模式原理与用法实例分析
- python使用QQ邮箱实现自动发送邮件
- php使用lua+redis实现限流,计数器模式,令牌桶模式
- PHP whois查询类定义与用法示例
- Laravel多域名下字段验证的方法
- ThinkPHP框架整合微信支付之Native 扫码支付模式二图文详解
- 简单了解如何封装自己的Python包
- python求解汉诺塔游戏
- Python第三方包PrettyTable安装及用法解析
- 如何让python的运行速度得到提升