2016-09-27 19:49:41 +02:00

58 lines
1.7 KiB
Python

from __future__ import print_function, division, absolute_import
from fontTools import ttLib
from fontTools.ttLib.tables import otTables as ot
# VariationStore
def buildVarRegionAxis(axisSupport):
self = ot.VarRegionAxis()
self.StartCoord, self.PeakCoord, self.EndCoord = axisSupport
return self
def buildVarRegion(support, axisTags):
self = ot.VarRegion()
self.VarRegionAxis = []
for tag in axisTags:
self.VarRegionAxis.append(buildVarRegionAxis(support.get(tag, (0,0,0))))
self.VarRegionAxisCount = len(self.VarRegionAxis)
return self
def buildVarRegionList(supports, axisTags):
self = ot.VarRegionList()
self.AxisCount = len(axisTags)
self.VarRegion = []
for support in supports:
self.VarRegion.append(buildVarRegion(support, axisTags))
self.VarRegionCount = len(self.VarRegion)
return self
def buildVarDeltas(varTupleIndexes, items):
self = ot.VarDeltas()
self.Format = 1 if all(all(128 <= delta <= 127 for delta in item) for item in items) else 2
self.VarRegionIndex = list(varTupleIndexes)
tupleCount = self.VarRegionCount = len(self.VarRegionIndex)
records = self.Item = []
for item in items:
assert len(item) == tupleCount
record = ot.VarItemByteRecord() if self.Format == 1 else ot.VarItemShortRecord()
record.Deltas = list(item)
records.append(record)
self.ItemCount = len(self.Item)
return self
def buildVarStore(varTupleList, varDeltasList):
self = ot.VarStore()
self.Format = 1
self.Reserved = 0
self.VarRegionList = varTupleList
self.VarDeltas = list(varDeltasList)
self.VarDeltasCount = len(self.VarDeltas)
return self
# Variation helpers
def buildVarIdxMap(varIdxes):
self = ot.VarIdxMap()
self.mapping = list(varIdxes)
return self