【布局 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 会保证在约束范围内显示完整。

目录
相关文章
|
3月前
|
编解码 前端开发 开发者
【Flutter前端技术开发专栏】Flutter中的响应式设计与自适应布局
【4月更文挑战第30天】Flutter框架助力移动应用实现响应式设计与自适应布局,通过层次化布局系统和`Widget`树管理,结合`BoxConstraints`定义尺寸范围,实现自适应。利用`MediaQuery`获取设备信息,调整布局以适应不同屏幕。`FractionallySizedBox`按比例设定尺寸,`LayoutBuilder`动态计算布局。借助这些工具,开发者能创建跨屏幕尺寸、方向兼容的应用,提升用户体验。
98 0
【Flutter前端技术开发专栏】Flutter中的响应式设计与自适应布局
|
3月前
|
开发框架 前端开发 数据安全/隐私保护
【Flutter 前端技术开发专栏】Flutter 中的布局与样式设计
【4月更文挑战第30天】本文探讨了Flutter的布局和样式设计,关键点包括:1) 布局基础如Column、Row和Stack用于创建复杂结构;2) Container、Center和Expanded等常用组件的作用;3) Theme和Decoration实现全局样式和组件装饰;4) 实战应用如登录界面和列表页面的构建;5) 响应式布局利用MediaQuery和弹性组件适应不同屏幕;6) 性能优化,避免过度复杂设计。了解并掌握这些,有助于开发者创建高效美观的Flutter应用。
86 0
【Flutter 前端技术开发专栏】Flutter 中的布局与样式设计
|
1月前
|
容器
flutter 布局管理【详解】
flutter 布局管理【详解】
21 3
|
1月前
Flutter-自定义折叠流布局实现
Flutter-自定义折叠流布局实现
28 0
|
1月前
Flutter-底部弹出框(Widget层级)
文章描述了如何在Flutter中使用DraggableScrollableSheet创建一个底部弹出框,同时保持其可手势滑动关闭。作者遇到问题并提出对原控件进行扩展,以支持头部和列表布局的滑动关闭功能。
70 0
|
2月前
Flutter StreamBuilder 实现局部刷新 Widget
Flutter StreamBuilder 实现局部刷新 Widget
22 0
|
3月前
|
Android开发
Flutter完整开发实战详解(六、 深入Widget原理),2024百度Android岗面试真题收录解析
Flutter完整开发实战详解(六、 深入Widget原理),2024百度Android岗面试真题收录解析
|
3月前
|
开发框架 前端开发 搜索推荐
【Flutter前端技术开发专栏】Flutter中的自定义Widget与渲染流程
【4月更文挑战第30天】探索Flutter的自定义Widget与渲染流程。自定义Widget是实现复杂UI设计的关键,优点在于个性化设计、功能扩展和代码复用,但也面临性能优化和复杂性管理的挑战。创建步骤包括设计结构、定义Widget类、实现构建逻辑和处理交互。Flutter渲染流程涉及渲染对象树、布局、绘制和合成阶段。实践案例展示如何创建带渐变背景和阴影的自定义按钮。了解这些知识能提升应用体验并应对开发挑战。查阅官方文档以深入学习。
49 0
【Flutter前端技术开发专栏】Flutter中的自定义Widget与渲染流程
|
3月前
|
JavaScript 前端开发 开发者
【Flutter前端技术开发专栏】Flutter中的Widget与状态管理
【4月更文挑战第30天】本文探讨了Flutter的Widget和状态管理。Widget是Flutter构建UI的基础,分为有状态和无状态两种。状态管理确保UI随应用状态变化更新,影响应用性能和可维护性。文章介绍了`setState`、`Provider`、`Riverpod`、`Bloc`和`Redux`等状态管理方法,并通过计数器应用展示了其实现。选择合适的状态管理策略对高效开发至关重要。
37 0
【Flutter前端技术开发专栏】Flutter中的Widget与状态管理
|
3月前
|
编解码 算法 开发者
Flutter的布局系统:深入探索布局Widget与布局原则
【4月更文挑战第26天】Flutter布局系统详解,涵盖布局Widget(Row/Column、Stack、GridView/ListView、CustomSingleChildLayout)和布局原则(弹性布局、约束优先、流式布局、简洁明了)。文章旨在帮助开发者理解并运用Flutter的布局系统,创建适应性强、用户体验佳的界面。通过选择合适的布局Widget和遵循原则,可实现复杂且高效的UI设计。