diff options
| author | Lex Neva <github.com@lexneva.name> | 2018-04-06 19:55:53 -0400 |
|---|---|---|
| committer | Lex Neva <github.com@lexneva.name> | 2018-04-09 20:15:56 -0400 |
| commit | dfbe6f9c0f12be693454390f5e92bb3dd06661cf (patch) | |
| tree | e38aaa376d6acd83a95f47804c0906f2497c3915 | |
| parent | 69c64bf3a7619b070768d68ccecf62bb97306864 (diff) | |
embroider_input.py: input extension to read embroidery formats
| -rwxr-xr-x | bin/gen-input-inx | 19 | ||||
| -rwxr-xr-x | bin/gen-output-format-option-list (renamed from bin/gen-format-list) | 0 | ||||
| -rw-r--r-- | embroider_input.py | 51 | ||||
| -rw-r--r-- | inkstitch/stitch_plan/stitch_plan.py | 26 | ||||
| -rw-r--r-- | templates/embroider_input.inx | 17 |
5 files changed, 110 insertions, 3 deletions
diff --git a/bin/gen-input-inx b/bin/gen-input-inx new file mode 100755 index 00000000..c88931ee --- /dev/null +++ b/bin/gen-input-inx @@ -0,0 +1,19 @@ +#!/usr/bin/env python + +import sys + +sys.path.append('embroidermodder/experimental/python/binding') +from libembroidery import * + +formatList = embFormatList_create() +curFormat = formatList +while(curFormat): + extension = embFormat_extension(curFormat) + description = embFormat_description(curFormat) + writerState = embFormat_readerState(curFormat) + + if writerState.strip() and embFormat_type(curFormat) != EMBFORMAT_OBJECTONLY: + print extension + + curFormat = curFormat.next + diff --git a/bin/gen-format-list b/bin/gen-output-format-option-list index 674813bb..674813bb 100755 --- a/bin/gen-format-list +++ b/bin/gen-output-format-option-list diff --git a/embroider_input.py b/embroider_input.py new file mode 100644 index 00000000..39a0e424 --- /dev/null +++ b/embroider_input.py @@ -0,0 +1,51 @@ +import sys +from libembroidery import * +from inkex import etree +import inkex +from inkstitch import PIXELS_PER_MM, _ +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) + + dimensions = stitch_plan.dimensions + svg = etree.Element("svg", nsmap=inkex.NSS, attrib= + { + "width": "%s" % dimensions[0], + "height": "%s" % dimensions[1], + "viewBox": "0 0 %s %s" % dimensions, + }) + render_stitch_plan(svg, stitch_plan) + + print etree.tostring(svg) + +if __name__ == '__main__': + sys.exit(main(*sys.argv[1:])) diff --git a/inkstitch/stitch_plan/stitch_plan.py b/inkstitch/stitch_plan/stitch_plan.py index 82584bbc..0e638f16 100644 --- a/inkstitch/stitch_plan/stitch_plan.py +++ b/inkstitch/stitch_plan/stitch_plan.py @@ -97,10 +97,21 @@ class StitchPlan(object): return sum(block.num_stitches for block in self) @property + def dimensions(self): + color_block_bounding_boxes = [cb.bounding_box for cb in self] + minx = min(bb[0] for bb in color_block_bounding_boxes) + miny = min(bb[1] for bb in color_block_bounding_boxes) + maxx = max(bb[2] for bb in color_block_bounding_boxes) + maxy = max(bb[3] for bb in color_block_bounding_boxes) + + import sys; print >> sys.stderr, color_block_bounding_boxes, minx, miny, maxx, maxy + + return (maxx - minx, maxy - miny) + + @property def dimensions_mm(self): - # TODO: implement this. Should do a bounding box calculation and - # convert to millimeters. - return "" + dimensions = self.dimensions + return (dimensions[0] / PIXELS_PER_MM, dimensions[1] / PIXELS_PER_MM) class ColorBlock(object): @@ -196,3 +207,12 @@ class ColorBlock(object): def replace_stitches(self, stitches): self.stitches = stitches + + @property + def bounding_box(self): + minx = min(stitch.x for stitch in self) + miny = min(stitch.y for stitch in self) + maxx = max(stitch.x for stitch in self) + maxy = max(stitch.y for stitch in self) + + return minx, miny, maxx, maxy diff --git a/templates/embroider_input.inx b/templates/embroider_input.inx new file mode 100644 index 00000000..148784bc --- /dev/null +++ b/templates/embroider_input.inx @@ -0,0 +1,17 @@ +<?xml version="1.0" encoding="UTF-8"?> +<inkscape-extension xmlns="http://www.inkscape.org/namespace/inkscape/extension"> + <_name>{{ format | upper }} file input</_name> + <id>org.inkstitch.input.{{ format }}</id> + <dependency type="executable" location="extensions">embroider_input.py</dependency> + <dependency type="executable" location="extensions">inkex.py</dependency> + <input> + <extension>.{{ format }}</extension> + <mimetype>application/x-embroidery-{{ format }}</mimetype> + <_filetypename>{{ description }} (.{{ format }})</_filetypename> + <_filetypetooltip>convert {{ format | upper }} file to Ink/Stitch manual-stitch paths</_filetypetooltip> + </input> + <script> + <command reldir="extensions" interpreter="python">embroider_input.py</command> + </script> +</inkscape-extension> + |
