Flutter 18: 易忽略的【小而巧】的技术点汇总 (一)

      小菜在学习 Flutter 过程中遇到很多有趣的小知识点,平时可能不太注意或一些简单直接的小功能点,准备整理一个小系列,方便日后的查找使用。

1. InkWell 水波纹效果

      小菜在 Android 的项目中很多需要水波纹的点击效果,Flutter 当然也提供了类似的效果,除了 FlatButton 按钮系列外,Flutter 还提供了 InkWell 水波纹效果,使用很方便,在需要的地方嵌套即可;例如:用在 ListViewitem中整体效果会好很多。

new Container(
    child: new InkWell(
//   highlightColor: Colors.red,
    splashColor: Colors.greenAccent,
    onTap: () {
      Scaffold.of(context).showSnackBar(new SnackBar(
        content: new Text('Tap'),
      ));
    },
    child: Container(
      width: 120.0,
      height: 40.0,
      child: new Center( child: new Text("测试水波纹"), ),
    ),
)), 
注意事项:
  1. 使用 InkWell 时内外层均不建议添加背景色,InkWell 默认的水波纹颜色很浅,背景色会遮挡波纹效果;
  2. 通过修改 splashColor: Colors.greenAccent, 属性可以动态修改水波纹的波纹颜色,但如果修改高亮色属性 highlightColor,则相当于修改背景色;
  3. 请一定添加 InWell 手势触发事件,如 onTap 等。

2. Stack 位置叠加

      Flutter 没有提供 Android 那么丰富的布局样式,只用 Row/Column/Stack 即可满足需求,而小菜在使用 Stack 层叠效果时发现一个很有用的属性 alignment,默认是在布局正中间,整个布局以中心点划分 x/y 轴的二维坐标系,横轴从左到右递增/纵轴从上到下递/增整体范围均为 [-1,1],可以通过设置不同的点位设置控件所在位置。

child: new ListView(
  children: <Widget>[
    new Stack(
      alignment: AlignmentDirectional.topCenter,
      children: <Widget>[
        Container( height: 200.0, color: Colors.blueGrey, ),
        new Text( "AlignmentDirectional.topCenter (0.0, -1.0)", style: new TextStyle(color: Colors.white), )
      ],
    ),
    new Stack(
      alignment: AlignmentDirectional.center,
      children: <Widget>[
        Container( height: 200.0, color: Colors.blueAccent, ),
        new Text( "AlignmentDirectional.center (0.0, 0.0)", style: new TextStyle(color: Colors.white), )
      ],
    ),
    new Stack(
      alignment: AlignmentDirectional.bottomEnd,
      children: <Widget>[
        Container( height: 200.0, color: Colors.greenAccent, ),
        new Text( "AlignmentDirectional.bottomEnd (-1.0, -1.0)", style: new TextStyle(color: Colors.white), )
      ],
    ),
    new Stack(
      alignment: Alignment(-0.5, -0.5),
      children: <Widget>[
        Container( height: 200.0, color: Colors.redAccent, ),
        new Text( "AlignmentDirectional (-0.5, -0.5)", style: new TextStyle(color: Colors.white), )
      ],
    ),
  ],
),

3. IndexedStack 栈式层叠效果

      小菜在偶然的机会查看到比 Stack 更高级一层的用法 IndexedStack,是一系列的 Stack 数组,多了一个 index 熟悉,根据 index 显示具体的层级。小菜觉得在处理显隐性方面会起到很大作用。

Widget childIndexedStack(BuildContext context) {
  return new IndexedStack(
    index: 1, // 代表第二层
    children: <Widget>[
      new Column(
        children: <Widget>[ new Icon(Icons.looks_one, color: Colors.blueAccent), new Text("第一页") ],
      ),
      new Column(
        children: <Widget>[ new Icon( Icons.looks_two, color: Colors.greenAccent ), new Text("第二页") ],
      ),
      new Column(
        children: <Widget>[ new Icon(Icons.looks_3, color: Colors.redAccent), new Text("第三页") ],
      ),
      new Column(
        children: <Widget>[ new Icon(Icons.looks_4, color: Colors.yellowAccent), new Text("第四页") ],
      )
    ],
    alignment: Alignment.center,
  );
}
注意事项:
  1. index 默认为 0,即如果不处理 index 属性值时默认展示第一层 Stack
  2. index 从下标从 0 开始,层数递增,如果超过最大层数或为负数时,全部不显示。

4. Table 表格布局

      小菜有个小需求是绘制各个边框,偷懒想到了 Table 布局,用法与 Android 的基本相同,设置每一行的 TableRow 并添加相应的 item,很方便的添加 border 边框,并设置边框的基本样式。

Widget childTableWid(BuildContext Context) {
  return new Table(
    border: new TableBorder.all(
        color: Colors.blueAccent, width: 1.0, style: BorderStyle.solid),
    children: <TableRow>[
      new TableRow(children: <Widget>[
        new Text("姓名", textAlign: TextAlign.center, style: new TextStyle(fontSize: 18.0)),
        new Text("地址", textAlign: TextAlign.center, style: new TextStyle(fontSize: 18.0))
      ]),
      new TableRow(children: <Widget>[
        new Text("唐三藏", textAlign: TextAlign.center),
        new Text("北京市海淀区", textAlign: TextAlign.center)
      ]),
      new TableRow(children: <Widget>[
        new Text("孙悟空", textAlign: TextAlign.center),
        new Text("北京市朝阳区", textAlign: TextAlign.center)
      ]),
      new TableRow(children: <Widget>[
        new Text("猪八戒", textAlign: TextAlign.center),
        new Text("北京市西城区北京市西城区北京市西城区北京市西城区", textAlign: TextAlign.center)
      ]),
      new TableRow(children: <Widget>[
        new Text("沙僧", textAlign: TextAlign.center),
        new Text("北京市东城区北京市东城区北京市东城区北京市东城区", textAlign: TextAlign.center)
      ])
    ],
  );
}
注意事项:

      Table 中默认每一个 TableRow 中子 item 数量要相同,否则会报异常,如果需要合并单元格的话需要自定义单元格。

5. Wrap 流式布局

      小菜需要在每行布局中根据文字内容长度自定义展示个数,单独的用 RowColumn 不能实现很好的效果,这时候发现 Flutter 提供的强大的 Wrap 流式布局,自动根据需要显示的内容设置宽度,大大减少了开发的成本。对于日常的需求很方便也很快捷。

Widget childWrapWid(BuildContext context) {
  return new Wrap(
    spacing: 10.0,
    direction: Axis.horizontal,
    alignment: WrapAlignment.start,
    children: <Widget>[
      new Text("今日热点", style: new TextStyle(fontSize: 16.0)),
      new Text("新闻早知道", style: new TextStyle(fontSize: 16.0)),
      new Text("政情一点通", style: new TextStyle(fontSize: 16.0)),
      new Text("我爱北京", style: new TextStyle(fontSize: 16.0)),
      new Text("赞", style: new TextStyle(fontSize: 16.0)),
      new Text("话题+", style: new TextStyle(fontSize: 16.0)),
      new Text("聊一聊", style: new TextStyle(fontSize: 16.0)),
      new Text("生活小常识", style: new TextStyle(fontSize: 16.0)),
      new Text("段子手", style: new TextStyle(fontSize: 16.0)),
      new Text("天气预报", style: new TextStyle(fontSize: 16.0)),
      new Text("重大看点", style: new TextStyle(fontSize: 16.0)),
      new Text("新闻小助手", style: new TextStyle(fontSize: 16.0)),
    ],
  );
}
注意事项:
  1. Wrap 中内容默认是横向排列,通过调整 direction: Axis.horizontal, 属性修改排列方向;
  2. 当横向排列时 spacing: 10.0, 属性为横向 item 间距;runSpacing: 20.0, 为每一行之间的间距;当为纵向排列时,则相反。
横向.jpg
纵向.jpg

      小菜刚接触 Flutter 时间不长,还有很多不清楚和不理解的地方,如果又不对的地方还希望多多指出。

来源:阿策小和尚

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