【动画 widget】Flutter SizeTransition

简介: 【动画 widget】Flutter SizeTransition

image.png


SizeTransition 用裁剪,摆放 child 的方式让 child 产生动画效果。

本来 SizeTransition 继承自 AnimatedWidget 没什么好讲的,掌握 AnimatedWidget 就足够了, 但是他产生动画的方式有点出乎意料。不是像直觉那样,改变 child 的 width,height。他是通过 clip + align 做动画,这样组合起来,可以产生的动画效果一下子丰富起来。如果不事先有个印象,知道 SizeTransition 能做出怎样的效果,用的时候,可能不一定能想起他来。

源码分析

Widget build(BuildContext context) {
    final AlignmentDirectional alignment;
    if (axis == Axis.vertical) {
      alignment = AlignmentDirectional(-1.0, axisAlignment);
    } else {
      alignment = AlignmentDirectional(axisAlignment, -1.0);
    }
    return ClipRect(
      child: Align(
        alignment: alignment,
        heightFactor: axis == Axis.vertical ? math.max(sizeFactor.value, 0.0) : null,
        widthFactor: axis == Axis.horizontal ? math.max(sizeFactor.value, 0.0) : null,
        child: child,
      ),
    );
}
复制代码

由两个 widget 嵌套而成。 sizeFactor.value 从 0 到 1,Align 的大小由 0 到 child size。如果没有 ClipRect ,在我们看来,child size 在视觉上 不会发生变化。Align size 虽然变小了,但却不能把 child 溢出的部分 clip 。外面加上 ClipRect 后,默认会把 child 溢出的部分 clip,我们就能看到 child size 的变化了。

使用 SizeTransition

最重要的是要对 SizeTransition 的效果有个印象,以便后面需要的时候能想起来。

image.png

Container(
    width: 100,
    height: 100,
    alignment: Alignment.topLeft,
    child: SizeTransition(
        axis:Axis.vertical,
        axisAlignment: -1,
        sizeFactor: controller,
        child: FlutterLogo(
          size: 100,)));
复制代码
  • 父级  alignment: Alignment.topLeft
  • SizeTransition  axisAlignment: -1,内部转换为  AlignmentDirectional(-1.0, -1.0)

使用 SizeTransition 的时候,需要注意确定好 alignment。比如本例,SizeTransition 左上角对齐,child 也是左上角对齐。child size 变化的时候,就会有从上向下展示的效果。

其实也很简单,只要保证 SizeTransition 父级的对齐和 child 的对齐方式一致就可以,比如由中间开始向外扩展的效果。

image.png

Container(
   width: 100,
   height: 100,
   alignment: Alignment.center,
   child: SizeTransition(
       axis:Axis.vertical,
       axisAlignment: 0,
       sizeFactor: controller,
       child: FlutterLogo(
         size: 100,
       )));
复制代码
  • 父级  alignment: Alignment.center
  • SizeTransition  axisAlignment: 0,内部转换为   AlignmentDirectional(0.0, 0.0)

还可以从下向上展示。

image.png

Container(
  width: 100,
  height: 100,
  alignment: Alignment.bottomLeft,
  child: SizeTransition(
      axis:Axis.vertical,
      axisAlignment: 1,
      sizeFactor: controller,
      child: FlutterLogo(
        size: 100,
      )));
复制代码
  • 父级  alignment: Alignment.bottomLeft
  • SizeTransition  axisAlignment: 1,内部转换为   AlignmentDirectional(-1.0, 1.0)

除了这三种,还有水平的三种,一共六种动画展示方式。只要保证 SizeTransition 在父级的对齐和 SizeTransition 的对齐方式一致就可以,就可以达成相应的效果。

目录
相关文章
|
1月前
|
容器
Flutter Widget 解析
Flutter Widget 解析
|
1月前
|
存储 容器
Flutter 有状态Widget 和 无状态Widget
Flutter 有状态Widget 和 无状态Widget
|
2月前
深入理解Flutter鸿蒙next版本 中的Widget继承:使用extends获取数据与父类约束
本文详细介绍了Flutter中如何通过继承其他Widget来创建自定义组件。首先解释了Widget继承的基本概念,包括StatelessWidget和StatefulWidget的区别。接着通过具体示例展示了如何继承StatelessWidget和StatefulWidget,并在子类中访问父类的build方法和状态。最后,结合多个自定义Widget展示了如何在实际应用中灵活使用继承和组合来构建复杂的UI。
99 8
|
2月前
|
开发工具 UED 容器
Flutter&鸿蒙next 实现长按录音按钮及动画特效
本文介绍了如何在 Flutter 中实现一个带有动画效果的长按录音按钮。通过使用 `GestureDetector` 监听长按手势,结合 `AnimatedContainer` 和 `AnimationController` 实现按钮的动画效果,以及 `flutter_sound` 插件完成录音功能。文章详细讲解了功能需求、实现思路和代码实现,帮助读者逐步掌握这一实用功能的开发方法。
149 5
|
2月前
|
容器
flutter&鸿蒙next 使用 InheritedWidget 实现跨 Widget 传递状态
在 Flutter 中,状态管理至关重要。本文详细介绍了如何使用 InheritedWidget 实现跨 Widget 的状态传递。InheritedWidget 允许数据在 Widget 树中向下传递,适用于多层嵌套的场景。通过一个简单的计数器示例,展示了如何创建和使用 InheritedWidget,包括其基础概念、工作原理及代码实现。虽然 InheritedWidget 较底层,但它是许多高级状态管理解决方案的基础。
118 2
|
2月前
|
前端开发 开发者
深入探索 Flutter 鸿蒙版的画笔使用与高级自定义动画
本文深入探讨了 Flutter 中的绘图功能,重点介绍了 CustomPainter 和 Canvas 的使用方法。通过示例代码,详细讲解了如何绘制自定义图形、设置 Paint 对象的属性以及实现高级自定义动画。内容涵盖基本绘图、动画基础、渐变动画和路径动画,帮助读者掌握 Flutter 绘图与动画的核心技巧。
94 1
|
3月前
动画控制器在 Flutter 中的工作原理
【10月更文挑战第18天】总的来说,动画控制器 `AnimationController` 在 Flutter 中起着关键的作用,它通过控制动画的数值、速度、节奏和状态,实现了丰富多彩的动画效果。理解它的工作原理对于我们在 Flutter 中创建各种精彩的动画是非常重要的。
|
3月前
|
容器
flutter:第一个flutter&Widget的使用 (二)
本文介绍了Flutter框架下的基本组件及其用法,包括简单的 Stateless Widget 如文本和按钮,以及更复杂的 StatefulWidget 示例。详细解释了如何使用 `context` 获取祖先小部件的信息,并展示了 `MaterialApp` 的属性及用途。此外,还探讨了 `StatefulWidget` 与 `StatelessWidget` 的区别,以及 `AppBar` 的常见属性配置方法。适合Flutter初学者参考学习。
|
2月前
|
Dart JavaScript 前端开发
Flutter 的 Widget 概述与常用 Widgets 与鸿蒙 Next 的对比
Flutter 是 Google 开发的开源 UI 框架,用于快速构建高性能的移动、Web 和桌面应用。Flutter 通过 Widget 构建 UI,每个 UI 元素都是 Widget,包括文本、按钮、图片等。Widget 不仅描述外观,还描述行为,是不可变的。常见的 Widget 包括结构型(Container、Column、Row)、呈现型(Text、Image)、交互型(ElevatedButton)和状态管理型(StatefulWidget)。Flutter 与鸿蒙 Next 在组件化架构、开发语言、布局系统、性能和跨平台支持方面各有优势
91 0
|
3月前
|
UED
flutter:动画&状态管理 (十三)
本文档介绍了Flutter中`animatedList`的使用方法和状态管理的示例。`animatedList`用于创建带有动画效果的列表,示例代码展示了如何添加、删除列表项,并执行相应的动画效果。状态管理部分通过一个简单的点击切换颜色的示例,演示了如何在Flutter中管理组件的状态。