【布局 widget】Flutter Align

简介: 【布局 widget】Flutter Align

image.png


Align 平时用的最多的恐怕就是居中,居左居右定位这样的功能了,实际上 Align 可以让 child 相对 Align 显示在任意位置。

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

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

child 的 Constrains

child!.layout(constraints.loosen(), parentUsesSize: true);
复制代码

Align 不会修改 constraints 的值,但会修改 tight 为 loose,这是 Align 的作用之一。

Align 的大小

如果没有 child, Align 会尽量大。

有 child ,但没有 widthFactor 和 heightFactor 参数,Align 会尽量大。

有 child, 有 widthFactor,

width = child!.size.width * ( widthFactor ?? 1.0);
复制代码

有 child, 有 heightFactor,

var height = child!.size.height * (heightFactor ?? 1.0);
复制代码

最后,Align Size 要在 constrains 的允许范围内.

如果 contrains 是 tight,widthFactor,heightFactor 没有效果。

摆放 child

Align 根据自己的尺寸和 child 的尺寸摆放 child。具体负责摆放的是 alongOffset 方法。

Offset alongOffset(Offset other) {
    final double centerX = other.dx / 2.0;
    final double centerY = other.dy / 2.0;
    return Offset(centerX + x * centerX, centerY + y * centerY);
  }
复制代码

参数 other 是要摆放的 child 的尺寸。

dx,dy 是影响 child 摆放位置的变量,代表矩形内的一个点。dx,dy 是哪里来的呢?就是我们传入的 alignment 参数,比如 Alignment.center 就相当于 0,0。

我们布局的时候,都是先确定一个矩形范围。 从一边到相对的另一边 用 [-1.0,1.0] 表示。

Alignment(-1.0, -1.0) 代表 矩形左上角

Alignment(1.0, 1.0) 代表 矩形右下角

Alignment(0.0, 3.0) 代表左右居中,正好在矩形的下面,挨着矩形。

Alignment(0.0, -0.5) 代表左右居中,垂直方向在上边和中间一半的位置

Alignment(x, y) 在矩形坐标体系中代表一个点: point (x * w/2 + w/2, y * h/2 + h/2) ,w 表示宽度,h 代表高度。

center

Center 是 Align 的子类,因为 Align 默认是 Alignment.center ,所以 Center 构造函数中不需要传 alignment 参数就是居中了。

class Center extends Align {
  /// Creates a widget that centers its child.
  const Center({ super.key, super.widthFactor, super.heightFactor, super.child });
}
复制代码

用 Cetner 的意义在于语义会更明确。如果你愿意也可以弄一个 TopLeft 出来,只不过,这样会导致类爆炸,而且也没有象 Center 这样常用。

在 Stack 中摆放子组件

image.png


Stack(
     alignment: Alignment.center,
     children: [
       Container(
         width: 50,
         height: 50,
         color: Colors.green,
       ),
       Container(
         width: 30,
         height: 30,
         color: Colors.amber,
       ),
       Align(
           alignment: Alignment.topLeft,
           child: Container(
             width: 50,
             height: 50,
             color: Colors.blue,
           ))
     ],
   )
复制代码

Stack  有 alignment 属性可以摆放所有 widget,如果想单独摆放某个 widget ,用 Align。

FractionalOffset

Align 的参数  alignment 的类型是 AlignmentGeometry,只要是 AlignmentGeometry 的子类都可以。Alignment 是AlignmentGeometry 的子类, FractionalOffset 是 Alignment 的子类,所以FractionalOffset 也可以用作 alignment 参数。  FractionalOffset 的特点是以左上角为参考点。比如 FractionalOffset(0.5,0.5)Alignment(0,0) 是等价的。

AlignmentDirectional

AlignmentDirectional 是 AlignmentGeometry 的子类,TextDirection.ltr 的条件下,效果上和 Alignment 一样。TextDirection.rtl 的条件下,效果相反。

目录
相关文章
|
12月前
|
缓存 监控 前端开发
优化 Flutter 应用启动速度的策略,涵盖理解启动过程、资源加载优化、减少初始化工作、界面布局优化、异步初始化、预加载关键数据、性能监控与分析等方面
本文探讨了优化 Flutter 应用启动速度的策略,涵盖理解启动过程、资源加载优化、减少初始化工作、界面布局优化、异步初始化、预加载关键数据、性能监控与分析等方面,并通过案例分析展示了具体措施和效果,强调了持续优化的重要性及未来优化方向。
514 10
|
11月前
|
存储 容器
Flutter 构建自适应布局
Flutter 构建自适应布局
319 2
Flutter 构建自适应布局
|
11月前
|
容器
Flutter Widget 解析
Flutter Widget 解析
149 2
|
12月前
|
开发框架 数据安全/隐私保护 开发者
Flutter 是一款强大的跨平台移动应用开发框架,本文深入探讨了其布局与样式设计
Flutter 是一款强大的跨平台移动应用开发框架,本文深入探讨了其布局与样式设计,涵盖布局基础、常用组件、样式设计、实战应用、响应式布局及性能优化等方面,助力开发者打造精美用户界面。
312 7
深入理解Flutter鸿蒙next版本 中的Widget继承:使用extends获取数据与父类约束
本文详细介绍了Flutter中如何通过继承其他Widget来创建自定义组件。首先解释了Widget继承的基本概念,包括StatelessWidget和StatefulWidget的区别。接着通过具体示例展示了如何继承StatelessWidget和StatefulWidget,并在子类中访问父类的build方法和状态。最后,结合多个自定义Widget展示了如何在实际应用中灵活使用继承和组合来构建复杂的UI。
252 8
|
开发者 容器
Flutter&鸿蒙next 布局架构原理详解
本文详细介绍了 Flutter 中的主要布局方式,包括 Row、Column、Stack、Container、ListView 和 GridView 等布局组件的架构原理及使用场景。通过了解这些布局 Widget 的基本概念、关键属性和布局原理,开发者可以更高效地构建复杂的用户界面。此外,文章还提供了布局优化技巧,帮助提升应用性能。
303 4
|
容器
flutter&鸿蒙next 使用 InheritedWidget 实现跨 Widget 传递状态
在 Flutter 中,状态管理至关重要。本文详细介绍了如何使用 InheritedWidget 实现跨 Widget 的状态传递。InheritedWidget 允许数据在 Widget 树中向下传递,适用于多层嵌套的场景。通过一个简单的计数器示例,展示了如何创建和使用 InheritedWidget,包括其基础概念、工作原理及代码实现。虽然 InheritedWidget 较底层,但它是许多高级状态管理解决方案的基础。
271 2
|
11月前
|
存储 容器
Flutter 有状态Widget 和 无状态Widget
Flutter 有状态Widget 和 无状态Widget
297 0
|
容器
深入理解 Flutter 鸿蒙版的 Stack 布局:适配屏幕与层叠样式布局
Flutter 的 Stack 布局组件允许你将多个子组件层叠在一起,实现复杂的界面效果。本文介绍了 Stack 的基本用法、核心概念(如子组件层叠、Positioned 组件和对齐属性),以及如何使用 MediaQuery 和 LayoutBuilder 实现响应式设计。通过示例展示了照片展示与文字描述、动态调整层叠布局等高级用法,帮助你构建更加精美和实用的 Flutter 应用。
520 2
Flutter&鸿蒙next 布局架构原理详解
Flutter&鸿蒙next 布局架构原理详解