如何计算边界矩形的宽度,以便文本包装以适合特定比例?

时间:2011-02-20 00:23:45

标签: algorithm text

如果我有以下文字:

“你好,这是一段文字,将显示在屏幕的矩形区域”

我知道文字的总宽度。

我试图根据给定的比率找到一个包围文本的边界宽度。

算法是什么?

例如,我想总是尝试按宽度和高度包装文本,其中边界矩形的比例为16:9。无论文本长度如何,都需要这样做。

2 个答案:

答案 0 :(得分:2)

这是我如何用伪代码

function calcWidth(string text, int rows, float ratio)

    let H be int with value /* how many pixels high is a row? */
    let total_width be int with value 0
    for each character c in string text
        let total_width be total_width + pixel_width(c)
    end for

    let W = total_width / length(text)

    /* RATIO = (H * row) / (W * col) */
    /* means col = (H * row) / (W * RATIO) */

    let cols be int with value (H * rows) / (W * ratio)

    return cols
end function

我可能还会检查一下,如果5行是不可接受的,但是6行更糟,我知道5比6好,所以在这种情况下我会返回5。

让我们回顾一下我们所知道的事情

对于等宽字体:

    H * rows
   ---------- = RATIO
    W * cols

现在,我们知道每行的cols不会相同,因为我们可能没有monospaced。但是,我们可以将cols近似为字母总数除以行数。

        H * rows
    -------------- = RATIO
    W * len / rows

      H * rows^2
    -------------- = RATIO
       W * len

现在你知道除了行之外的所有这些变量,所以求解行

   rows = roundUp ( SQRT (  (RATIO * W * len) / h ) )

现在我们从上面知道cols大约是

   cols = (H * rows) / (W * ratio)

有了这两个你应该对你的盒子有一个不错的猜测。

您可能需要渲染它才能看到,并且根据错误的大小和边距,可能会向上或向下增加或减少一行或多行。

答案 1 :(得分:0)

由于字长是不可预测的,我认为没有比生成和测试更好的方法。您可以从找到一个单词边界开始,比如说,在文本的第9/16行,并使用到该点的宽度作为候选宽度。然后迭代包装所有文本,测量结果,并向左或向右移动第一个边界,直到您尽可能接近。这为您提供了第一行以及上限和下限(一个词多一个或少一个词)的最佳中断,如果您愿意,可以使用二进制搜索进一步搜索最佳解决方案。