Flutter透明度渐变动画FadeTransition实现透明度渐变动画效果

简介: 本文章将实现在Flutter开发中通过 FadeTransition 实现透明度渐变动画效果

题记
—— 执剑天涯,从你的点滴积累开始,所及之处,必精益求精,即是折腾每一天。

** 你可能需要
CSDN 网易云课堂教程
掘金 EDU学院教程
知乎 Flutter系列文章

在这里插入图片描述

在Flutter 中实现透明度渐变效果的方式可通过以下

  • 通过 AnimatedOpacity 实现 点击查看这里
  • 通过 FadeTransition实现 就是本文了
  • 透明组件 Opacity 实现
  • 通过颜色改变实现透明度渐变效果

本文章将实现通过 FadeTransition 实现透明度渐变动画效果,实现效果如下

在这里插入图片描述
如上图所示效果,使用 FadeTransition 组件就的实现代码如下:

   ///构建渐变动画[FadeTransition]
  Widget buildSlideTransition() {
    ///实现透明渐变动画
    return FadeTransition(
      ///过渡
      opacity: controller,
      //将要执行动画的子view
      child: Container(
        width: 200,
        height: 200,
        color: Colors.red,
      ),
    );
  }

使用 FadeTransition 组件时,opacity 配置的是FadeTransition组件的透明度,在这里
opacity 属性配置的是 Animation 类型。

AnimationController 继承于 Animation,所以在这里声明了一个 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();
     },
   )

完毕

公众号 我的大前端生涯

相关文章
|
9天前
|
前端开发
Flutter快速实现自定义折线图,支持数据改变过渡动画
Flutter快速实现自定义折线图,支持数据改变过渡动画
20 4
Flutter快速实现自定义折线图,支持数据改变过渡动画
|
1月前
Flutter-实现头像叠加动画效果
Flutter-实现头像叠加动画效果
25 0
|
1月前
Flutter-加载中动画
Flutter-加载中动画
17 0
|
1月前
Flutter-自定义表情雨下落动画
Flutter-自定义表情雨下落动画
16 0
|
1月前
Flutter-数字切换动画
Flutter-数字切换动画
11 0
|
1月前
|
开发者
Flutter 动画学习
Flutter 动画学习
|
3月前
|
数据库 Android开发
Android数据库框架-GreenDao入门,2024年最新flutter 页面跳转动画
Android数据库框架-GreenDao入门,2024年最新flutter 页面跳转动画
Android数据库框架-GreenDao入门,2024年最新flutter 页面跳转动画
|
3月前
|
前端开发 开发者 UED
【Flutter前端技术开发专栏】Flutter中的动画与过渡效果实现
【4月更文挑战第30天】Flutter UI框架以其高性能动画库著称,允许开发者轻松创建复杂动画。动画基于`Animation<double>`类,结合`Tween`、`Curve`和`AnimationController`实现。简单示例展示了一个点击按钮后放大效果的创建过程。此外,Flutter提供预定义动画组件和`Navigator`类实现页面过渡。`PageRouteBuilder`允许自定义过渡,而`Hero`动画则实现跨页面的平滑过渡。借助这些工具,开发者能提升应用的视觉吸引力和交互体验。
81 0
【Flutter前端技术开发专栏】Flutter中的动画与过渡效果实现
|
3月前
|
开发框架 API 开发者
Flutter的动画:实现方式与动画库的技术探索
【4月更文挑战第26天】探索Flutter动画机制与库:基础动画、自定义动画、物理动画及Lottie、AnimatedWidgets、EasyAnimations等库的应用,助开发者实现丰富动画效果,提升用户体验。同时,了解性能优化技巧,如避免重绘、利用离屏渲染和GPU加速,确保动画流畅。 Flutter为移动应用开发带来强大动画支持。
|
3月前
|
Web App开发 前端开发 iOS开发
CSS3 转换,深入理解Flutter动画原理,前端基础图形
CSS3 转换,深入理解Flutter动画原理,前端基础图形