diff options
| author | Lex Neva <lexelby@users.noreply.github.com> | 2018-09-12 20:49:31 -0400 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2018-09-12 20:49:31 -0400 |
| commit | 3fd741a1a4218b6559184aaadcde8abca178bde2 (patch) | |
| tree | 638a96776f6deecb82150b2b97efb372084e464c /lib/stitch_plan/read_file.py | |
| parent | eff7c8d8ce7c9c1f8396c99bcf5fc15078ff99b7 (diff) | |
| parent | a876066c75eafc20547b055c5dffe8e89e4c327f (diff) | |
Merge pull request #284 from inkstitch/simulator-timeline
simulator timeline
Diffstat (limited to 'lib/stitch_plan/read_file.py')
| -rw-r--r-- | lib/stitch_plan/read_file.py | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/lib/stitch_plan/read_file.py b/lib/stitch_plan/read_file.py new file mode 100644 index 00000000..ff5a68ac --- /dev/null +++ b/lib/stitch_plan/read_file.py @@ -0,0 +1,21 @@ +import pyembroidery +from .stitch_plan import StitchPlan + +from ..svg import PIXELS_PER_MM + + +def stitch_plan_from_file(embroidery_file): + """Read a machine embroidery file in any supported format and return a stitch plan.""" + pattern = pyembroidery.read(embroidery_file) + + stitch_plan = StitchPlan() + color_block = None + + for raw_stitches, thread in pattern.get_as_colorblocks(): + color_block = stitch_plan.new_color_block(thread) + for x, y, command in raw_stitches: + color_block.add_stitch(x * PIXELS_PER_MM / 10.0, y * PIXELS_PER_MM / 10.0, + jump=(command == pyembroidery.JUMP), + trim=(command == pyembroidery.TRIM)) + + return stitch_plan |
