| from __future__ import ( |
| print_function, division, absolute_import, unicode_literals) |
| from fontTools.misc.py23 import * |
| |
| from fontTools.pens.transformPen import TransformPen |
| from .parser import parse_path |
| |
| try: |
| from xml.etree import cElementTree as ElementTree # python 2 |
| except ImportError: # pragma nocover |
| from xml.etree import ElementTree # python 3 |
| |
| |
| __all__ = [tostr(s) for s in ("SVGPath", "parse_path")] |
| |
| |
| class SVGPath(object): |
| """ Parse SVG ``path`` elements from a file or string, and draw them |
| onto a glyph object that supports the FontTools Pen protocol. |
| |
| For example, reading from an SVG file and drawing to a Defcon Glyph: |
| |
| import defcon |
| glyph = defcon.Glyph() |
| pen = glyph.getPen() |
| svg = SVGPath("path/to/a.svg") |
| svg.draw(pen) |
| |
| Or reading from a string containing SVG data, using the alternative |
| 'fromstring' (a class method): |
| |
| data = '<?xml version="1.0" ...' |
| svg = SVGPath.fromstring(data) |
| svg.draw(pen) |
| |
| Both constructors can optionally take a 'transform' matrix (6-float |
| tuple, or a FontTools Transform object) to modify the draw output. |
| """ |
| |
| def __init__(self, filename=None, transform=None): |
| if filename is None: |
| self.root = ElementTree.ElementTree() |
| else: |
| tree = ElementTree.parse(filename) |
| self.root = tree.getroot() |
| self.transform = transform |
| |
| @classmethod |
| def fromstring(cls, data, transform=None): |
| self = cls(transform=transform) |
| self.root = ElementTree.fromstring(data) |
| return self |
| |
| def draw(self, pen): |
| if self.transform: |
| pen = TransformPen(pen, self.transform) |
| for el in self.root.findall(".//{http://www.w3.org/2000/svg}path[@d]"): |
| parse_path(el.get("d"), pen) |