2019-01-09 Flutter 实现流式布局

先来看看效果图吧


想必很多同学已经开始体验flutter了吧,如果还没有安装,请移步
flutter 中文网
进行安装。

不过别着急,光看个热闹也是可以的,顺便熟悉一下 flutter 的语法,也是很不错的哦

当然,在安装flutter过程中,可能会遇到一些坑,我只是记录了我自己的坑,如果想了解,请查阅我之前的文章。
那么,接下来,我们步入正题,我自行切入小白视角,大神路过
请手下留情,欢迎共同探讨

创建Flutter 流式布局工程

点击,然后默认next


然后改名,next

然后就创建好了

第一次创建Flutter项目的时候,可能时间会长一些,耐心等待就好。
创建好后,Flutter有一个示例项目,如果第一次玩的话,可以看一看,如下。

这样,我们项目就创建好了,接下来,我们开始正式编写流式布局代码

开始编写流式布局

上面,我们看到flutter项目的目录结构很好玩

  • android
  • ios
  • lib
    等等,而android中的清单文件是这个样子的

    说明flutter仅仅是把android的这个MainActivity 当做一个壳子,里面嵌入了自己的代码。
    而我们要编辑的文件则是lib包下面的main.dartdart文件

    我们先看一下示例代码

    这个示例代码的架子我还留着,但是,我要修改一下,主要动的是
    MyHomePage这一部分,如图

    body需要修改
    floatingActionButton我们就不要了,所以,经过修改之后的是这样的

    好了,接下来的关键就是这个流式布局怎么写😭

重头戏来了

1、首先,我们先随机生成文字,用来准备要显示的文字

这里选择一个包含很多单词的单词库

    import 'package:english_words/english_words.dart'; 

见下图

注意,这个时候填完main.dart文件会报错的,这里不用管,下面执行完命令之后就没事了

不过在此之前,需要在项目中的pubspec.yaml文件中填加一下依赖

      english_words: ^3.1.0

文件的位置及添加依赖的位置见下图

好了,上面两步都做好之后,还需要在terminal执行一下命令,用来导入这个单词库

flutter packages get

回车即可。

这样,这个单词库就可以使用了,而且main.dart文件也不会报错了,使用方法,我们这里也很简单,就是随机生成一个单词

    var wp=WordPair.random();//得到一个随机生成单词的wordpair
    wp.asPascalCase;//拿到单词的内容

OK,生成单词的问题搞定了

2、再来搞定单个块吧

这个东西,我们用Container来做
先来看下Container的属性


很简单,用color做颜色,用child做文字即可,height我们固定,padding也固定
来看一下单个块的代码


ok,如上图,我们先将单个弄出来,然后返回,这样跑出来的效果是这样的

哦,效果还可以,就是有点小瑕疵,不过我们先不管,最后再调整即可。
注意上面的文字用到了Text控件,这个控件的属性是这样的,大家可以参考一下


青色的表示常用的属性
好了,下面我们开始逐行添加单词块

3、逐行添加单词块

根据上面的代码先进行一下调整,将生成单个单词块的代码抽取出来,抽取完成如下图:


创建一个方法,根据用户输入创建单词块的数量来创建n多个单词块,并将单词块存储在集合中

是不是很简单,接下来,遍历这个集合,然后逐行添加,这个时候需要考虑到行宽行高

本文的关键来了

flutter为我们提供了一个Flow的控件,这是他的结构

所以,这里我们直接借助Flow即可,再也不用像Android那样重写LinearLayout了。


根据官方提示,paintChildren是用来控制Flow中子控件的排列的
shouldRePaint则是决定是否重绘
接下来,我们开始编写paintChildren方法

ok,具体的代码及注释都已标注,请仔细阅读,这些东西,其实是本文章最重要的东西。

4、添加好后,修改我们之前的生成Widget的方法,实现流式布局的显示


这一步之后,效果就出来了~~~
请看


00.jpg

5、其实基本已经搞定了,但是现在和顶部的效果图还是有一定区别的,效果图中的文字是相对块居中的不知道小伙伴有没有注意到。

所以,后期还需要微调一下



我这里是使用了Stack进行了包裹,实现了居中的效果


6、最终效果~

总结
第一次使用flutter写东西,写的有些流水账,谈一下感想:
flutter 这个东西大体跟 java 还是很像的,只是布局不再像以前编辑 xml 文件,而是又回到了通过代码实现,不过实现方式其实 dart 语言提供了很多 Widget,等待我们挖掘。当然了,页面的跳转,他也有自己的方式
想关注更多flutter的东西,请大家持续关注~~~

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

推荐阅读更多精彩内容