Flutter入门(7):Flutter 组件之 Container 详解

1. Container 介绍

基础属性不做太多介绍,有兴趣的可以去Flutter 中文网 了解一下。

2. 示范代码

代码下载地址。如果对你有帮助的话记得给个关注,代码会根据我的 Flutter 专题不断更新。

container.dart 路径如下
/FMStudyApp/lib/Widgets/BaseWidget/container.dart

3. 基本属性

优雅的编程,我们先单独创建一个 container.dart 文件,用来试用 Container 的属性和效果。

import 'package:flutter/material.dart';

class FMContainerVC extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return Container(
      child: Scaffold(
        appBar: AppBar(
          title: Text(
            "Container",
          ),
          backgroundColor: Colors.lightBlue,
        ),
        body: _container(),
      ),
    );
  }

  Container _container() {
    return Container(
      // 在这里尝试 Container 属性效果
    );
  }
}

4. 颜色与大小

直接使用 color 属性改变背景色,使用 width 设置宽度,使用 height 属性设置高度。

  Container _container() {
    return Container(
      // 在这里尝试 Container 属性效果
      width: 320,
      height: 200,
      color: Colors.red,
    );
  }

使用 constraints 属性来改变 container 大小

  Container _container() {
    return Container(
      // 在这里尝试 Container 属性效果
      constraints: BoxConstraints.expand(
        width: 320,
        height: 200,
      ),
      color: Colors.red,
    );
  }

使用约束来改变 container 的位置与大小,同时设置了大小和约束并且有冲突时,会优先执行约束。

  Container _container() {
    return Container(
      // 在这里尝试 Container 属性效果
      constraints: BoxConstraints.expand(
        width: 320,
        height: 200,
      ),
      color: Colors.red,
      // 此时优先执行约束,会挤压宽度小于 320
      margin: const EdgeInsets.only(left: 150, top: 100, right: 30),
    );
  }

5. Border 边框设置

不得不赞一下,flutter 的边框真的是自定义起来非常的方便,可以给4个边指定不同的颜色,也可以给4个角不同的圆角。

我们先给这个 container 添加一个边框,使用 decoration 属性,BoxDecoration 中的 border 属性。

  Container _container() {
    return Container(
      // 在这里尝试 Container 属性效果
      constraints: BoxConstraints.expand(
        width: 320,
        height: 200,
      ),
      decoration: BoxDecoration(
          border: Border.all(
          color: Colors.red,
          width: 3,
        ),
      ),
    );
  }

注意:decoration 属性和 color 属性不可以同时使用,否则会如下报错。在 decoration 属性里也可以设置背景色,如需要同时使用边框和背景色,可以在这里设置。

Cannot provide both a color and a decoration
To provide both, use "decoration: BoxDecoration(color: color)".
'package:flutter/src/widgets/container.dart':
Failed assertion: line 283 pos 15: 'color == null || decoration == null'

我们在来改变一下边框的角度

  Container _container() {
    return Container(
      // 在这里尝试 Container 属性效果
      constraints: BoxConstraints.expand(
        width: 320,
        height: 200,
      ),
      decoration: BoxDecoration(
          border: Border.all(
            color: Colors.red,
            width: 3,
         ),
         borderRadius: BorderRadius.circular(30),
      ),
    );
  }
container border.png

其实这样已经能解决大部分需求了,下边我们在介绍下自定义边框

  Container _container() {
    return Container(
      // 在这里尝试 Container 属性效果
      constraints: BoxConstraints.expand(
        width: 320,
        height: 200,
      ),
      decoration: BoxDecoration(
          border: Border.all(
            color: Colors.red,
            width: 3,
         ),
         color: Colors.yellow,
        borderRadius: BorderRadius.only(
            topLeft: Radius.circular(0), 
            topRight: Radius.circular(0), 
            bottomLeft: Radius.circular(30), 
            bottomRight: Radius.circular(30)),
      ),
    );
  }
container border custom.png

下边在自定义不同的边框色

  Container _container() {
    return Container(
      // 在这里尝试 Container 属性效果
      constraints: BoxConstraints.expand(
        width: 320,
        height: 200,
      ),
      decoration: BoxDecoration(
          border: Border.all(
            color: Colors.red,
            width: 3,
         ),
        border: Border(
            top: BorderSide(
              width: 3,
              color: Colors.cyan,
            ),
            left: BorderSide(
              width: 3,
              color: Colors.blue,
            ),
            right: BorderSide(
              width: 3,
              color: Colors.black,
            ),
            bottom: BorderSide(
              width: 3,
              color: Colors.orange,
            ),
         ),
       ),
    );
  }
container border colorful.png

注意:使用自定义 border 时,不可以使用 borderRadius 属性,否则会有如下报错

A borderRadius can only be given for a uniform Border.

6. 渐变色背景设置

使用 gradient 属性给 container 设置渐变背景色。

  Container _container() {
    return Container(
      // 在这里尝试 Container 属性效果
      constraints: BoxConstraints.expand(
        width: 320,
        height: 200,
      ),
      decoration: BoxDecoration(
          border: Border.all(
            color: Colors.red,
            width: 3,
         ),
         borderRadius: BorderRadius.circular(30),
        gradient: LinearGradient(colors: [Colors.white, Colors.yellow], begin: FractionalOffset(0, 0), end: FractionalOffset(0, 1)),
      ),
    );
  }
container gradient.png

7. 设置背景图

使用 image 属性设置背景图,其中 centerSlice 可以改变填充大小,可以自行实验效果。

  Container _container() {
    return Container(
      // 在这里尝试 Container 属性效果
      constraints: BoxConstraints.expand(
        width: 320,
        height: 200,
      ),
      decoration: BoxDecoration(
          border: Border.all(
            color: Colors.red,
            width: 3,
         ),
         borderRadius: BorderRadius.circular(30),
         image: DecorationImage(
            image: NetworkImage('http://tiebapic.baidu.com/forum/w%3D580/sign=a96ca741eafaaf5184e381b7bc5594ed/7ea6a61ea8d3fd1f2643ad5d274e251f95ca5f38.jpg'),
          // centerSlice: Rect.largest,
         ),
         gradient: LinearGradient(colors: [Colors.white, Colors.yellow], begin: FractionalOffset(0, 0), end: FractionalOffset(0, 1)),
      ),
    );
  }
container image.png

8. 阴影

使用 boxShadow 属性设置阴影。

  Container _container() {
    return Container(
      // 在这里尝试 Container 属性效果
      constraints: BoxConstraints.expand(
        width: 320,
        height: 200,
      ),
      decoration: BoxDecoration(
          border: Border.all(
            color: Colors.red,
            width: 3,
         ),
         borderRadius: BorderRadius.circular(30),
         boxShadow: [BoxShadow(color: Colors.grey, offset: Offset(10,10))],
         image: DecorationImage(
            image: NetworkImage('http://tiebapic.baidu.com/forum/w%3D580/sign=a96ca741eafaaf5184e381b7bc5594ed/7ea6a61ea8d3fd1f2643ad5d274e251f95ca5f38.jpg'),
          // centerSlice: Rect.largest,
         ),
         gradient: LinearGradient(colors: [Colors.white, Colors.yellow], begin: FractionalOffset(0, 0), end: FractionalOffset(0, 1)),
      ),
    );
  }
container shadow.png

9. 旋转

使用 transform 属性设置旋转,这里不做太多叙述了。

  Container _container() {
    return Container(
      // 在这里尝试 Container 属性效果
      constraints: BoxConstraints.expand(
        width: 320,
        height: 200,
      ),
      decoration: BoxDecoration(
          border: Border.all(
            color: Colors.red,
            width: 3,
         ),
         borderRadius: BorderRadius.circular(30),
         boxShadow: [BoxShadow(color: Colors.grey, offset: Offset(10,10))],
         image: DecorationImage(
            image: NetworkImage('http://tiebapic.baidu.com/forum/w%3D580/sign=a96ca741eafaaf5184e381b7bc5594ed/7ea6a61ea8d3fd1f2643ad5d274e251f95ca5f38.jpg'),
          // centerSlice: Rect.largest,
         ),
         gradient: LinearGradient(colors: [Colors.white, Colors.yellow], begin: FractionalOffset(0, 0), end: FractionalOffset(0, 1)),
      ),
      transform: Matrix4.rotationZ(0.1),
    );
  }
container rotate.png

10. child 子控件

使用 child 属性给 container 添加子控件,使用 padding 属性设置子控件的范围,使用 alignment 来设置子控件的居中属性。

  Container _container() {
    return Container(
      // 在这里尝试 Container 属性效果
      constraints: BoxConstraints.expand(
        width: 320,
        height: 200,
      ),
      decoration: BoxDecoration(
          border: Border.all(
            color: Colors.red,
            width: 3,
         ),
         borderRadius: BorderRadius.circular(30),
         boxShadow: [BoxShadow(color: Colors.grey, offset: Offset(10,10))],
         image: DecorationImage(
            image: NetworkImage('http://tiebapic.baidu.com/forum/w%3D580/sign=a96ca741eafaaf5184e381b7bc5594ed/7ea6a61ea8d3fd1f2643ad5d274e251f95ca5f38.jpg'),
          // centerSlice: Rect.largest,
         ),
         gradient: LinearGradient(colors: [Colors.white, Colors.yellow], begin: FractionalOffset(0, 0), end: FractionalOffset(0, 1)),
      ),
      transform: Matrix4.rotationZ(0.1),
      alignment: Alignment.centerLeft,
      padding: const EdgeInsets.all(30),
      child: Text(
        "Container",
        style: TextStyle(
          fontSize: 30,
          color: Colors.red,
        ),
      ),
    );
  }

padding 属性,你可以理解为 child 距离该 container 4个边框的边界距离,例如 padding: const EdgeInsets.all(30),
就是距离 child 上方距离 container 上方 30,左右下三个方向同理

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,923评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,154评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,775评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,960评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,976评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,972评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,893评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,709评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,159评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,400评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,552评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,265评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,876评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,528评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,701评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,552评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,451评论 2 352