【Flutter 1-16】Flutter手把手教程UI布局和Widget——容器控件Container
2020/12/29 8:08:17
本文主要是介绍【Flutter 1-16】Flutter手把手教程UI布局和Widget——容器控件Container,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
作者 | 弗拉德
来源 | 弗拉德
Container
我们先来看一下Container初始化的参数:
Container({ Key key, // 位置 居左、居右、居中 this.alignment, // EdgeInsets Container的内边距 this.padding, // 背景颜色 this.color, // 背景装饰器 this.decoration, // 前景装饰器 this.foregroundDecoration, // 宽度 double width, // 告诉 double height, // 约束 BoxConstraints constraints, // EdgeInsets Container的外边距 this.margin, // 旋转 this.transform, // 子控件 this.child, // 裁剪Widget的模式 this.clipBehavior = Clip.none, })
注意:
-
Container
的color
属性与属性decoration
的color
存在冲突,如果两个color
都做了设置,默认会以decoration
的color
为准。 -
如果我们没有给
Container
设置width
和height
,Container
会跟child
的大小一样;假如我们没有设置child
的时候,它的尺寸会极大化,尽可能的充满它的父Widget
。
1. 最简单的Container
Container( child: Text("Fulade"), color: Colors.red, )
Container接收一个child
参数,我们可以传入Text
作为child
参数,然后传入是一个颜色。
2. Padding
Container( child: Text("Pading 10"), padding: EdgeInsets.all(10), color: Colors.blue, )
Padding
是内边距,我们在这里设置了padding: EdgeInsets.all(10)
,也就是说Text
距离Container
的四条边的边距都是10。
3. Margin
Container( child: Text("Margin 10"), margin: EdgeInsets.all(10), color: Colors.green, )
Margin
是外边距,我们在这里设置了margin: EdgeInsets.all(10)
,Container
在原有大小的基础上,又被包围了一层宽度为10的矩形。
需要注意,绿色外围的白色区域也是属于Container
的一部分。
4. transform
Container( padding: EdgeInsets.symmetric(horizontal: 15), margin: EdgeInsets.all(10), child: Text("transform"), transform: Matrix4.rotationZ(0.1), color: Colors.red, )
transform
可以帮助我们做旋转,Matrix4
给我们提供了很多的变换样式。
5. decoration
decoration
可以帮助我们实现更多的效果。例如形状、圆角、边界、边界颜色等。
Container( child: Text("Decoration"), padding: EdgeInsets.symmetric(horizontal: 15), margin: EdgeInsets.all(10), decoration: BoxDecoration( color: Colors.red, shape: BoxShape.rectangle, borderRadius: BorderRadius.all(Radius.circular(5)), ), )
这里就是设置了一个圆角的示例,同样我们对BoxDecoration
的color
属性设置颜色,对整个Container
的也是有效的。
6. 显示 Image
Container( height: 40, width: 100, margin: EdgeInsets.all(10), decoration: BoxDecoration( image: DecorationImage( image: AssetImage("images/flutter_icon_100.png"), fit: BoxFit.contain, ), ), )
BoxDecoration
可以传入一个Image
对象,这样就灵活了很多,Image
可以来自本地也可以来自网络。
7. Border
Container( child: Text('BoxDecoration with border'), padding: EdgeInsets.symmetric(horizontal: 15), margin: EdgeInsets.all(5), decoration: BoxDecoration( borderRadius: BorderRadius.circula(12), border: Border.all( color: Colors.red, width: 3, ), ), )
使用border
可以帮助我们做边界效果,还可以设置圆角borderRadius
,也可以设置border
的宽度,颜色等。
8. 渐变色
Container( padding: EdgeInsets.symmetric(horizontal: 20), margin: EdgeInsets.all(20), //容器外填充 decoration: BoxDecoration( gradient: RadialGradient( colors: [Colors.blue, Colors.black, Colors.red], center: Alignment.center, radius: 5 ), ), child: Text( //卡片文字 "RadialGradient", style: TextStyle(color: Colors.white), ), )
BoxDecoration
的属性gradient
可以接收一个颜色的数组,Alignment.center
是渐变色开始的位置,可以从左上角
、右上角
、中间
等位置开始颜色变化。
想体验以上的Container
的示例的运行效果,可以到[我的Github仓库]github.com/Johnson8888/learn_flutter项目flutter_app
->lib
->routes
->container_page.dart
查看,并且可以下载下来运行并体验。
这篇关于【Flutter 1-16】Flutter手把手教程UI布局和Widget——容器控件Container的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2025-01-10Rakuten 乐天积分系统从 Cassandra 到 TiDB 的选型与实战
- 2025-01-09CMS内容管理系统是什么?如何选择适合你的平台?
- 2025-01-08CCPM如何缩短项目周期并降低风险?
- 2025-01-08Omnivore 替代品 Readeck 安装与使用教程
- 2025-01-07Cursor 收费太贵?3分钟教你接入超低价 DeepSeek-V3,代码质量逼近 Claude 3.5
- 2025-01-06PingCAP 连续两年入选 Gartner 云数据库管理系统魔力象限“荣誉提及”
- 2025-01-05Easysearch 可搜索快照功能,看这篇就够了
- 2025-01-04BOT+EPC模式在基础设施项目中的应用与优势
- 2025-01-03用LangChain构建会检索和搜索的智能聊天机器人指南
- 2025-01-03图像文字理解,OCR、大模型还是多模态模型?PalliGema2在QLoRA技术上的微调与应用