flutter 布局 Stack Positioned的混合操作 两个组件Container重叠 构建背景圆角操作 类似css的relative

article/2025/9/28 18:32:35

flutter 布局 Stack Positioned的混合操作 两个组件Container重叠 构建背景圆角操作

首先看一下需求 需要在这里加一个背景圆角,涉及到两个组件Container的重叠

在这里插入图片描述

我们使用Stack Positioned的混合操作 类似于css汇中的relative属性,而且我接下来使用的操作不影响之后的布局,有点骚的操作

先简单介绍一下这个Stack和Positioned。Stack是最外部布局,然后Positioned内部相对原有位置移动 先看个简单的示例

Stack(alignment: Alignment.center,children: [Container(width: 200,height: 200,color: Colors.green,alignment: Alignment.center,child: Text("Stack"),),Positioned(top: 10.0,width: 100,left: 10,child: Container(width: 100,height: 100,color: Colors.red,alignment: Alignment.center,child: Text("测试Posittion"),),)],)

效果图

在这里插入图片描述

接来我们来实现上述需求

我们先写好分别的两个组件 然后我们利用Positioned创建一个白色的圆角Container叠在红色箭头位置 位置用bottom:-15来定位 具体数值大家可以自己测

Stack(alignment: Alignment.topCenter,children: <Widget>[Container(height: 220,decoration: BoxDecoration(image: DecorationImage(image: AssetImage("assets/images/ground/顶部背景 6@2x.png"),fit: BoxFit.cover,),),child: Row(mainAxisAlignment: MainAxisAlignment.spaceBetween,crossAxisAlignment: CrossAxisAlignment.center,children: <Widget>[Padding(padding: EdgeInsets.all(10),child: Image.asset("assets/images/ground/顶部头像@2x.png",height: 120,width: 120,),),Expanded(child: Column(children: <Widget>[Padding(padding: EdgeInsets.fromLTRB(10, 30, 10, 10),child: Row(mainAxisAlignment: MainAxisAlignment.spaceBetween,children: <Widget>[Text("浙江大学",style: TextStyle(color: Colors.white, fontSize: 24, fontWeight: FontWeight.w600),),IconButton(icon: Icon(Icons.arrow_forward_ios,color: Colors.white,),onPressed: () {},)],),),Padding(padding: EdgeInsets.fromLTRB(10, 0, 10, 5),child: Row(mainAxisAlignment: MainAxisAlignment.spaceBetween,children: <Widget>[Text("1234帖子 1234成员",style: TextStyle(color: Colors.white, fontSize: 14),),Container(decoration: BoxDecoration(borderRadius: BorderRadius.circular(8),color: ColorsUtil.hexColor(0xD8D8D8, alpha: 0.4),),height: 40,width: 85,// color: ColorsUtil.hexColor(0xD8D8D8, alpha: 0.4),child: InkWell(child: Row(children: <Widget>[SizedBox(width: 12,),Icon(Icons.add,color: Colors.white,),Text("加入",style: TextStyle(color: Colors.white),),],),),)],),),Padding(padding: EdgeInsets.fromLTRB(10, 0, 0, 5),child: Text("置顶:欢迎来到浙江大学操场,这里是本校区所有活动的集结之地,在这里你可以发布任意动态,希望你玩得开心~",style: TextStyle(color: Colors.white),),)],))],),),Positioned(bottom: -15.0,width: ScreenUtil.screenWidth,child: Container(width: ScreenUtil.screenWidth,height: 30,alignment: Alignment.center,decoration: BoxDecoration(color: Colors.white, borderRadius: BorderRadius.all(Radius.circular(30))),),),],
),

效果图

在这里插入图片描述


http://chatgpt.dhexx.cn/article/5BskJuye.shtml

相关文章

Flutter布局组件之层叠组件Stack和Positioned

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

Flutter开发之——多组件布局容器-Stack和IndexedStack及Positioned

一 概述 Stack组件时Flutter中用来进行绝对布局的一个容器组件(Stack组件可以将子组件叠加显示&#xff0c;根据子组件的顺利依次向上叠加)IndexedStack是Stack的子类&#xff0c;Stack是将所有的子组件叠加显示&#xff0c;而IndexedStack只显示指定的子组件Positioned组件通…

Flutter 层叠布局 Stack、Positioned

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

Flutter 多子 Widget 布之Stack、Positioned

文章目录 层叠 Widget 布局Stackalignmentfitoverflow Positioned 上文 Flutter 多子 Widget 布局之Flex、Expanded、Wrap、Flow&#xff0c;介绍了弹性布局 Flex、Expanded和流式布局Wrap、Flow再上文 Flutter 多子 Widget 布局之线性布局 Row、Column&#xff0c;介绍了线性布…

【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…