Flutter的Stack和Positioned的控件

简介: Flutter的Stack和Positioned的控件

简介

Flutter中的Stack控件是一种可用于将多个子控件重叠在一起的布局控件。Stack将所有子控件放在同一个位置,它们可以根据需要进行定位、缩放或旋转。Stack中的子控件可以是任何类型的控件,例如文本、图像、按钮等。


主要属性

Stack控件的主要属性包括:


alignment:用于指定子控件的对齐方式,可以是左上角、居中、右下角等。

fit:用于指定未定位子控件的大小调整方式,可以是填充、缩放或保持原始大小。

overflow:用于指定当子控件超出Stack范围时的处理方式,可以是裁剪或滚动。

Stack控件中的子控件可以使用Positioned控件来指定其位置和大小。Positioned控件有四个位置属性:left、top、right和bottom,分别表示子控件距离Stack左边、上边、右边和下边的距离。除了位置属性外,Positioned控件还可以设置大小属性,包括width和height。如果不设置大小属性,则子控件将自动调整为其内容的大小。如果设置了位置和大小属性,则子控件将被限制在指定的位置和大小范围内。


例子

下面是一个使用Stack和Positioned控件的示例代码:


Stack(
  alignment: Alignment.center,
  children: <Widget>[
    Positioned(
      left: 20.0,
      top: 20.0,
      child: Text('Hello'),
    ),
    Positioned(
      right: 20.0,
      bottom: 20.0,
      child: Text('World'),
    ),
  ],
)

上述代码将在Stack控件中创建两个文本控件,分别位于左上角和右下角。由于设置了alignment属性为居中对齐,因此Stack控件会将这两个文本控件重叠在一起,并居中对齐。

效果如下图:


05e3aee1746dddd55126b5189a343674.png

Positioned控件

Positioned是Flutter中的一个控件,用于将子控件放置在Stack控件中的特定位置。


Positioned控件需要作为Stack控件的直接子控件使用,并通过top、bottom、left、right属性来确定子控件在Stack中的位置。


Positioned的属性

以下是Positioned控件的详细属性说明:


top: 指定子控件的顶部边缘与Stack的顶部边缘之间的距离。如果同时指定了top和bottom属性,则会忽略bottom属性。

bottom: 指定子控件的底部边缘与Stack的底部边缘之间的距离。

left: 指定子控件的左侧边缘与Stack的左侧边缘之间的距离。如果同时指定了left和right属性,则会忽略right属性。

right: 指定子控件的右侧边缘与Stack的右侧边缘之间的距离。

width: 指定子控件的宽度。如果同时指定了left和right属性,则会忽略right属性。

height: 指定子控件的高度。如果同时指定了top和bottom属性,则会忽略bottom属性。

使用Positioned控件可以轻松地将子控件放置在Stack的特定位置,并可以通过调整top、bottom、left、right属性来控制子控件的位置和大小。


例子

以下是一个使用Positioned控件的示例:


Copy code
Stack(
  children: [
    Positioned(
      top: 100,
      left: 20,
      child: Container(
        width: 200,
        height: 100,
        color: Colors.red,
      ),
    ),
    Positioned(
      bottom: 50,
      right: 10,
      child: Container(
        width: 150,
        height: 150,
        color: Colors.blue,
      ),
    ),
  ],
)



在上面的示例中,两个Container分别被放置在Stack的不同位置,通过调整top、bottom、left、right属性来确定它们的位置。


相关文章
|
Android开发 iOS开发 容器
Flutter控件封装之轮播图Banner
Flutter中实现轮播图的方式有很多种,比如使用三方flutter_swiper,card_swiper等等,使用这些三方,可以很快很方便的实现一个轮播图展示,基本上也能满足我们日常的开发需求,如果说,想要一些定制化的操作,那么就不得不去更改源码或者自己自定义一个,自己定义的话,Flutter中提供了原生组件PageView,可以使用它很方便的来实现一个轮播图。
398 0
|
5月前
|
Android开发
Flutter控件的显示与隐藏
Flutter控件的显示与隐藏
185 3
|
2月前
|
容器
Flutter &&鸿蒙next中的 Stack 和 Positioned 用法详解
在 Flutter 中,Stack 和 Positioned 是创建层叠布局和灵活定位元素的常用组件。Stack 可以将多个子组件叠加在一起,允许子组件相互重叠;Positioned 用于在 Stack 内部精确控制子组件的位置。本文详细介绍了它们的基本用法、属性和应用场景,包括动画、弹出层和悬浮按钮等。
113 1
|
2月前
|
容器
深入理解 Flutter 鸿蒙版的 Stack 布局:适配屏幕与层叠样式布局
Flutter 的 Stack 布局组件允许你将多个子组件层叠在一起,实现复杂的界面效果。本文介绍了 Stack 的基本用法、核心概念(如子组件层叠、Positioned 组件和对齐属性),以及如何使用 MediaQuery 和 LayoutBuilder 实现响应式设计。通过示例展示了照片展示与文字描述、动态调整层叠布局等高级用法,帮助你构建更加精美和实用的 Flutter 应用。
149 2
|
5月前
|
开发者 监控 开发工具
如何将JSF应用送上云端?揭秘在Google Cloud Platform上部署JSF应用的神秘步骤
【8月更文挑战第31天】本文详细介绍如何在Google Cloud Platform (GCP) 上部署JavaServer Faces (JSF) 应用。首先,确保已准备好JSF应用并通过Maven构建WAR包。接着,使用Google Cloud SDK登录并配置GCP环境。然后,创建`app.yaml`文件以配置Google App Engine,并使用`gcloud app deploy`命令完成部署。最后,通过`gcloud app browse`访问应用,并利用GCP的监控和日志服务进行管理和故障排查。整个过程简单高效,帮助开发者轻松部署和管理JSF应用。
66 0
|
6月前
|
移动开发 UED 容器
Flutter-自定义可展开文本控件
Flutter-自定义可展开文本控件
105 0
|
6月前
Flutter-自定义三角形评分控件
Flutter-自定义三角形评分控件
59 0
|
8月前
Flutter StatefulWidget传递数据,多级控件传递数据
Flutter StatefulWidget传递数据,多级控件传递数据 在Flutter中,StatefulWidget可以通过构造函数将数据传递给其子控件,这种方式适用于一些简单的场景。但是,当存在多级嵌套控件时,将数据从祖先传递到后代可能会变得困难。在这种情况下,可以使用Flutter提供的InheritedWidget类来传递数据。
126 0
|
API Android开发
Flutter控件封装之视频进度条
视频控制器,三方所提供的样式,有时很难满足我们的需求,对于此情况,我们不得不在此基础上自行封装,今天所分享的文章就是一个很简单的控制器封装案例,包含了基本的播放暂停,全屏和退出全屏,以及时间和进度的展示,封装了事件回调以及各个属性的控制,基本上可以满足大部分的业务需求,即便不满足,大家也可以在此基础之上拓展。
317 0
|
Android开发 UED
Flutter控件之Tab选项卡封装
Tab选项卡,这是一个非常常见且权重很高的一个组件,随便打开一个App,比如掘金,如下图,首页顶部就是一个Tab选项卡,这个功能可以说,几乎每个App都会存在。
251 0