为了获取字形宽度,我将TTF
字体转换为AFM
,然后解析AFM
文件的内容以获取每个字形的宽度。
由于从技术上讲,fontforge
是从二进制文件中捕获字形宽度TTF
,然后AFM
基于AFM
标准模板创建字体文件。我想知道是否可以TTF
通过 fontforge 命令直接将文件转换为字形宽度列表?!?
FontForge 包含两个解释器,因此您可以编写脚本来修改字体。其中一个解释器是 Python(首选),一个是遗留语言。Fontforge 嵌入了 Python,但也可以将 Fontforge 构建为 Python 扩展。
那么您将使用什么:Python还是传统语言?什么界面:命令行或GUI或Python 扩展?
脚本可以在文件中,也可以只是作为参数呈现的字符串。您可能需要指定与 -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
打开字体。然后选择:“文件”>“执行脚本...”。进入:
Select('A')
Error(ToString(GlyphInfo('Width')))
单击“确定”。
首先是单个字形(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()
也选择了非字形。访问不存在的字形会引发错误。