summaryrefslogtreecommitdiff
path: root/lib/stitch_plan/read_file.py
diff options
context:
space:
mode:
authorLex Neva <lexelby@users.noreply.github.com>2018-09-12 20:49:31 -0400
committerGitHub <noreply@github.com>2018-09-12 20:49:31 -0400
commit3fd741a1a4218b6559184aaadcde8abca178bde2 (patch)
tree638a96776f6deecb82150b2b97efb372084e464c /lib/stitch_plan/read_file.py
parenteff7c8d8ce7c9c1f8396c99bcf5fc15078ff99b7 (diff)
parenta876066c75eafc20547b055c5dffe8e89e4c327f (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.py21
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