summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLex Neva <github@lexneva.name>2016-10-28 22:08:23 -0400
committerLex Neva <github@lexneva.name>2016-10-28 22:10:54 -0400
commit14ec80d012b3f9878b558a366220889a03380372 (patch)
tree894f84b56ed45347b752e96e352dd670a81fc666
parentb63abea79786e9065c518c98c65655d6ccdada18 (diff)
switch to millimeters and make pixels_per_millimeter an option
-rw-r--r--embroider.inx1
-rw-r--r--embroider.py40
-rw-r--r--embroider_params.inx14
3 files changed, 28 insertions, 27 deletions
diff --git a/embroider.inx b/embroider.inx
index 67922103..fea28b2f 100644
--- a/embroider.inx
+++ b/embroider.inx
@@ -4,6 +4,7 @@
<id>jonh.embroider</id>
<dependency type="executable" location="extensions">embroider.py</dependency>
<dependency type="executable" location="extensions">inkex.py</dependency>
+ <param name="pixels_per_mm" type="float" min="1" max="100" precision="2" _gui-text="How many pixels on-screen equal one millimeter in embroidery output">10</param>
<param name="zigzag_spacing_mm" type="float" min="0.01" max="5.00" precision="2" _gui-text="Zigzag spacing (mm)">1.00</param>
<param name="row_spacing_mm" type="float" min="0.01" max="5.00" precision="2" _gui-text="Row spacing (mm)">0.40</param>
<param name="max_stitch_len_mm" type="float" min="0.1" max="100.0" _gui-text="Maximum stitch length (mm)">3.0</param>
diff --git a/embroider.py b/embroider.py
index a01c540e..1db16f43 100644
--- a/embroider.py
+++ b/embroider.py
@@ -41,10 +41,6 @@ from pprint import pformat
dbg = open("/tmp/embroider-debug.txt", "w")
PyEmb.dbg = dbg
-#pixels_per_millimeter = 90.0 / 25.4
-
-#this makes each pixel worth one tenth of a millimeter
-pixels_per_millimeter = 10
# a 0.5pt stroke becomes a straight line.
STROKE_MIN = 0.5
@@ -281,14 +277,18 @@ class Embroider(inkex.Effect):
action="store", type="int",
dest="max_backups", default=5,
help="Max number of backups of output files to keep.")
+ self.OptionParser.add_option("-p", "--pixels_per_mm",
+ action="store", type="int",
+ dest="pixels_per_millimeter", default=10,
+ help="Number of on-screen pixels per millimeter.")
self.patches = []
def process_one_path(self, node, shpath, threadcolor, angle):
#self.add_shapely_geo_to_svg(shpath.boundary, color="#c0c000")
flip = get_boolean_param(node, "flip", False)
- row_spacing_px = get_float_param(node, "row_spacing", self.row_spacing_px)
- max_stitch_len_px = get_float_param(node, "max_stitch_length", self.max_stitch_len_px)
+ row_spacing_px = get_float_param(node, "row_spacing", self.options.row_spacing_mm) * self.options.pixels_per_millimeter
+ max_stitch_len_px = get_float_param(node, "max_stitch_length", self.options.max_stitch_len_mm) * self.options.pixels_per_millimeter
num_staggers = get_int_param(node, "staggers", 4)
rows_of_segments = self.intersect_region_with_grating(shpath, row_spacing_px, angle, flip)
@@ -340,7 +340,7 @@ class Embroider(inkex.Effect):
# only stitch the first point if it's a reasonable distance away from the
# last stitch
- if last_end is None or (beg - last_end).length() > 0.5 * pixels_per_millimeter:
+ if last_end is None or (beg - last_end).length() > 0.5 * self.options.pixels_per_millimeter:
patch.addStitch(beg)
# Now, imagine the coordinate axes rotated by 'angle' degrees, such that
@@ -366,7 +366,7 @@ class Embroider(inkex.Effect):
patch.addStitch(beg + offset * row_direction)
offset += max_stitch_len_px
- if (end - patch.stitches[-1]).length() > 0.1 * pixels_per_millimeter:
+ if (end - patch.stitches[-1]).length() > 0.1 * self.options.pixels_per_millimeter:
patch.addStitch(end)
last_end = end
@@ -582,11 +582,11 @@ class Embroider(inkex.Effect):
old_stdout = sys.stdout
sys.stdout = sys.stderr
- self.row_spacing_px = self.options.row_spacing_mm * pixels_per_millimeter
- self.zigzag_spacing_px = self.options.zigzag_spacing_mm * pixels_per_millimeter
- self.max_stitch_len_px = self.options.max_stitch_len_mm*pixels_per_millimeter
- self.running_stitch_len_px = self.options.running_stitch_len_mm*pixels_per_millimeter
- self.collapse_len_px = self.options.collapse_len_mm*pixels_per_millimeter
+ self.row_spacing_px = self.options.row_spacing_mm * self.options.pixels_per_millimeter
+ self.zigzag_spacing_px = self.options.zigzag_spacing_mm * self.options.pixels_per_millimeter
+ self.max_stitch_len_px = self.options.max_stitch_len_mm * self.options.pixels_per_millimeter
+ self.running_stitch_len_px = self.options.running_stitch_len_mm * self.optoins.pixels_per_millimeter
+ self.collapse_len_px = self.options.collapse_len_mm * self.options.pixels_per_millimeter
self.svgpath = inkex.addNS('path', 'svg')
self.svgdefs = inkex.addNS('defs', 'svg')
@@ -646,8 +646,8 @@ class Embroider(inkex.Effect):
#dbg.write("stroke_width is <%s>\n" % repr(stroke_width))
#dbg.flush()
- running_stitch_len_px = get_float_param(node, "stitch_length", self.running_stitch_len_px)
- zigzag_spacing_px = get_float_param(node, "zigzag_spacing", self.zigzag_spacing_px)
+ running_stitch_len_px = get_float_param(node, "stitch_length", self.options.running_stitch_len_mm) * self.pixels_per_millimeter
+ zigzag_spacing_px = get_float_param(node, "zigzag_spacing", self.options.zigzag_spacing_mm) * self.options.pixels_per_millimeter
repeats = get_int_param(node, "repeats", 1)
paths = flatten(parse_path(node), self.options.flat)
@@ -761,13 +761,13 @@ class Embroider(inkex.Effect):
self.validate_satin_column(node, csp)
# fetch parameters
- zigzag_spacing_px = get_float_param(node, "zigzag_spacing", self.zigzag_spacing_px)
- pull_compensation_px = get_float_param(node, "pull_compensation", 0)
- underlay_inset = get_float_param(node, "satin_underlay_inset", 0)
- underlay_stitch_len_px = get_float_param(node, "stitch_length", self.running_stitch_len_px)
+ zigzag_spacing_px = get_float_param(node, "zigzag_spacing", self.zigzag_spacing_mm) * self.options.pixels_per_millimeter
+ pull_compensation_px = get_float_param(node, "pull_compensation", 0) * self.options.pixels_per_millimeter
+ underlay_inset = get_float_param(node, "satin_underlay_inset", 0) * self.options.pixels_per_millimeter
+ underlay_stitch_len_px = get_float_param(node, "stitch_length", self.running_stitch_len_mm) * self.options.pixels_per_millimeter
underlay = get_boolean_param(node, "satin_underlay", False)
center_walk = get_boolean_param(node, "satin_center_walk", False)
- zigzag_underlay_spacing = get_float_param(node, "satin_zigzag_underlay_spacing", 0)
+ zigzag_underlay_spacing = get_float_param(node, "satin_zigzag_underlay_spacing", 0) * self.options.pixels_per_millimeter
zigzag_underlay_inset = underlay_inset / 2.0
# A path is a collection of tuples, each of the form:
diff --git a/embroider_params.inx b/embroider_params.inx
index 1e19bdb4..37530502 100644
--- a/embroider_params.inx
+++ b/embroider_params.inx
@@ -4,20 +4,20 @@
<id>jonh.embroider.params</id>
<dependency type="executable" location="extensions">embroider_params.py</dependency>
<dependency type="executable" location="extensions">inkex.py</dependency>
- <param name="zigzag_spacing" type="string" _gui-text="Zigzag spacing (pixels)"></param>
- <param name="stitch_length" type="string" _gui-text="Running stitch length (pixels)"></param>
- <param name="row_spacing" type="string" _gui-text="Row spacing (pixels)"></param>
- <param name="max_stitch_length" type="string" _gui-text="Maximum stitch length (pixels)"></param>
+ <param name="zigzag_spacing" type="string" _gui-text="Zigzag spacing (mm)"></param>
+ <param name="stitch_length" type="string" _gui-text="Running stitch length (mm)"></param>
+ <param name="row_spacing" type="string" _gui-text="Row spacing (mm)"></param>
+ <param name="max_stitch_length" type="string" _gui-text="Maximum stitch length (mm)"></param>
<param name="repeats" type="string" _gui-text="Repeats (stroke only)"></param>
<param name="angle" type="string" _gui-text="Angle for lines in fills"></param>
- <param name="pull_compensation" type="string" _gui-text="Pull compensation for satin column (pixels)"></param>
+ <param name="pull_compensation" type="string" _gui-text="Pull compensation for satin column (mm)"></param>
<param name="hatching" type="string" _gui-text="Hatching? (yes/no)"></param>
<param name="flip" type="string" _gui-text="Flip fill? (yes/no)"></param>
<param name="satin_column" type="string" _gui-text="Satin Column? (yes/no)"></param>
<param name="satin_underlay" type="string" _gui-text="Edge-walk underlay for satin Column? (yes/no)"></param>
- <param name="satin_underlay_inset" type="string" _gui-text="Inset for satin colum underlay (pixels)"></param>
+ <param name="satin_underlay_inset" type="string" _gui-text="Inset for satin colum underlay (mm)"></param>
<param name="satin_center_walk" type="string" _gui-text="Satin center walk underlay? (yes/no)"></param>
- <param name="satin_zigzag_underlay_spacing" type="string" _gui-text="Zigzag underlay spacing (pixels)"></param>
+ <param name="satin_zigzag_underlay_spacing" type="string" _gui-text="Zigzag underlay spacing (mm)"></param>
<param name="stroke_first" type="string" _gui-text="Stitch stroke before fill? (yes/no)"></param>
<effect>
<object-type>all</object-type>