发表日期:2018-12 文章编辑:小灯 浏览次数:6393
Google 前段时间举办了Flutter Live。 哔哩哔哩有视频: https://www.bilibili.com/video/av37844001, 大家也可以在微信公众号: 谷歌开发者。
最近开始学习使用flutter。说点鲜闲话,flutter 有点蛋疼的是如何做适配的问题,在Android Native, 使用dp,但是flutter 并没有这个概念。
回归正文,最近有一个需求,做一个垂直布局的文字。啊? flutter Text widget 的TextDirection 只有ltr 和rtl , 是的就是Android Native的左右顺序布局,为了一些阿拉伯国家,他们文字是从右边开始写的。
先看效果:
原理:
Text 步步相android native , 有canvas,无法重写控件。所以需要用到 CustomPaint 、 CustomPainter 来自定义控件。
自定义 VerticalText 继承 CustomPainter,实现基本原理、:我们将句子拆成一个一个的字,每绘制一个字的时候就计算该字绘制的位置, 主要代码:
for (int i = 0; i < text.length; i++) { TextSpan span = new TextSpan(style: textStyle, text: text[i]); TextPainter tp = new TextPainter( text: span, textAlign: TextAlign.center, textDirection: TextDirection.ltr); tp.layout();if (offsetY + tp.height > height) { // 如果一列不够一个文字,就新起一列。 newLine = true; offsetY = 0; // 如果是新起一列,y 从0 开始 }if (newLine) { offsetX -= maxWidth; newLine = false; }if (offsetX < -maxWidth) { break; // 如果超出左边边界,不绘制。 }tp.paint(canvas, new Offset(offsetX, offsetY)); offsetY += tp.height; }
就这么简单就实现了。
Github地址: https://github.com/wilin52/vertical_text
欢迎大家提出建议和意见,有问题请联系 wilin52@163.com,其他联系方式 简介以及Github 简介里面有。
日期:2018-10 浏览次数:7253
日期:2018-12 浏览次数:4328
日期:2018-07 浏览次数:4876
日期:2018-12 浏览次数:4174
日期:2018-09 浏览次数:5502
日期:2018-12 浏览次数:9922
日期:2018-11 浏览次数:4804
日期:2018-07 浏览次数:4578
日期:2018-05 浏览次数:4859
日期:2018-12 浏览次数:4324
日期:2018-10 浏览次数:5139
日期:2018-12 浏览次数:6212
日期:2018-11 浏览次数:4464
日期:2018-08 浏览次数:4592
日期:2018-11 浏览次数:12630
日期:2018-09 浏览次数:5579
日期:2018-12 浏览次数:4833
日期:2018-10 浏览次数:4188
日期:2018-11 浏览次数:4528
日期:2018-12 浏览次数:6063
日期:2018-06 浏览次数:4007
日期:2018-08 浏览次数:5436
日期:2018-10 浏览次数:4457
日期:2018-12 浏览次数:4525
日期:2018-07 浏览次数:4362
日期:2018-12 浏览次数:4500
日期:2018-06 浏览次数:4383
日期:2018-11 浏览次数:4375
日期:2018-12 浏览次数:4249
日期:2018-12 浏览次数:5283
Copyright ? 2013-2018 Tadeng NetWork Technology Co., LTD. All Rights Reserved.