4

为了获取字形宽度,我将TTF字体转换为AFM,然后解析AFM文件的内容以获取每个字形的宽度。

由于从技术上讲,fontforge是从二进制文件中捕获字形宽度TTF,然后AFM基于AFM标准模板创建字体文件。我想知道是否可以TTF通过 fontforge 命令直接将文件转换为字形宽度列表?!?

4

1 回答 1

7

FontForge 包含两个解释器,因此您可以编写脚本来修改字体。其中一个解释器是 Python(首选),一个是遗留语言。Fontforge 嵌入了 Python,但也可以将 Fontforge 构建为 Python 扩展。

那么您将使用什么:Python还是传统语言?什么界面:命令行GUIPython 扩展

命令行和传统语言

脚本可以在文件中,也可以只是作为参数呈现的字符串。您可能需要指定与 -lang 参数一起使用的解释器。请参阅命令行参数

$ fontforge -script scriptfile.pe {arguments}
$ fontforge -c "script-string" {arguments}
$ fontforge -lang={ff|py} -c "script-string"

扫描文档后,我编写了 scriptfile.pe:

Open($1, 1)
Select($2)
Print( GlyphInfo('Width') )

比:

$ fontforge -script scriptfile.pe YourFont.ttf A
... # Some output truncated.
1298

从 GUI 执行脚本

打开字体。然后选择:“文件”>“执行脚本...”。进入:

Select('A')
Error(ToString(GlyphInfo('Width')))

单击“确定”。

Fontforge 错误窗口

Python 扩展

首先是单个字形(docs)的宽度:

>>> import fontforge
>>> f = fontforge.open("YourFont.ttf")
>>> f['A'].width
1298

这里是你问题的答案。对于每个字形,编码索引、名称和宽度:

>>> for i in f.selection.all():
...    try:
...       name, width = f[i].glyphname, f[i].width
...       print i, name, width
...    except:
...       pass
... 
0 uni0009 0
2 uni0002 0
13 nonmarkingreturn 510
# ... Truncated ...
65707 germandbls.smcp 2266
>>>

注意:我使用 try/except 是因为不知何故f.selection.all()也选择了非字形。访问不存在的字形会引发错误。

于 2014-01-07T10:42:13.787 回答