summaryrefslogtreecommitdiff
path: root/embroider_input.py
diff options
context:
space:
mode:
authorLex Neva <lexelby@users.noreply.github.com>2018-04-15 19:40:46 -0400
committerGitHub <noreply@github.com>2018-04-15 19:40:46 -0400
commitb134a8dafad390f9c197d9439669db7001f4e8d8 (patch)
tree338fd72785708189dbbdf7cd06f4f0f8f90717d9 /embroider_input.py
parent69c64bf3a7619b070768d68ccecf62bb97306864 (diff)
parent28e2250d8c937e1c7dcd114b6392b1a0f90251da (diff)
Merge pull request #145 from lexelby/lexelby-embroidery-input
input extension for all libembroidery-supported formats
Diffstat (limited to 'embroider_input.py')
-rw-r--r--embroider_input.py61
1 files changed, 61 insertions, 0 deletions
diff --git a/embroider_input.py b/embroider_input.py
new file mode 100644
index 00000000..04d79d4f
--- /dev/null
+++ b/embroider_input.py
@@ -0,0 +1,61 @@
+import sys
+import os
+from libembroidery import *
+from inkex import etree
+import inkex
+from inkstitch import PIXELS_PER_MM, INKSCAPE_LABEL, _
+from inkstitch.stitch_plan import StitchPlan
+from inkstitch.svg import render_stitch_plan
+
+
+def pattern_stitches(pattern):
+ stitch_pointer = pattern.stitchList
+ while stitch_pointer:
+ yield stitch_pointer.stitch
+ stitch_pointer = stitch_pointer.next
+
+
+def main(embroidery_file):
+ pattern = embPattern_create()
+ embPattern_read(pattern, embroidery_file)
+ embPattern_flipVertical(pattern)
+
+ stitch_plan = StitchPlan()
+ color_block = None
+ current_color = None
+
+ for stitch in pattern_stitches(pattern):
+ if stitch.color != current_color:
+ thread = embThreadList_getAt(pattern.threadList, stitch.color)
+ color = thread.color
+ color_block = stitch_plan.new_color_block((color.r, color.g, color.b))
+ current_color = stitch.color
+
+ if not stitch.flags & END:
+ color_block.add_stitch(stitch.xx * PIXELS_PER_MM, stitch.yy * PIXELS_PER_MM,
+ jump=stitch.flags & JUMP,
+ stop=stitch.flags & STOP,
+ trim=stitch.flags & TRIM)
+
+ extents = stitch_plan.extents
+ svg = etree.Element("svg", nsmap=inkex.NSS, attrib=
+ {
+ "width": str(extents[0] * 2),
+ "height": str(extents[1] * 2),
+ "viewBox": "0 0 %s %s" % (extents[0] * 2, extents[1] * 2),
+ })
+ render_stitch_plan(svg, stitch_plan)
+
+ # rename the Stitch Plan layer so that it doesn't get overwritten by Embroider
+ layer = svg.find(".//*[@id='__inkstitch_stitch_plan__']")
+ layer.set(INKSCAPE_LABEL, os.path.basename(embroidery_file))
+ layer.attrib.pop('id')
+
+ # Shift the design so that its origin is at the center of the canvas
+ # Note: this is NOT the same as centering the design in the canvas!
+ layer.set('transform', 'translate(%s,%s)' % (extents[0], extents[1]))
+
+ print etree.tostring(svg)
+
+if __name__ == '__main__':
+ sys.exit(main(*sys.argv[1:]))