diff options
| author | Lex Neva <lexelby@users.noreply.github.com> | 2018-04-15 19:40:46 -0400 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2018-04-15 19:40:46 -0400 |
| commit | b134a8dafad390f9c197d9439669db7001f4e8d8 (patch) | |
| tree | 338fd72785708189dbbdf7cd06f4f0f8f90717d9 /embroider_input.py | |
| parent | 69c64bf3a7619b070768d68ccecf62bb97306864 (diff) | |
| parent | 28e2250d8c937e1c7dcd114b6392b1a0f90251da (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.py | 61 |
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:])) |
