【布局 widget】 Flutter FractionallySizedBox

简介: 【布局 widget】 Flutter FractionallySizedBox

image.png

大家好,我是17。


FractionallySizedBox 是布局 widget,可以给 child tight 约束,多用于按比例填充空白。

BoxConstraints _getInnerConstraints(BoxConstraints constraints) {
    double minWidth = constraints.minWidth;
    double maxWidth = constraints.maxWidth;
    if (_widthFactor != null) {
      final double width = maxWidth * _widthFactor!;
      minWidth = width;
      maxWidth = width;
    }
    double minHeight = constraints.minHeight;
    double maxHeight = constraints.maxHeight;
    if (_heightFactor != null) {
      final double height = maxHeight * _heightFactor!;
      minHeight = height;
      maxHeight = height;
    }
    return BoxConstraints(
      minWidth: minWidth,
      maxWidth: maxWidth,
      minHeight: minHeight,
      maxHeight: maxHeight,
    );
  }
复制代码
void performLayout() {
    if (child != null) {
      child!.layout(_getInnerConstraints(constraints), parentUsesSize: true);
      size = constraints.constrain(child!.size);
      alignChild();
    } else {
      size = constraints.constrain(_getInnerConstraints(constraints).constrain(Size.zero));
    }
  }
复制代码

上面两段代码就是 FractionallySizedBox 的布局逻辑。我们从三个方面来描述一下。

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

确定 child constrains

constrains 是 tight ,FractionallySizedBox 透传 constrains 给 child。

constrains 是 loose,widthFactor 为空,FractionallySizedBox 透传 minWidth,maxWith 给 child;heightFactor 为空,FractionallySizedBox 透传 minHeight,maxHeight 给 child。

constrains 是 loose,widthFactor 不为空, 在 constrains 范围内 给 child 的 width tight 约束;heightFactor 不为空 在 constrains 范围内 给 child 的 height tight 约束。

举个例子:

image.png

ConstrainedBox(
    constraints: const BoxConstraints(
        minWidth: 0,
        maxWidth: 100,
        minHeight: 0,
        maxHeight: 100),
    child: FractionallySizedBox(
      widthFactor: 0.5,
      child: Container(
        color: Colors.green[400],
      ),
));
复制代码

widthFactor 不为空,child 的宽受到 tight 约束,值为 100 * 0.5 等于 50。

heightFactor 为空,FractionallySizedBox 将 约束透传给 child。Container 在没有 child 的情况下会尽量大,所以高度为 100。

widthFactor 和 heightFactor 必须大于 0,可以大于 1 ,所以 child 的大小可以超出 parent

确定自己的大小

简单来说,FractionallySizedBox 的大小不会超过 constrains 的范围。在这个前提下,FractionallySizedBox 尽量和 child 一样大。如果没有 child 尽量取 widthFactor,heightFactor 设定的值。

摆放 child

通过 alignment 参数摆放 child。只有 FractionallySizedBox 与 child 不一样大的时候才会有效果。

应用场景

按比例填充空白


image.png

Container(
  width: 100,
  height: 100,
  child: FractionallySizedBox(
    widthFactor: 0.8,
    heightFactor: 0.8,
    decoration: BoxDecoration(border: Border.all(color: Colors.blue,width: 2)),
    child: Container(
      color: Colors.green[400],
    ),
  ))
复制代码

虽然用 container 的 padding 也能做到空白,但不能弹性变化。

FractionallySizedBox 能用在 Row ,Column 中,但需要用 Flexible 包起来。

FractionallySizedBox 可以允许 child 超出父容器,做溢出效果,但是如果溢出,用 OverflowBox 可读性会更好些。


与 SizedBox 比较


SizedBox 和 FractionallySizedBox 都可以给 child tight 约束。

虽然都可以填充空白,但是场景不同。SizedBox 是在同级的兄弟之间填充空白,FractionallySizedBox 是在父子之间填充空白。

SizedBox 的 child 必须在 constrains 范围之内,FractionallySizedBox 的 child 可以超出 constrains 范围。

目录
相关文章
|
5天前
|
Android开发
Flutter完整开发实战详解(六、 深入Widget原理),2024百度Android岗面试真题收录解析
Flutter完整开发实战详解(六、 深入Widget原理),2024百度Android岗面试真题收录解析
|
6天前
|
开发框架 前端开发 搜索推荐
【Flutter前端技术开发专栏】Flutter中的自定义Widget与渲染流程
【4月更文挑战第30天】探索Flutter的自定义Widget与渲染流程。自定义Widget是实现复杂UI设计的关键,优点在于个性化设计、功能扩展和代码复用,但也面临性能优化和复杂性管理的挑战。创建步骤包括设计结构、定义Widget类、实现构建逻辑和处理交互。Flutter渲染流程涉及渲染对象树、布局、绘制和合成阶段。实践案例展示如何创建带渐变背景和阴影的自定义按钮。了解这些知识能提升应用体验并应对开发挑战。查阅官方文档以深入学习。
【Flutter前端技术开发专栏】Flutter中的自定义Widget与渲染流程
|
6天前
|
JavaScript 前端开发 开发者
【Flutter前端技术开发专栏】Flutter中的Widget与状态管理
【4月更文挑战第30天】本文探讨了Flutter的Widget和状态管理。Widget是Flutter构建UI的基础,分为有状态和无状态两种。状态管理确保UI随应用状态变化更新,影响应用性能和可维护性。文章介绍了`setState`、`Provider`、`Riverpod`、`Bloc`和`Redux`等状态管理方法,并通过计数器应用展示了其实现。选择合适的状态管理策略对高效开发至关重要。
【Flutter前端技术开发专栏】Flutter中的Widget与状态管理
|
6天前
|
前端开发 开发者 UED
Flutter的自定义Painter:深入探索自定义绘制Widget的技术实现
【4月更文挑战第26天】Flutter的自定义Painter允许开发者根据需求绘制独特UI,通过继承`CustomPaint`类和重写`paint`方法实现。在`paint`中使用`Canvas`绘制图形、路径等。创建自定义Painter类后,将其作为`CustomPaint` Widget的`painter`属性使用。此技术可实现自定义形状、渐变、动画等复杂效果,提升应用视觉体验。随着Flutter的进化,自定义Painter将提供更丰富的功能。
|
6天前
|
编解码 算法 开发者
Flutter的布局系统:深入探索布局Widget与布局原则
【4月更文挑战第26天】Flutter布局系统详解,涵盖布局Widget(Row/Column、Stack、GridView/ListView、CustomSingleChildLayout)和布局原则(弹性布局、约束优先、流式布局、简洁明了)。文章旨在帮助开发者理解并运用Flutter的布局系统,创建适应性强、用户体验佳的界面。通过选择合适的布局Widget和遵循原则,可实现复杂且高效的UI设计。
|
6天前
|
开发框架 搜索推荐 Android开发
Flutter的Widget基础:概念、分类与深入探索
【4月更文挑战第26天】Flutter Widget详解:基础、分类与工作原理。Widget是Flutter UI的核心,描述界面外观而非直接渲染。分为基础、布局、可滚动及状态管理四大类。基于响应式编程,状态变化时自动更新UI。了解其概念、分类和原理,能助开发者高效构建精美应用。随着Flutter生态发展,Widget系统潜力无限。
|
8月前
|
Dart 前端开发 开发工具
谷歌移动UI框架Flutter教程之Widget
谷歌移动UI框架Flutter教程之Widget
|
9月前
Flutter源码分析笔记:Widget类源码分析
本文记录阅读与分析Flutter源码 - Widget类源码分析。
64 0
Flutter源码分析笔记:Widget类源码分析
|
10月前
|
API Android开发 容器
Flutter控件之基类Widget封装
基类的Widget主要确定以下几个方面,第一就是,自定义一个抽象类还是非抽象类,第二、继承方式,采取有状态还是无状态,第三、关于组件的点击方式,如何进行实现。
115 0
Flutter万物皆为Widget
Flutter 中的 Widget 是描述界面元素的基本单元,可以包含视觉和交互元素。Widget 可以嵌套、组合和扩展,从而构建出复杂的 UI 界面。在 Flutter 中,Widget 可以分为两种类型:StatelessWidget 和 StatefulWidget。
Flutter万物皆为Widget