- make otf and ttf sample match as much as possible

This commit is contained in:
Medhat Assaad 2019-07-19 19:37:08 -05:00 committed by GitHub
parent 9a43ca89bc
commit caa78e1c25
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -91,19 +91,21 @@ def drawTestGlyph(pen):
fb = FontBuilder(1024, isTTF=False) fb = FontBuilder(1024, isTTF=False)
fb.setupGlyphOrder([".notdef", ".null", "A", "a"]) fb.setupGlyphOrder([".notdef", ".null", "space", "A", "a"])
fb.setupCharacterMap({65: "A", 97: "a"}) fb.setupCharacterMap({32: "space", 65: "A", 97: "a"})
advanceWidths = {".notdef": 600, "space": 500, "A": 600, "a": 600, ".null": 0}
advanceWidths = {".notdef": 600, "A": 600, "a": 600, ".null": 600}
familyName = "HelloTestFont" familyName = "HelloTestFont"
styleName = "TotallyNormal" styleName = "TotallyNormal"
version = "0.1"
nameStrings = dict( nameStrings = dict(
familyName=dict(en=familyName, nl="HalloTestFont"), familyName=dict(en=familyName, nl="HalloTestFont"),
styleName=dict(en=styleName, nl="TotaalNormaal"), styleName=dict(en=styleName, nl="TotaalNormaal"),
uniqueFontIdentifier="fontBuilder: " + familyName + "." + styleName, uniqueFontIdentifier="fontBuilder: " + familyName + "." + styleName,
fullName=familyName + "-" + styleName, fullName=familyName + "-" + styleName,
psName=familyName + "-" + styleName, psName=familyName + "-" + styleName,
version="Version " + version,
) )
pen = T2CharStringPen(600, None) pen = T2CharStringPen(600, None)
@ -111,23 +113,21 @@ drawTestGlyph(pen)
charString = pen.getCharString() charString = pen.getCharString()
charStrings = { charStrings = {
".notdef": charString, ".notdef": charString,
"space": charString,
"A": charString, "A": charString,
"a": charString, "a": charString,
".null": charString, ".null": charString,
} }
fb.setupCFF(nameStrings["psName"], {"FullName": nameStrings["psName"]}, charStrings, {}) fb.setupCFF(nameStrings["psName"], {"FullName": nameStrings["psName"]}, charStrings, {})
lsb = {gn: cs.calcBounds(None)[0] for gn, cs in charStrings.items()} lsb = {gn: cs.calcBounds(None)[0] for gn, cs in charStrings.items()}
metrics = {} metrics = {}
for gn, advanceWidth in advanceWidths.items(): for gn, advanceWidth in advanceWidths.items():
metrics[gn] = (advanceWidth, lsb[gn]) metrics[gn] = (advanceWidth, lsb[gn])
fb.setupHorizontalMetrics(metrics) fb.setupHorizontalMetrics(metrics)
fb.setupHorizontalHeader(ascent=824, descent=200) fb.setupHorizontalHeader(ascent=824, descent=200)
fb.setupNameTable(nameStrings) fb.setupNameTable(nameStrings)
fb.setupOS2() fb.setupOS2(sTypoAscender=824, usWinAscent=824, usWinDescent=200)
fb.setupPost() fb.setupPost()
fb.save("test.otf") fb.save("test.otf")
``` ```
""" """