3

昨天,我为如何在原点为top-left.

保留这种正交设置让我很难正确对齐FTGL字体,尤其是。在y 轴

void enable2D(int w, int h)
{
    winWidth = w;
    winHeight = h;

    glViewport(0, 0, w, h);

    glMatrixMode(GL_PROJECTION);
    glLoadIdentity();
    glOrtho(0, w, h, 0, 0, 1);
    glMatrixMode(GL_MODELVIEW);
}

然后渲染成这样:

glPushMatrix();
    glTranslated(X, Y + font.LineHeight(), 0);
    glScalef(1, -1, 0); //reverse scaling of y
    font.Render(str);
glPopMatrix();

我尝试测量不同字体的边界框,但结果不一致。

他们来了:

不同的字体 注意inconsistency of y-position of boxes

还有代码:

glClear(GL_COLOR_BUFFER_BIT);
glMatrixMode(GL_MODELVIEW);
glLoadIdentity();

///Draw the fonts
for (int i = 0;i < N; ++i)
{
    auto &X = x[i];
    auto &Y = y[i];
    auto &font = fonts[i];

    glColor3ub(0, 0, 0);
    glPushMatrix();
        glTranslated(X, Y + font.LineHeight(), 0);
        glScalef(1, -1, 0);
        font.Render(str);
    glPopMatrix();
}

///Draw the boxes
for (int i = 0;i < N; ++i)
{
    auto &X = x[i];
    auto &Y = y[i];
    auto &box = boxes[i];

    glColor3ub(255, 0, 0);
    glPushMatrix();
        glTranslated(X, Y, 0);
        glBegin(GL_LINE_LOOP);
        glVertex2f(box.Lower().X(),                   -box.Lower().Y());                       //top-left
        glVertex2f(box.Upper().X() - box.Lower().X(), -box.Lower().Y());                       //top-right
        glVertex2f(box.Upper().X() - box.Lower().X(), +box.Upper().Y() - box.Lower().Y() * 2); //bottom-right
        glVertex2f(box.Lower().X(),                   +box.Upper().Y() - box.Lower().Y() * 2); //bottom-left
        glEnd();
    glPopMatrix();
}

但我想实现一个完全适合渲染字体的框,如下所示:

在此处输入图像描述

我只是手动调整一些值以使其适合

具体问题是,如何在这种设置中计算渲染字体的y 位置?

我不知道是什么FTGL::Descender(),但我认为它与此有关?

我将接受任何讨论此类主题的链接作为答案。

4

1 回答 1

2

然而,经过反复试验,我发现了我正在做的错误。

盒子

首先,我应该在做这种坐标系时考虑到,盒子的最左边和最上面的部分应该被设置zero,即:

glVertex2f( 0, 0 );
glVertex2f( w, 0 );
glVertex2f( w, h );
glVertex2f( 0, h );

所以我不需要担心其他事情。从那开始,我确保在将 转换font为指定坐标时,它必须相对于左上角原点窗口(无填充、偏移等...)

字体

现在在字体部分进行翻译,我这样做:

float x_offset = (font.BBox(str).Lower().X() * font_scale);
float y_offset = (font.BBox(str).Upper().Y() * font_scale);

glPushMatrix();

    ///the coorinate should now be relative the box!
    glTranslatef( x - x_offset,
                  y + y_offset,
                  0
                );
    glScalef( font_scale, -font_scale, 0); //notice the negative in y

    font.Render(str);

glPopMatrix();

现在应该是这样的

在此处输入图像描述

在框外绘制的字体(#6),可能是由于字体的样式。

谢谢!希望有人可以帮助:D

更新:

我之前的计算有错误,无论如何,我更新了我的答案以更准确。您可以在我的编辑历史中看到更改。

更新:

这里还是有错误。仅返回当前文本的FTGL::BBox当前边界框,当当前字符串中不存在最大字形高度时,高度可能会有所不同。我再次检查源代码,但我找不到yMaxw/c 是它可以返回的最大高度。但是,我可以在iterate all over the available glpyhs and get the maximum height那里做,我认为有一个现有的功能freetype已经可以做到这一点?有人知道吗?

于 2014-03-02T08:51:58.243 回答