【动画 widget】Flutter TweenAnimationBuilder

简介: 【动画 widget】Flutter TweenAnimationBuilder

image.png

大家好,我是 17,今天的每日 widget 为大家介绍 TweenAnimationBuilder。

Flutter TweenAnimationBuilder 继承自 ImplicitlyAnimatedWidget,它的作用是生成一个有动画功能的 StatefulWidget widget 作为复杂 widget 的一部分。

源码分析

构造函数

const TweenAnimationBuilder({
    super.key,
    required this.tween,
    required super.duration,
    super.curve,
    required this.builder,
    super.onEnd,
    this.child,
  })
复制代码

ImplicitlyAnimatedWidget 相比,增加了 tween 和 build。 tween 只有一个,不像   ImplicitlyAnimatedWidget 那样可以操作 多个 tween。

if (_currentTween!.begin != _currentTween!.end) {
      controller.forward();
 }
复制代码

ImplicitlyAnimatedWidget 不同的是,一旦发现 tween 的开始结束不一样,就立即执行动画,不用等到通过改变属性来触发。

Widget build(BuildContext context) {
    return widget.builder(context, _currentTween!.evaluate(animation), widget.child);
  }
复制代码

widget.builder 通过一个函数生成 widget,给我们可以自定义 widget 内容的能力。

@override
  void forEachTween(TweenVisitor<dynamic> visitor) {
    assert(
      widget.tween.end != null,
      'Tween provided to TweenAnimationBuilder must have non-null Tween.end value.',
    );
    _currentTween = visitor(_currentTween, widget.tween.end, (dynamic value) {
      assert(false);
      throw StateError('Constructor will never be called because null is never provided as current tween.');
    }) as Tween<T>?;
  }
复制代码

TweenAnimationBuilder 为我们复写了 forEachTween。 参数 tween.end 不能为空,实际上 ,tween.begin 也不能为空,在 initState 阶段,已经给 tween.begin 赋值。这样一来,tween 的值就是完整的。和 ImplicitlyAnimatedWidget 出场时没有动画相比, 只要 tween.begin!=tween.end 就会有出场动画。

tween.end 不为空。所以就不需要 tween 的构造函数了,visitor 中的构造函数永远不会执行。

使用 TweenAnimationBuilder

使用 TweenAnimationBuilder 要比 使用 ImplicitlyAnimatedWidget 简单的多,不需要自定义类。

还是拿上次 AnimatedWidget 正方形 的例子,看看用 TweenAnimationBuilder 如何写。

class MyAnimation extends StatefulWidget {
  const MyAnimation({super.key});
  @override
  State<MyAnimation> createState() => _MyAnimationState();
}
class _MyAnimationState extends State<MyAnimation> {
  double targetValue = 100;
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
        home: Scaffold(
            body: Center(
                child: TweenAnimationBuilder<double>(
      tween: Tween<double>(begin: 0, end: targetValue),
      builder: (context, value, child) {
        return GestureDetector(
          onTap: () {
              setState(() {
              targetValue = targetValue == 100 ? 50 : 100;
            });
          },
          child: Container(color: Colors.blue[200],width: value,height: value,),
        );
      },
      duration:const Duration(seconds: 1),
    ))));
  }
}
复制代码

效果上,动画并不能循环播放。只能是出场的时候执行一次,受到点击的时候再执行一次

和用 ImplicitlyAnimatedWidget 的实现方式相比,代码确实简洁很多。TweenAnimationBuilder 让动画 widget 以内嵌的方式嵌入到其它 widget 当中,省去了自定类。

但是 TweenAnimationBuilder 也是有他的不足的,如果要多次复用动画 Widget ,还是用直接继承 AnimatedWidget 或  juejin.cn/post/717196… 的方式比较好,并且 TweenAnimationBuilder 只能有一个 tween。

性能优化

TweenAnimationBuilder 的优化方式和 AnimatedBuilder 一样。已经说过了,不再赘述。

目录
相关文章
|
2月前
|
开发工具 UED 容器
Flutter&鸿蒙next 实现长按录音按钮及动画特效
本文介绍了如何在 Flutter 中实现一个带有动画效果的长按录音按钮。通过使用 `GestureDetector` 监听长按手势,结合 `AnimatedContainer` 和 `AnimationController` 实现按钮的动画效果,以及 `flutter_sound` 插件完成录音功能。文章详细讲解了功能需求、实现思路和代码实现,帮助读者逐步掌握这一实用功能的开发方法。
149 5
|
2月前
|
前端开发 开发者
深入探索 Flutter 鸿蒙版的画笔使用与高级自定义动画
本文深入探讨了 Flutter 中的绘图功能,重点介绍了 CustomPainter 和 Canvas 的使用方法。通过示例代码,详细讲解了如何绘制自定义图形、设置 Paint 对象的属性以及实现高级自定义动画。内容涵盖基本绘图、动画基础、渐变动画和路径动画,帮助读者掌握 Flutter 绘图与动画的核心技巧。
94 1
|
3月前
动画控制器在 Flutter 中的工作原理
【10月更文挑战第18天】总的来说,动画控制器 `AnimationController` 在 Flutter 中起着关键的作用,它通过控制动画的数值、速度、节奏和状态,实现了丰富多彩的动画效果。理解它的工作原理对于我们在 Flutter 中创建各种精彩的动画是非常重要的。
|
3月前
|
UED
flutter:动画&状态管理 (十三)
本文档介绍了Flutter中`animatedList`的使用方法和状态管理的示例。`animatedList`用于创建带有动画效果的列表,示例代码展示了如何添加、删除列表项,并执行相应的动画效果。状态管理部分通过一个简单的点击切换颜色的示例,演示了如何在Flutter中管理组件的状态。
|
5月前
|
前端开发
Flutter快速实现自定义折线图,支持数据改变过渡动画
Flutter快速实现自定义折线图,支持数据改变过渡动画
137 4
|
6月前
Flutter-实现头像叠加动画效果
Flutter-实现头像叠加动画效果
93 0
|
6月前
Flutter-加载中动画
Flutter-加载中动画
50 0
|
6月前
Flutter-自定义表情雨下落动画
Flutter-自定义表情雨下落动画
49 0
|
6月前
Flutter-数字切换动画
Flutter-数字切换动画
48 0
|
6月前
|
开发者
Flutter 动画学习
Flutter 动画学习