【布局 widget】Flutter FittedBox

简介: 【布局 widget】Flutter FittedBox

image.png

FittedBox 用来缩放 child 的大小,从而适应父容器的尺寸。FittedBox 给人的感觉是一看就懂,但实际上可能并没有真正理解,所以需要耐心理解每一句话的含意。

对于布局组件,我们按布局三板斧来研究。

  1. 确定 child 的 constrains
  2. 确定 自己的 大小
  3. 摆放 child

确定 child 的 constrains

performLayout 的代码说明 child 的约束是从 0 到 infinity,相当于没有约束。

child!.layout(const BoxConstraints(), parentUsesSize: true);
复制代码

为什么要为 child 放开约束呢?是为了拿到 child 的真实 size。

FittedBox 的大小

如果是 tight 约束,决定 FittedBox 大小的只有 tight 约束,值为约束的最小值。

如果是 loose 约束,决定 Fittedbox 大小的有 loose 约束和 child size。约束的作用是提供边界,child 的作用是提供比例。

FittedBox 的 child 的 大小

把 child 的真实 size 根据 fit 参数进行缩放就得到了将要展现的 size,是 chid 的最终大小。

fit 是 BoxFit 枚举值,点开链接里面有图例。我复述一下适配逻辑。

  1. fill:child 大小与 FittedBox 一样大,因为无视原来的宽高比,所以画面可能会被扭曲。
  2. contain:child 尽可能的大,只要整体还在 FittedBox 之内。
  3. cover:child 尽可能的小,只要能覆盖住 FittedBox。
  4. fitWidth:保证宽能显示完整就行。
  5. fitHeight:保证高能显示完整就行。
  6. none:child 保持原来大小,无论是比 FittedBox 大还是比 FittedBox 小。
  7. scaleDown:如果 FittedBox 放不下 child,策略同 contain,如果能放大,策略同 none。

从 1 到 5 都可能把 child 变大或变小。

7 只把 child 从大变小,但不会从小变大。

因为 child 的约束是无限,所以 child 可以无限超出 FittedBox。

摆放 child

如果要摆放 child ,FittedBox 必须和 child 的大小不一样。FittedBox size 大于或小于 chid size 的时候,根据 alignment 参数摆放 child。

触发缩放的条件

UnconstrainedBox(
   child: FittedBox(
       child: Text(
     'IAM17 Flutter 每日更新',
     style: TextStyle(fontSize: 100),
 );
复制代码

本例中,无论 fontSize 多大,都会原样显示,不会触发缩放,因为 child 的实际 size 和显示 size 相同。

所以 FittedBox 触发缩放的条件就是 child 的实际 size 和显示 size 不相同。

FittedBox 应用场景

FittedBox 给 child 的约束是无约束,如果 fit 参数再是 BoxFit.none 的话,那么 child 就被彻底放飞了。但是这样做的话,从可读性上来讲,不如 OverflowBox

比较合适的场景是图片缩放,官方举的例子也是缩放图片,但是 Image widget 自带 fit 参数,可以自己缩放的。

其它的 widget 如果缩放大概率会影响美观,所以一时想不到理想的应用场景。如果缩放不是很大,对美观度影响不大,或者不在意美观的话,倒是可以一用。

保证文字在一行显示完整

FittedBox(
    child: Text('IAM17 IAM17 IAM17'),),
)));
复制代码

FittedBox 在布局的时候会把让 Text 在没有约束的情况下布局,所以 无论 text 有多长,都不会折行。

FittedBox 的 fit 默认值是  BoxFit.contain 会保证在约束范围内显示完整。

目录
相关文章
|
15天前
深入理解Flutter鸿蒙next版本 中的Widget继承:使用extends获取数据与父类约束
本文详细介绍了Flutter中如何通过继承其他Widget来创建自定义组件。首先解释了Widget继承的基本概念,包括StatelessWidget和StatefulWidget的区别。接着通过具体示例展示了如何继承StatelessWidget和StatefulWidget,并在子类中访问父类的build方法和状态。最后,结合多个自定义Widget展示了如何在实际应用中灵活使用继承和组合来构建复杂的UI。
66 8
|
15天前
|
开发者 容器
Flutter&鸿蒙next 布局架构原理详解
本文详细介绍了 Flutter 中的主要布局方式,包括 Row、Column、Stack、Container、ListView 和 GridView 等布局组件的架构原理及使用场景。通过了解这些布局 Widget 的基本概念、关键属性和布局原理,开发者可以更高效地构建复杂的用户界面。此外,文章还提供了布局优化技巧,帮助提升应用性能。
78 4
|
13天前
|
容器
flutter&鸿蒙next 使用 InheritedWidget 实现跨 Widget 传递状态
在 Flutter 中,状态管理至关重要。本文详细介绍了如何使用 InheritedWidget 实现跨 Widget 的状态传递。InheritedWidget 允许数据在 Widget 树中向下传递,适用于多层嵌套的场景。通过一个简单的计数器示例,展示了如何创建和使用 InheritedWidget,包括其基础概念、工作原理及代码实现。虽然 InheritedWidget 较底层,但它是许多高级状态管理解决方案的基础。
88 2
|
15天前
|
容器
深入理解 Flutter 鸿蒙版的 Stack 布局:适配屏幕与层叠样式布局
Flutter 的 Stack 布局组件允许你将多个子组件层叠在一起,实现复杂的界面效果。本文介绍了 Stack 的基本用法、核心概念(如子组件层叠、Positioned 组件和对齐属性),以及如何使用 MediaQuery 和 LayoutBuilder 实现响应式设计。通过示例展示了照片展示与文字描述、动态调整层叠布局等高级用法,帮助你构建更加精美和实用的 Flutter 应用。
105 2
|
27天前
|
容器
Flutter&鸿蒙next 布局架构原理详解
Flutter&鸿蒙next 布局架构原理详解
|
1月前
|
Android开发 开发者 容器
flutter:&UI布局 (六)
本文档介绍了Flutter中的UI布局方式,包括线性布局(如Column和Row)、非线性布局(如Stack、Flex、Positioned)以及Wrap布局等。通过具体示例代码展示了如何使用这些布局组件来构建灵活多变的用户界面,例如使用Column垂直排列文本、使用Stack叠加组件、以及利用Wrap实现自动换行的按钮布局等。
|
1月前
|
容器
flutter:第一个flutter&Widget的使用 (二)
本文介绍了Flutter框架下的基本组件及其用法,包括简单的 Stateless Widget 如文本和按钮,以及更复杂的 StatefulWidget 示例。详细解释了如何使用 `context` 获取祖先小部件的信息,并展示了 `MaterialApp` 的属性及用途。此外,还探讨了 `StatefulWidget` 与 `StatelessWidget` 的区别,以及 `AppBar` 的常见属性配置方法。适合Flutter初学者参考学习。
|
13天前
|
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 在组件化架构、开发语言、布局系统、性能和跨平台支持方面各有优势
64 0
|
4月前
|
容器
flutter 布局管理【详解】
flutter 布局管理【详解】
38 3
|
4月前
Flutter-自定义折叠流布局实现
Flutter-自定义折叠流布局实现
81 0