如何在Pyglet中加载同一系列的字体变体?

时间:2013-02-20 10:29:45

标签: python fonts pyglet

我想在Pyglet中显示多种带有各种字体的文本标签。在这种情况下,我使用“Ubuntu”字体,粗体和其他时间斜体。在这种情况下,我将Ubuntu-B.ttfUbuntu-BI.ttf作为字体文件。

根据instructions的指示,我正在加载字体:

pyglet.font.add_file(font_filename)

然后使用它的面部名称(我正在硬编码“Ubuntu”,因为我看不到从字体文件中获取它的方法):

label = pyglet.text.Label(text="Hello", font_name="Ubuntu", font_size=16)

不幸的是,Pyglet字体系统似乎只注册了第一个带有该名称Ubuntu的字体,并且它用于所有字体实例,斜体或其他字体。

因此,如果我先加载Ubuntu-BI.ttf,那么Ubuntu的所有用法都是斜体。如果我首先加载Ubuntu-B.ttf,那么所有使用都是非斜体粗体,即使我在稍后阶段加载斜体字体。

我无法看到在运行时清除或删除已加载字体的明显方法。有办法解决这个问题吗?

2 个答案:

答案 0 :(得分:4)

我找到了自己的解决方案。有一个名为pyglet.font.ttf.TruetypeInfo的未记录的类可用于获取特定字体文件的正确面部名称。这允许我在尝试使用不同的字体时使用正确的面部名称(而不是依赖于Pyglet来根据不完整的面部名称选择最佳选项)。所以我现在可以直接使用我需要的字体:

def load_font(path):
    # load external font from file
    p = TruetypeInfo(path)
    name = p.get_name("name")
    p.close()
    font.add_file(path)
    print("Loaded font " + name + " from " + path)

参考pyglet-users主题。

答案 1 :(得分:0)

根据meowsqueak的回答,您可能希望使用get_name('family')代替get_name('name')。更具体地说,在我的情况下,我有一个仅包含Bold版本的.ttf文件。使用

    p = pyglet.font.ttf.TruetypeInfo(path)
    print p.get_name('name')
    print p.get_name('family')

制作

Orbitron Bold
Orbitron

pyglet没有用

获取字体
pyglet.text.Label(text="Text", font_name='Orbitron Bold')

但是

pyglet.text.Label(text="Text", font_name='Orbitron', bold=True,

的工作。