- make otf and ttf sample match as much as possible
This commit is contained in:
parent
9a43ca89bc
commit
caa78e1c25
@ -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")
|
||||||
```
|
```
|
||||||
"""
|
"""
|
||||||
|
Loading…
x
Reference in New Issue
Block a user