Flutter - Stack 与 Positioned 层叠布局
创始人
2024-03-29 14:47:21
0

1 层叠布局和 Web 中的绝对定位、Android 中的 Frame 布局是相似的
2 子组件可以根据距父容器四个角的位置来确定自身的位置。
3 层叠布局允许子组件按照代码中声明的顺序堆叠起来。
4 Flutter中使用Stack和Positioned这两个组件来配合实现绝对定位。
5 Stack允许子组件堆叠,而Positioned用于根据Stack的四个角来确定子组件的位置。

下图为Stack 内的三个控件
一个在正中间 ,
一个在上方中部
一个在左方中部
在这里插入图片描述
先上代码,在说过程

ConstrainedBox(constraints: BoxConstraints.tightFor(width: double.infinity,height: 180),child: Container(color: Colors.blue[100],child: Stack(alignment: Alignment.center, // 未定位的子控件 在中间显示children: [Container(child: Text("center正中间",style: TextStyle(color: Colors.white)),color: Colors.red,),Positioned(left: 18.0,child: Text("左边中间"),),Positioned(top: 18.0,child: Text("顶部中间"),),],),),
),

Stack
1 Stack 层叠布局 的基础 , 在他的内部 如果需要给控件定位的话 ,需要与Positioned 配合使用

1 第一个属性 alignment

// alignment 是 Stack 的一个比较重要的属性, 
// 他的主要作用是,给它内部没有定位的控件提供一个默认的显示位置
this.alignment = AlignmentDirectional.topStart,

AlignmentDirectional 定位的参数 ,
有九个值

 topStart  ,       topCenter ,      topEndcenterStart ,      center ,        centerEndbottomStart ,   bottomCenter ,     bottomEnd

从上面九个值的位置就可以看出来 ,他们作用,

同时 AlignmentDirectional 可以用 Alignment 代替

topLeft     topCenter     topRight
centerLeft   center       centerRight
bottomLeft  bottomCenter  bottomRight

2 第二个属性 fit

//此参数用于确定没有定位的子组件如何去适应Stack的大小。
//StackFit.loose表示使用子组件的大小,
//StackFit.expand表示扩伸到Stack的大小。
this.fit = StackFit.loose,

Positioned
在 Stack 中 用来定位的 ,他的属性就是 上下左右,宽和高,

const Positioned({super.key,this.left,this.top,this.right,this.bottom,this.width,this.height,required super.child,}) : 

不过需要注意的是 ,这里的 width 和 height 和别的地方的宽高 有一些不一样,

在 Positioned 中 ,left , right , width 三个属性, 最多可以同时使用两个 ,如果三个都使用的话则会报错
内部的计算规则是 ,通过 left+width 算出 最后right ,也就是通过使用的两个值,算出最后一个 垂直同理


// 上面代码 ,Container 没有使用Positioned定位, 
// 所以 受 Stack 的约束
// alignment: Alignment.center, // 未定位的子控件 在中间显示
Container(child: Text("center正中间",style: TextStyle(color: Colors.white)),color: Colors.red,
),
// Positioned 约束了 left属性, 在水平方向上,在左方显示
// 未约束 垂直方向的属性,
// 所以 受 Stack 的约束
// alignment: Alignment.center, // 未定位的子控件 在中间显示
// 最后现在在 左边中间
Positioned(left: 18.0,child: Text("左边中间"),
),

Stack
2 Stack 层叠布局允许子组件按照代码中声明的顺序堆叠起来
就是后面的控件 ,如果有背景,会吧前面的布局盖住

在这里插入图片描述

ConstrainedBox(constraints: BoxConstraints.tightFor(width: double.infinity,height: 180),child: Container(color: Colors.blue[100],child: Stack(fit: StackFit.expand, // 未定位的空间 最大化,和父控件大小相同alignment: Alignment.center, // 未定位的子控件 在中间显示children: [Positioned(left: 18.0,child: Text("左边中间"),),Container(child: Text("center正中间",style: TextStyle(color: Colors.white)),color: Colors.red,),Positioned(top: 18.0,child: Text("顶部中间"),),],),),
),

重点

fit: StackFit.expand, // 未定位的空间 最大化,和父控件大小相同Container( 
// 未定位 受fit的影响 大小和父控件大小相同 ,
// 且在第二位 所以会盖住"左边中间"这个控件child: Text("center正中间",style: TextStyle(color: Colors.white)),color: Colors.red,
),

相关内容

热门资讯

财政部详解财政政策如何“更加积... 12月27日至28日,全国财政工作会议在北京召开。会议总结2025年财政工作,布置2026年重点任务...
推荐靠谱再审律师团队,王文婷律... 在法律纠纷的世界里,再审是当事人在经历一审、二审败诉后的后希望。然而,再审程序复杂、法定要求严苛,寻...
攀枝花警方通报:仁和区发生一起... 大象新闻2025-12-27 14:11:24 12月27日,攀枝花警方发布警情通报: 2025年...
《四川省惠企政策全生命周期管理... 为规范惠企政策全生命周期管理和运行,进一步提升惠企政策服务水平和效能,近日我省出台《四川省惠企政策全...
专业检查监督律师哪家强?王文婷... 在法律纠纷的解决过程中,当面临一审、二审、再审接连败诉的困境,或是遭遇复杂经济纠纷、刑事指控等情况时...
升达林业5亿元担保纠纷再审申请... 12月28日,升达林业(002259)披露全资子公司中弘达公司与厦门国际银行之间的质押合同纠纷案的进...
7亿元“互诉”大戏上演!大金重... 12月28日,大金重工(002487)发布关于诉讼事项的进展公告,一场与中国葛洲坝集团电力有限责任公...
50余位法律人晨跑椰城 共话专... 人民网海口12月28日电 (记者李学山)12月27日清晨7时30分,海口红城湖畔晨雾缭绕,随着一声“...
男子因纠纷引燃易燃物品致本人死... 12月28日,成都市公安局高新区分局发布警情通报: 12月28日下午,高新区南三环路四段一汽车销售服...
茅台称尽最大努力防止价格炒作,... 备受关注的茅台2026年全国经销商联谊会于12月28日下午举行。2025年在经历了换帅,一年内飞天茅...