- mongodb - 在 MongoDB mapreduce 中,如何展平值对象?
- javascript - 对象传播与 Object.assign
- html - 输入类型 ="submit"Vs 按钮标签它们可以互换吗?
- sql - 使用 MongoDB 而不是 MS SQL Server 的优缺点
我需要显示长文本,这将占用几个屏幕/页面。我还必须添加一些功能,所以我想实现自己的文本显示组件。
我找到了两个对应这个任务的类:
TextPainter
对文本使用 TextSpan
使用 paint(canvas, offset) 进行绘画
段落
对文本和样式使用“队列”
使用 Canvas.drawParagraph(paragraph, offset) 进行绘画
它们有什么区别,用哪一个?!
如果文本包含100行,并且一页只能放置10行,那么如何在下一页上绘制截断的文本直到什么都没有?
最佳答案
tl;dr: imo TextPainter
> Paragraph
(因为 API 更好)。
我创建了 simple example app比较两者TextPainter
和 Paragraph
Canvas
上呈现文本的方法(CustomPainter
)。两种方法都很好,都使用了不同的方法,都有奇怪的摆动。
TextPainter
首先我想提一下 TextPainter
界面似乎更容易 - 至少对我而言。您只需将 text
指定为 TextSpan
条目或树 - 奇怪的是,它不是默认值 - textDirection
。您还可以提供诸如 maxLines
、style
和 textAlign
等选项(以及其他一些选项)。然后,您需要使用 layout
来指定渲染的布局方式(嗯,仅限 maxWidth
)。最后,在指定的 Offset
上的特定 Canvas
上 paint
。
final TextPainter textPainter = TextPainter(
text: TextSpan(text: text, style: style),
textAlign: TextAlign.justify,
textDirection: TextDirection.ltr
)
..layout(maxWidth: size.width - 12.0 - 12.0);
textPainter.paint(canvas, const Offset(12.0, 36.0));
使用的 TextSpan
在 Flutter 中非常普遍 - RichText
和其他小部件也在使用这个类。我还必须注意,使用 TextPainter
可以让您检查 height
和 width
的像素(在渲染之前) .
段落
第二:段落
。这似乎是更基础的程序方法。正如您在下面看到的,Paragraph
方法不太干净。首先你必须使用 ParagraphBuilder
(因为 Paragraph
没有构造函数)。你需要用 ParagraphStyle
喂它包含各种文本样式,如字体信息、textAlign
、maxLines
等。然后您可以使用 pushStyle
、pop
和 addText
来准备段落的下一部分和下一部分。在 build
之后,您将获得 Paragraph
,您可以在 Canvas
上 drawParagraph
。
final ui.ParagraphBuilder paragraphBuilder = ui.ParagraphBuilder(
ui.ParagraphStyle(
fontSize: style.fontSize,
fontFamily: style.fontFamily,
fontStyle: style.fontStyle,
fontWeight: style.fontWeight,
textAlign: TextAlign.justify,
)
)
..pushStyle(style.getTextStyle())
..addText(text);
final ui.Paragraph paragraph = paragraphBuilder.build()
..layout(ui.ParagraphConstraints(width: size.width - 12.0 - 12.0));
canvas.drawParagraph(paragraph, const Offset(12.0, 36.0));
请注意,TextStyle
有两种类型(Dart UI 和 Flutter)。与 pushStyle
一致,您可以看到 Flutter Painting library TextStyle
变成了Dart UI TextStyle
.另一个奇怪的事情是,您可以/需要在 ParagraphBuilder
中指定一些字体设置 - 即使您将在后面的行中使用 pushStyle
。并且 layout
必须用 width
指定。
我认为我可以更好地用于读取文件等情况,尤其是格式化,因为不需要将文件解析为 TextSpan
树,这可能会很昂贵。如果您知道自己在做什么,我想它也可以比其他方法快一点,但我没有时间深入挖掘它。
当文本过多时,您可能想要剪辑文本。 Paragraph
和 TextPainter
都暴露了 maxLines
- 设置最大行数 - 和 didExceedMaxLines
- 检测是否超过限制-, 以这种或那种方式。还有 canvas.clipRect
和相关方法允许将所有绘图剪切到选定的空间中。
还有简单的performance test (发布时),这表明这两种方法具有可比性(在我的测试案例中,TextPainter
比 Paragraph
快不超过 2%)。也可能是测量误差¯\_(ツ)_/¯。
关于dart - Flutter - 用于绘图书页面的 TextPainter 与段落,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51640388/
我正在尝试编写一个函数来制作绘图并将其自动保存到文件中。 我努力用它来动态地做的技巧[plotname=varname & filename=varname &], 并使其与从循环中调用它兼容。 #
有人可以帮助我如何在绘图条形图中添加“下拉”菜单。 我在以下链接 ( https://plot.ly/python/v3/dropdowns/ ) 上找到了一些信息,但我正在努力调整代码,因此下拉选项
我不确切知道如何表达这一点,但我本质上希望根据其他数据之前的列值将数据分组为 Excel 图的系列。例如: size weight apple 3 35 orange 4
我正在为出版物创建图表并希望它们具有相同的字体大小。 当我用多图创建图形时,字体大小会减小,即使我没有更改tiff() 分辨率或pointsize 参数。我根据最终适合的地 block 数量增加了图形
我用 glm::perspective(80.0f, 4.0f/3.0f, 1.0f, 120.0f);并乘以 glm::mat4 view = glm::lookAt( glm::vec3(
我在 Shiny UI 中有一个情节。如果我更改任何输入参数并且通过 react 性图将会改变。但是让我们考虑以下情况:- Shiny UI 中的绘图可以说股票的日内价格变动。为此,您查询一些实时数据
我对 R 有点陌生。我在以下两个线程中跟踪并实现了结果: http://tolstoy.newcastle.edu.au/R/e17/help/12/03/7984.html http://lukem
我想在 WPF 控件中使用 GDI+ 绘图。 最佳答案 有多种方法可以做到这一点,最简单的方法是锁定您使用 GDI 操作的位图,获取像素缓冲区(从锁定中获取的 BitmapData 中的 Scan0
如何在以下取自其网站的绘图示例中隐藏颜色条? df % layout(title = '2014 Global GDPSource:CIA World Factbook',
我有两列数据,X 和 Y,每个条目在两个向量的小数点后都有 4 位数据。 当我使用 plot(x,y) 绘制简单图时,轴上显示的数据精确到小数点后两位。如何在两个轴上将其更改为小数点后 4 位精度?
我目前正在使用 Canvas 处理 JavaFX-Drawing-Application。在 GraphicsContext 的帮助下,我使用 beginPath() 和 lineTo() 方法绘制线
如果这个问题已经得到解答,但我无法找到我需要的东西,我提前道歉。我想从名为 data1.dat、data2.dat 的文件中绘制一些结果......我设法通过循环导入数据,但我无法使用循环绘制结果。仅
我的 pandas 数据框中有一个功能,可以(可能)具有多个级别。我可以使用以下方法获得独特的级别: reasons = df["Reason"].unique() 我可以通过执行以下操作在单个图表上
我在 Ubuntu 14 和 Windows 7(均为 64 位)中用 Python 绘制结果时遇到问题。作为一个简单的比较,我做了: from tvb.simulator.lab import *
以下代码相当简单 - 它用随机选择的像素填充设计表面 - 没什么特别的(暂时忽略第二种方法中的 XXXXXXX)。 private void PaintBackground() { Rando
我正在尝试制作一个绘制函数图形的 swing 应用程序(现在很简单,例如 x+2)但我在根据屏幕坐标制作我的点的数学坐标时遇到问题。我希望它在我的图表中简单地画一条从 P1(0,1) 到 P2(1,2
编辑 4:问题的新格式 背景:我有一个扩展 JFrame 的类 Window,在 JFrame 中我有一个 Canvas 。我向 Canvas 添加自定义对象。这个对象的唯一目的(为了争论)是在 Ca
我需要为即将到来的锦标赛标记阶梯,但我找不到任何方法来语义标记它。到目前为止我看到的唯一方法是 mark it up as a table ,我想不惜一切代价避免这种情况。 有什么想法吗? 最佳答案
我目前正在为一个小型 uC 项目编写 UI。在计算垂直线的位置时遇到一些问题。这个想法是将红线沿 x 轴移动到矩形的末端。 使用无限旋转编码器递增的值,范围为 0 到 800,增量为 1。矩形的左侧是
我正在尝试绘制光分布图。我想准确地执行此问题的第一步所要求的:Statistical analysis on Bell shaped (Gaussian) curve . 现在我有一组值。我希望数组元
我是一名优秀的程序员,十分优秀!