我想在Pyglet中显示多种带有各种字体的文本标签。在这种情况下,我使用“Ubuntu”字体,粗体和其他时间斜体。在这种情况下,我将Ubuntu-B.ttf
和Ubuntu-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
,那么所有使用都是非斜体粗体,即使我在稍后阶段加载斜体字体。
我无法看到在运行时清除或删除已加载字体的明显方法。有办法解决这个问题吗?
答案 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,
的工作。