Flutter 多子 Widget 布之Stack、Positioned

article/2025/9/28 10:36:56

文章目录

    • 层叠 Widget 布局
      • Stack
        • alignment
        • fit
        • overflow
      • Positioned

  • 上文 Flutter 多子 Widget 布局之Flex、Expanded、Wrap、Flow,介绍了弹性布局 Flex、Expanded和流式布局Wrap、Flow
  • 再上文 Flutter 多子 Widget 布局之线性布局 Row、Column,介绍了线性布局Row、Column组件

层叠 Widget 布局

层叠布局,类似于Android中的FrameLayout,可以将布局叠加在另一个布局上。
Flutter中可以通过StackPositioned来实现相同的效果。

Stack

将控件叠加在另一个控件的上面,比如在一张图片上放置一段文字。

查看构造函数,看看都支持哪些属性:

Stack({Key key,this.alignment = AlignmentDirectional.topStart,// 定位方向this.textDirection,// 和 Row Column 中一致,用于决定控件的摆放方向this.fit = StackFit.loose,// 子控件适应 Stack 的大小模式this.overflow = Overflow.clip,// 子控件超出 Stack 的显示空间的显示模式List<Widget> children = const <Widget>[],// 子控件集合}) 

接下来,详细看看各个参数支持的值。

alignment

alignment支持以下值:center, bottomCenter, bottomEnd, bototmStart, centerEnd, centerStart, topCenter, topStart, topEnd,各个参数从字面意思也能理解。

在这里插入图片描述
直接上效果图看各参数具体的显示:这里只展示topStart, topCenter, bottomEnd,其他参数的显示效果也是类似。
主要看 四个颜色(蓝黄绿红)方块层叠的位置!
topStart
topCenter
bottomEnd
伪代码如下:

Stack(alignment: AlignmentDirectional.bottomEnd,children: <Widget>[Container(width: 350,height: 350,color: Colors.red,alignment: Alignment.topLeft,// 改变文本的显示位置,为了展示效果,这个值需要跟随 stack 的 alignment 改变child: Text('bottomEnd',style: TextStyle(color: Colors.white),),),Container(width: 250,height: 250,color: Colors.green,alignment: Alignment.topLeft,child: Text('bottomEnd',style: TextStyle(color: Colors.white),),),Container(width: 150,height: 150,color: Colors.yellow,alignment: Alignment.topLeft,child: Text('bottomEnd',style: TextStyle(color: Colors.white),),),Container(width: 50,height: 50,color: Colors.blue,alignment: Alignment.topLeft,child: Text('bottomEnd',style: TextStyle(color: Colors.white),),),],
)

fit

fit支持以下值:expand, loose, passthough

在这里插入图片描述

  • StackFit.loose:默认效果,非 Positioned子组件可取最小到最大这个区间内的值,如Stack添加宽高 350*600 的约束,那么子组件宽取值区间为0-350,高取值区间为0-600
  • StackFit.expand:子组件取最大尺寸,如Stack添加宽高 350*600 的约束,那么子组件的宽为350,高为600
  • StackFit.passthrough:不改变子组件约束条件。

效果示例:
在这里插入图片描述
StackFit.expand 效果伪代码实现:

Stack(fit: StackFit.expand,children: <Widget>[Container(width: 350,height: 350,color: Colors.red,alignment: Alignment.topLeft,// 改变文本的显示位置,为了展示效果,这个值需要跟随 stack 的 alignment 改变child: Text('expand',style: TextStyle(color: Colors.white),),),Container(width: 50,height: 50,color: Colors.blue,alignment: Alignment.topLeft,child: Text('expand',style: TextStyle(color: Colors.white),),),],
)

loose, passthrough字段,暂时没想到示例,就不放效果图了。

overflow

overflow支持以下值:expand, loose, passthough

在这里插入图片描述

  • Overflow.clip: 默认效果,超出Stack部分会被剪裁(隐藏),
  • Overflow.visible 超出Stack部分不会被剪裁(隐藏)。

示例效果图:
原文源码:在Flutter中,定位的Widget如何在其父Stack区域之外点击?
在这里插入图片描述
在这里插入图片描述

Positioned

Positioned 可以设置子 Widget 位置

查看构造函数,看看都支持哪些属性:

const Positioned({Key key,this.left,// 离 Stack 左边的距离this.top,// 离 Stack 上边的距离this.right,// 离 Stack 右边的距离this.bottom,// 离 Stack 底边的距离this.width,// child 的宽度this.height,// child 的高度@required Widget child, // 子控件}) 

示例效果图:
在这里插入图片描述
示例伪代码:

Stack(children: <Widget>[Container(color: Colors.yellow, width: 300, height: 300),//黄色容器Positioned(left: 18.0,top: 18.0,child: Container(color: Colors.green, width: 50, height: 50),//叠加在黄色容器之上的绿色控件),Positioned(left: 18.0,top:70.0,child: Text("距离左边距 18,上边距 70 的文本"),),Positioned(right: 18.0,top:170.0,child: Text("距离右边距 18,上边距 170 的文本"),)],
)

完~


http://chatgpt.dhexx.cn/article/lVcJmH0f.shtml

相关文章

【Flutter从入门到实战】 ⑧、FlexWidget、Flex的主轴和交叉轴、Row和Column的使用、Expanded的FlexFit和flex的使用、Stack、Positioned的使用

Flutter从入门到实战 一共分为23个系列 ①(Flutter、Dart环境搭建篇) 共3个内容 已更新 ②(Dart语法1 篇) 共4个内容 已更新 ③(Dart语法2 篇) 共2个内容 已更新 ④(Flutter案例开发篇) 共4个内容 已更新 ⑤(Flutter的StatelessWidget 共3个内容 已更新 ⑥(Flutter的基础Widge…

Flutter入门学习--(16)布局定位控件Positioned

Positioned控件主要用来设置绝对布局&#xff0c;必须配合Stack控件来使用&#xff0c; Positioned控件 通过设置left和top属性可以设置控件的绝对位置 import package:flutter/material.dart;void main() > runApp(MyApp());class MyApp extends StatelessWidget {overrid…

Flutter 中 Positioned、Align、Center 的使用详解 _ Flutter Widgets

), Positioned( 《Android学习笔记总结+最新移动架构视频+大厂安卓面试真题+项目实战源码讲义》 【docs.qq.com/doc/DSkNLaERkbnFoS0ZF】 完整内容开源分享 top: 10, child: getItem(‘top 10’), ), Positioned( bottom: 10, child: getItem(‘bottom 10’), ), Positioned( h…

12、 Flutter Widgets 之 Stack,Positioned叠加组件

Stack/Positioned是用来做页面布局定位的组件&#xff0c;需要结合使用 Stack children:一个数组&#xff0c;里面可放多个Widgetalignment:Alignment.topCenter//对齐方式&#xff0c;会对所有的子组件统一设置对齐&#xff0c;不灵活&#xff0c;一般不用 Positioned child:一…

Flutter层叠布局 Stack、Positioned

Flutter中使用Stack和Positioned这两个组件来配合实现绝对定位。Stack允许子组件堆叠&#xff0c;而Positioned用于根据Stack的四个角来确定子组件的位置。 Stack alignment&#xff1a; 此参数决定如何去对齐没有定位&#xff08;没有使用Positioned&#xff09;或部分定位…

Flutter之层叠布局Stack、Positioned

Flutter中使用Stack和Positioned这两个组件来配合实现绝对定位。Stack允许子组件堆叠&#xff0c;而Positioned用于根据Stack的四个角来确定子组件的位置。 一.属性列表 Stack Stack({this.alignment AlignmentDirectional.topStart, this.textDirection,this.fit StackFi…

Flutter组件--重叠布局/相对布局(Stack,Positioned组件)

1.Flutter Stack组件 Stack表示堆的意思&#xff0c;我们可以用Stack或者Stack结合Align或者Stack结合 Positiond来实现页面的定位布局 属性 说明 alignment 配置所有子元素的显示位置 children 子组件 只使用Stack组件的情况下,所有的组件都是重叠在一起的,具体见下: …

Flutter——最详细(Positioned)使用教程

Positioned简介 创建一个小组件&#xff0c;用于控制 [Stack] 的子项的位置。 使用场景&#xff1a; 可以通过坐标的形式来摆放控件的位置&#xff0c;堆叠布局时可以使用&#xff1b; 属性作用width宽度height高度top顶bottom底left左right右 注意事项&#xff1a; 1.如果设置…

【Flutter组件】层叠布局 Stack、Positioned

层叠布局(Stack)和 Web 中的绝对定位、Android 中的 FrameLayout 布局是相似的&#xff0c;子组件可以根据距父容器四个角的位置来确定自身的位置。层叠布局允许子组件按照代码中声明的顺序堆叠起来。Flutter中使用Stack和Positioned这两个组件来配合实现绝对定位。Stack允许子…

【Flutter】Flutter 布局组件 ( FractionallySizedBox 组件 | Stack 布局组件 | Positioned 组件 )

文章目录 一、FractionallySizedBox 组件二、Stack 布局组件三、Positioned 组件四、 完整代码示例五、 相关资源 一、FractionallySizedBox 组件 FractionallySizedBox 组件 : 可控制组件在水平/垂直方向上填充满父容器 ; class FractionallySizedBox extends SingleChildRen…

Flutter实战Stack与Positioned使用详解

目录 Stack Positioned 小案例 Stack Stack({Key key,this.alignment AlignmentDirectional.topStart,//未指定区域的排布方式this.textDirection,this.fit StackFit.loose,//没有定位的子组件如何去适应Stack的大小this.overflow Overflow.clip,this.clipBehavior Clip…

Flutter基础学习 13-19 Stack的Positioned属性

前边已经介绍了Stack组件&#xff0c;并且进行了两个组件的层叠布局&#xff0c;但是如果是超过两个组件的层叠该如何进行定位那?这就是我们加今天要学的主角Positioned组件了&#xff0c;这个组件也叫做层叠定位组件。 知识点&#xff1a; Positioned组件的属性&#xff1a…

《Flutter 控件大全》第六十八个:Positioned

如果你对Flutter还有疑问或者技术方面的疑惑,欢迎加入Flutter交流群(微信:laomengit)。同时也欢迎关注我的Flutter公众号【老孟程序员】,公众号首发Flutter的相关内容。Flutter地址:http://laomengit.com 里面包含160多个组件的详细用法。Positioned用于定位Stack子组件,…

Flutter- Positioned

Positioned widget 用于定位 Stack 的子 widget。 Flutter Stack Positioned 仅用作 Stack 的直接(或后代)子部件。在 Positioned 到 Stack 的路径上&#xff0c;它只包含 StatelessWidget 或 StatefulWidget 小部件&#xff0c;不允许使用其他小部件(例如 RenderObjectWidge…

jclasslib插件使用

1、安装 File->setting->plugins->Brower Repositories 安装好后如下图 2、查看二进制码即指令

JVM知识体系学习一:JVM了解基础、java编译后class文件的类结构详解,class分析工具 javap 和 jclasslib 的使用

文章目录 前言一、JVM基础1、cross platform 跨平台2、cross language 跨语言3、什么是JVM呢&#xff1f;一张图告诉你4、java从编码到执行*****5. 从跨平台的语言到跨语言的平台6. jvm与class文件格式7. JVM8. javac的过程9. 常见的JVM实现10. JDK JRE JVM 二、Class File For…

如何在IDEA中使用 Jclasslib

在插件中安装jclasslib&#xff0c;然后重启IDEA 选中你的java文件&#xff0c;然后View->Show ByteCode With Jclasslib即可

android studio 字节码查看工具jclasslib bytecode viewer

jclasslib bytecode viewer 是一款非常好用的.class文件查看工具&#xff1b; jclasslib bytecode editor is a tool that visualizes all aspects of compiled Java class files and the contained bytecode. Many aspects of class files can be edited in the UI. In addit…

Jclasslib 试用

简述&#xff1a; jclasslib 是一个查看class文件的工具 TestJclasslib.java package com.anialy.test;public class TestJclasslib {private String str "Im TestJclasslib";private void print(){System.out.println(str);}public static void main(String[] arg…

jclasslib修改class文件

今天看到别人写的用工具jclasslib直接修改别人jar包里面的class文件,我自己也学着写了一下&#xff0c;发现果然很强大&#xff0c;但是也遇到一些坑 public class JVMTest {public static void main(String[] args) {long maxMemory Runtime.getRuntime().maxMemory(); //返…