summaryrefslogtreecommitdiff
path: root/gerbonara/newstroke.py
diff options
context:
space:
mode:
authorjaseg <git@jaseg.de>2023-07-21 17:56:24 +0200
committerjaseg <git@jaseg.de>2023-07-21 17:56:24 +0200
commit91b99a04523e7efb37dab0a5b9378c1c5a230b74 (patch)
tree37efbe927c5798b5279e5b4e3791d4ff65948d71 /gerbonara/newstroke.py
parent09c9d2672878f4099ba874f495cd4f76c919f07e (diff)
downloadgerbonara-91b99a04523e7efb37dab0a5b9378c1c5a230b74.tar.gz
gerbonara-91b99a04523e7efb37dab0a5b9378c1c5a230b74.tar.bz2
gerbonara-91b99a04523e7efb37dab0a5b9378c1c5a230b74.zip
WIP
Diffstat (limited to 'gerbonara/newstroke.py')
-rw-r--r--gerbonara/newstroke.py28
1 files changed, 24 insertions, 4 deletions
diff --git a/gerbonara/newstroke.py b/gerbonara/newstroke.py
index d0ed951..c2f3d55 100644
--- a/gerbonara/newstroke.py
+++ b/gerbonara/newstroke.py
@@ -31,12 +31,13 @@ class Newstroke:
def load(kls):
return kls()
- def render(self, text, size=1.0, x0=0, y0=0, rotation=0, h_align='left', v_align='bottom', space_width=DEFAULT_SPACE_WIDTH, char_gap=DEFAULT_CHAR_GAP, scale=(1, 1)):
+ def render(self, text, size=1.0, x0=0, y0=0, rotation=0, h_align='left', v_align='bottom', space_width=DEFAULT_SPACE_WIDTH, char_gap=DEFAULT_CHAR_GAP, scale=(1, 1), mirror=(False, False)):
text = unicodedata.normalize('NFC', text)
missing_glyph = self.glyphs['?']
sx, sy = scale
+ mx, my = mirror
x = 0
- if text in ('VDDA', 'PA9', 'VSS'):
+ if text in ('VDDA', 'PA9', 'VSS', 'FB3'):
print(text, x0, y0, rotation, h_align, v_align, scale)
if rotation >= 180:
@@ -44,6 +45,25 @@ class Newstroke:
h_align = {'left': 'right', 'right': 'left'}.get(h_align, h_align)
x0, y0 = -x0, y0
+ if scale == (1, 1) and rotation == 90:
+ rotation = 270
+ h_align = {'left': 'right', 'right': 'left'}.get(h_align, h_align)
+ v_align = {'top': 'bottom', 'bottom': 'top'}.get(v_align, v_align)
+
+ #if mx:
+ # x0 = -x0
+ # if rotation == 90:
+ # v_align = {'top': 'bottom', 'bottom': 'top'}.get(v_align, v_align)
+ # else:
+ # h_align = {'left': 'right', 'right': 'left'}.get(h_align, h_align)
+
+ if my:
+ y0 = -y0
+ if rotation == 0:
+ v_align = {'top': 'bottom', 'bottom': 'top'}.get(v_align, v_align)
+ else:
+ h_align = {'left': 'right', 'right': 'left'}.get(h_align, h_align)
+
x0, y0 = rotate_point(x0, y0, math.radians(-rotation))
alx, aly = 0, 0
@@ -77,7 +97,7 @@ class Newstroke:
x += glyph_w*size
- def render_svg(self, text, size=1.0, x0=0, y0=0, rotation=0, h_align='left', v_align='bottom', space_width=DEFAULT_SPACE_WIDTH, char_gap=DEFAULT_CHAR_GAP, scale=(1, -1), **svg_attrs):
+ def render_svg(self, text, size=1.0, x0=0, y0=0, rotation=0, h_align='left', v_align='bottom', space_width=DEFAULT_SPACE_WIDTH, char_gap=DEFAULT_CHAR_GAP, scale=(1, -1), mirror=(False, False), **svg_attrs):
if 'stroke_linecap' not in svg_attrs:
svg_attrs['stroke_linecap'] = 'round'
if 'stroke_linejoin' not in svg_attrs:
@@ -88,7 +108,7 @@ class Newstroke:
strokes = ['M ' + ' L '.join(f'{x:.3f} {y:.3f}' for x, y in stroke)
for stroke in self.render(text, size=size, x0=x0, y0=y0, rotation=rotation, h_align=h_align,
- v_align=v_align, space_width=space_width, char_gap=char_gap,
+ v_align=v_align, mirror=mirror, space_width=space_width, char_gap=char_gap,
scale=scale)]
return Tag('path', d=' '.join(strokes), **svg_attrs)