【Flutter】基础组件

TextStyle 文本样式

  • color 字体颜色
  • fontSize (逻辑)字体大小,默认14
  • fontWeight 字体粗细 一般使用的属性:FontWeight normal(默认) 、FontWeight bold(粗体)
  • fontStyle 字体:normal和italic
  • fontFamily 设置字体,注意和 fontStyle的区别
  • letterSpacing 字母间距,默认0,负数间距越小,正数 间距越大
  • wordSpacing 单词 间距,默认0,负数间距越小,正数 间距越大,注意和letterSpacing的区别,比如hello,h、e、l、l、o各是一个字母,hello是一个单词
  • textBaseline 字体基线
  • height 类似 css 的 line-height 小数表示
  • foreground 和 background 感觉用不到
  • shadows 字体阴影
  • decoration 文字划线:下划线、上划线、中划线
  • decorationColor 划线颜色
  • decorationStyle 划线样式:虚线、双线等

Text 文本

正常字体

  Text(
    '正常文本'
  )

下划线,中划线

image.png
    Text(
      '下划线文本',
      style: TextStyle(
        decoration: TextDecoration.underline
      ),
    ),
    Text(
      '中划线文本',
      style: TextStyle(
          decoration: TextDecoration.lineThrough
      ),
    ),
    Text(
      '上划线文本',
      style: TextStyle(
          decoration: TextDecoration.overline
      ),
    ),

粗体


image
  Text(
      '加粗文本',
      style: TextStyle(
        fontWeight: FontWeight.bold
      ),
    ),
    Text(
      '加粗文本',
      style: TextStyle(
          fontWeight: FontWeight.w200
      ),
    ),

斜文本


image.png
  Text(
      '斜体文本',
      style: TextStyle(
        fontStyle: FontStyle.italic
      ),
    ),

字体大小


image
    Text(
      '大号文本',
      style: TextStyle(
        fontSize: 30
      ),
    ),

    Text(
      '中号文本',
      style: TextStyle(
        fontSize: 20
      ),
    ),

    Text(
      '小号文本',
      style: TextStyle(
        fontSize: 10
      ),
    ),
  • textAlign 设置文本对齐。多行文本才能表现出来


    image
  • textDirection 文本方向。

  • softWrap 是否自动换行,默认为 true

  • overflow 溢出时如何展示。


    image

    ellipsis 和 clip 都和 css 一样,fade 有一个半透明的效果

  • textScaleFactor 字体缩放

  • maxLines 最大显示行

  • semanticsLabel 语义化

如果需要显示富文本需要使用 Text.rich 和 textSpan


image
Text.rich(
  TextSpan(
    style: TextStyle(
      color: Colors.red
    ),
    text: 'hello world',
    children: [
      TextSpan(
        style: TextStyle(
            color: Colors.blue
        ),
        text: 'hello world'
      )
    ]
  )
);

这么展示富文本也太费劲了。

Image

return Image.asset(
  'assets/images/title.png',
  semanticLabel: '这是一张 title 图片',
  excludeFromSemantics: false,
  width: 60,
  height: 60,
  fit: BoxFit.contain,
  alignment: Alignment.bottomCenter,
  matchTextDirection: true,
  filterQuality: FilterQuality.high
);

属性

  • semanticLabel 图片语义化。类似 image 的 alt 属性。
  • excludeFromSemantics 不提供图片的语义,默认是 false。对于对 app 没有意义的图片使用。
  • width 宽度
  • height 宽度
  • color 会和图片像素重合。
  • colorBlendMode [ color ] 和 图片的混合方式。[ color ] 是源, 图片是目标。
  • fit 控制图片的布局,类型是 BoxFit。 可选值为 BoxFit[ fill, contain, cover, fitWidth, fitHeight, none, scaleDown ]。
  • alignment 对齐方式。类型是 Alignment。
  • repeat 重复方式。取值 ImageRepeat。
  • centerSlice 不能和 fit 同时设置。指定中心区域进行九个补丁图像,在中心切片内的图像区域将水平和垂直拉伸,以使图像适合其目的地。 中心切片上方和下方的图像区域将仅水平拉伸,而中心切片左侧和右侧的图像区域仅垂直拉伸。应该是设置九宫格图片用的。
  • matchTextDirection 如果是在文本中,是否根据文本方向翻转图片。
  • gaplessPlayback 当图像提供者发生变化时,是继续显示旧图像,默认不显示!
  • filterQuality 图片过滤器, 类型 FilterQuality。 可选值为: [ none, low, medium, high ],默认是 low。

创建图片容器的方法有下面几种:

  • new Image.asset 展示本地图片
  return Image.asset(
      'assets/images/title.png'
  );
  • new Image.network
return Image.network(
   'https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1553355447588&di=7df0e766c457cd950a09f3c3d016cb9a&imgtype=0&src=http%3A%2F%2Fdn-p-tystore.qbox.me%2Fp%2Fchapter%2Fattachment%2FEtIUE_bte-%2FEgfvEBITe_-W4B6ve_2wElu16gjT7UL68vmn6MiB6m9tJh9pHUfV9t2.jpg'
);
  • new Image.file 展示从 [ file ] 中获取的图片
  • new Image memory 展示从 [Uint8List] 中获取的图片

Icon

return Icon(
  Icons.star,
  color: Colors.red,
);

Icons 提供了很多内置的图标,如果需要别的图标可以借鉴 :
https://blog.csdn.net/kangshaojun888/article/details/86719741

Placeholder 占位符

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

推荐阅读更多精彩内容