Stack

在flutter中,Stack表示堆的意思,可以用来实现页面的定位布局。

Stack组件接收两个可选参数:

  • alignment:配置所有子元素的显示位置
  • children:子组件

  

在上面的Stack组件里面定义了一个Container和两个Text组件,我们会发现这三个组件实现了重叠,并且后定义的在上层,这就是所谓的堆效果,

  1. import 'package:flutter/material.dart';
  2.  
  3. void main() => runApp(MyApp());
  4.  
  5. class MyApp extends StatelessWidget {
  6. @override
  7. Widget build(BuildContext context) {
  8. // TODO: implement build
  9. return MaterialApp(
  10. home: Scaffold(
  11. appBar: AppBar(title: Text('FlutterDemo')),
  12. body: LayoutDemo(),
  13. ));
  14. }
  15. }
  16.  
  17. class LayoutDemo extends StatelessWidget {
  18. @override
  19. Widget build(BuildContext context) {
  20. // TODO: implement build
  21. return Center(
  22. child: Stack(
  23. alignment: Alignment.center,
  24. children: <Widget>[
  25. Container(
  26. height: 400,
  27. width: 300,
  28. color: Colors.red,
  29. ),
  30. Text('我是一个文本',style: TextStyle(
  31. fontSize: 40,
  32. color: Colors.white
  33. ))
  34. ],
  35. ),
  36. );
  37. }
  38. }

在上面的例子中,我们给alignment的值是Alignment.center,除此之外,还有Alignment.topLeft等,另外,它也可以接收两个double类型的值,介于-1到1之间:(0,0)表示中心点,(1,1)表示右下角,(-1,-1)表示左上角。

Stack Align

Stack 组件中结合 Align 组件可以控制每个子元素的显示位置 。
  

和上面的例子一样,当我们在Stack组件里面定义了多个子元素的时候,会发生重叠,即使使用了alignment进行了定位,也是对所有的元素统一定位,这个时候就可以借助Align来控制每个子元素的位置。

Align也有两个可选参数属性:

  • alignment :配置所有子元素的显示位置
  • child :子组件

现在,我们可以这样修改上面的例子:

  1. import 'package:flutter/material.dart';
  2.  
  3. void main() => runApp(MyApp());
  4.  
  5. class MyApp extends StatelessWidget {
  6. @override
  7. Widget build(BuildContext context) {
  8. // TODO: implement build
  9. return MaterialApp(
  10. home: Scaffold(
  11. appBar: AppBar(title: Text('FlutterDemo')),
  12. body: LayoutDemo(),
  13. ));
  14. }
  15. }
  16.  
  17. class LayoutDemo extends StatelessWidget {
  18. @override
  19. Widget build(BuildContext context) {
  20. // TODO: implement build
  21. return Center(
  22. child: Container(
  23. height: 400,
  24. width: 300,
  25. color: Colors.red,
  26. child: Stack(
  27. // alignment: Alignment.center,
  28. children: <Widget>[
  29. Align(
  30. alignment: Alignment(1,-0.2),
  31. child: Icon(Icons.home,size: 40,color: Colors.white),
  32. ),
  33. Align(
  34. alignment: Alignment.center,
  35. child: Icon(Icons.search,size: 30,color: Colors.white),
  36. ),
  37. Align(
  38. alignment: Alignment.bottomRight,
  39. child: Icon(Icons.settings_applications,size: 30,color: Colors.white),
  40. )
  41. ],
  42. ),
  43. ),
  44. );
  45. }
  46. }

Stack Positioned

Stack 组件中结合 Positioned 组件也可以控制每个子元素的显示位置 。Positioned 有多个可选参数属性:
  • top :子元素距离顶部的距离
  • bottom
  • left 
  • right 
  • child 
 我们也可以使用Positioned来实现上面Align的效果:

  1. class LayoutDemo extends StatelessWidget {
  2. @override
  3. Widget build(BuildContext context) {
  4. // TODO: implement build
  5. return Center(
  6. child: Container(
  7. height: 400,
  8. width: 300,
  9. color: Colors.red,
  10. child: Stack(
  11. // alignment: Alignment.center,
  12. children: <Widget>[
  13. Positioned(
  14. // left: 10,
  15. child: Icon(Icons.home,size: 40,color: Colors.white),
  16. ),
  17. Positioned(
  18. bottom: 0,
  19. left: 100,
  20. child: Icon(Icons.search,size: 30,color: Colors.white),
  21. ),
  22. Positioned(
  23. right: 0,
  24. child: Icon(Icons.settings_applications,size: 30,color: Colors.white),
  25. )
  26. ],
  27. ),
  28. ),
  29. );
  30. }
  31. }

flutter页面布局二的更多相关文章

  1. Flutter 页面布局 Stack层叠组件

    Stack 表示堆的意思,我们可以用 Stack 或者 Stack 结合 Align 或者 Stack 结合 Positiond 来实现页面的定位布局 属性 说明 alignment 配置所有子元素的 ...

  2. flutter 页面布局 Paddiing Row Column Expanded 组件

    Flutter Paddiing 组件 在 html 中常见的布局标签都有 padding 属性,但是 Flutter 中很多 Widget 是没有 padding 属 性.这个时候我们可以用 Pad ...

  3. flutter页面布局三

    RaisedButton 为了实现今天的效果,在认识Wrap组件之前,先认识一下flutter中的按钮组件,Flutter 中通过 RaisedButton 定义一个按钮. import 'packa ...

  4. flutter页面布局一

    Padding组件 在 html 中常见的布局标签都有 padding 属性,但是 Flutter 中很多 Widget 是没有 padding 属性.这个时候我们可以用 Padding 组件处理容器 ...

  5. 13Flutter页面布局 Wrap组件

    /* Flutter页面布局Wrap组件: Wrap可以实现流布局,单行的Wrap跟Row表现几乎一致,单列的Wrap则跟Row表现几乎一致. 但Row与Column都是单行单列的.Wrap则突破了这 ...

  6. 11Flutter页面布局 Stack层叠组件 Stack与Align Stack与Positioned实现定位布局

    /* Flutter 页面布局 Stack层叠组件: Stack与Align Stack与Positioned实现定位布局: Flutter Stack组件: Stack表示堆得意思,我们可以用Sta ...

  7. 10Flutter页面布局 Padding Row Column Expanded组件详解:

    Padding组件: main.dart import 'package:flutter/material.dart'; import 'res/listData.dart'; /* flutter页 ...

  8. 基本CSS布局二

    基本CSS布局二------基本页面布局二 /*主面板样式*/ #container { width:100%; margin:0px auto;/*主面板DIV居中*/ } /*顶部面板样式*/ # ...

  9. HTML5+CSS3学习笔记(二) 页面布局:HTML5新元素及其特性

    HTML5的语义化标签以及属性,可以让开发者非常方便地实现清晰的web页面布局,加上CSS3的效果渲染,快速建立丰富灵活的web页面显得非常简单. 本次学习HTML5的新标签元素有: <head ...

随机推荐

  1. 132、TensorFlow加载模型

    # The tf.train.Saver对象不仅保存变量到checkpoint文件 # 它也恢复变量,当你恢复变量的时候,你就不必须要提前初始化他们 # 列如如下的代码片段解释了如何去调用tf.tra ...

  2. IntelliJ IDEA中创建xml文件

      1.file—setting,左上角输入template, 2.在左侧栏找到File And Code Templates 3.中间选中Files 4.点击+号,添加模板 5.输入模板名字:Nam ...

  3. 从有状态应用(Session)到无状态应用(JWT),以及 SSO 和 OAuth2

    不管用哪种方式认证用户,都可能被中间人攻击窃取 SessionID 或 Token,从而发生 CSRF 攻击.解决方式就是全站 HTTPS.现在 Let's Encrypt 已经支持免费的通配符 HT ...

  4. php远程抓取(下载)文件到本项目指定目录中

    function httpcopy($url, $file="", $timeout=60) { $file = empty($file) ? pathinfo($url,PATH ...

  5. Altium Designer chapter5总结

    PCB设计环境中需要注意的如下: (1)PCB设计步骤:绘制原理图和生成网表—规划电路板—载入网表—元件布局—制定设计规则—布线—后期处理—DRC检查—信号完整性分析—gerbera文件输出 (2)P ...

  6. 【ABAP系列】SAP ABAP实现LOG显示的方法

    公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[ABAP系列]SAP ABAP实现LOG显示的 ...

  7. springboot异步任务、定时任务

    打开浏览器 http://localhost:8080/hello ,连续刷新可以看到不会 等待 3秒时间了,pom.xml controller service 代码如下. -----------S ...

  8. jQuery基础--CSS操作、class操作、attr操作、prop操作

    1.1.1    css操作 功能:设置或者修改样式,操作的是style属性. 设置单个样式 //name:需要设置的样式名称 //value:对应的样式值 css(name, value); //使 ...

  9. Springboot War包部署下nacos无法注册问题

    目录 1. @EnableDiscoveryClient的使用 2. EnableDiscoveryClientImportSelector类的作用 3.AutoServiceRegistration ...

  10. python-MySQL数据库--- 基础篇

    MySQL数据库基础 数据库系统(database system) 1.数据库系统(database system)         数据库系统是计算机系统中一种专门管理数组资源的系统,数据库存储的是 ...