summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorKaalleen <36401965+kaalleen@users.noreply.github.com>2024-03-11 13:55:00 +0100
committerGitHub <noreply@github.com>2024-03-11 13:55:00 +0100
commit3121bbaedf7e76d92a029fad067828014f9f5fde (patch)
treecee31f3e30bba5665ef04ccd13a0222ccede4650
parentea4d48119ab1b20dd35b022004212ffd1ae46d8e (diff)
add satins only option to force lock stitch extension (#2773)
-rw-r--r--lib/extensions/lettering_force_lock_stitches.py7
-rw-r--r--templates/lettering_force_lock_stitches.xml8
2 files changed, 11 insertions, 4 deletions
diff --git a/lib/extensions/lettering_force_lock_stitches.py b/lib/extensions/lettering_force_lock_stitches.py
index 62d7ae14..17033ce9 100644
--- a/lib/extensions/lettering_force_lock_stitches.py
+++ b/lib/extensions/lettering_force_lock_stitches.py
@@ -20,6 +20,7 @@ class LetteringForceLockStitches(InkstitchExtension):
def __init__(self, *args, **kwargs):
InkstitchExtension.__init__(self, *args, **kwargs)
+ self.arg_parser.add_argument("-s", "--satin_only", type=inkex.Boolean, dest="satin_only")
self.arg_parser.add_argument("-a", "--max_distance", type=float, default=3, dest="max_distance")
self.arg_parser.add_argument("-i", "--min_distance", type=float, default=1, dest="min_distance")
self.arg_parser.add_argument("-l", "--last_element", type=inkex.Boolean, dest="last_element")
@@ -65,7 +66,7 @@ class LetteringForceLockStitches(InkstitchExtension):
# set force lock stitches attribute if needed
for last_element in last_elements:
last_element.attrib.pop('lastglyphelement')
- if self.options.last_element:
+ if self.options.last_element and not (self.options.satin_only and not last_element.get('inkstitch:satin_column', False)):
last_element.set(INKSTITCH_ATTRIBS['force_lock_stitches'], True)
# hide glyph layers again
@@ -74,7 +75,9 @@ class LetteringForceLockStitches(InkstitchExtension):
def _set_force_attribute(self, first_stitch, last_stitch, previous_element):
distance_mm = first_stitch.distance(last_stitch) / PIXELS_PER_MM
- if distance_mm < self.options.max_distance and distance_mm > self.options.min_distance:
+ if (distance_mm < self.options.max_distance and
+ distance_mm > self.options.min_distance and
+ not (self.options.satin_only and not previous_element.get_boolean_param('satin_column', False))):
previous_element.node.set(INKSTITCH_ATTRIBS['force_lock_stitches'], True)
def _update_layer_visibility(self, display):
diff --git a/templates/lettering_force_lock_stitches.xml b/templates/lettering_force_lock_stitches.xml
index 7c3a3f33..a0273d99 100644
--- a/templates/lettering_force_lock_stitches.xml
+++ b/templates/lettering_force_lock_stitches.xml
@@ -20,8 +20,12 @@
<label indent="1">
This extension has been build to help font authors to define "force lock stitches"-attributes automatically if they are placed in a predefined distance to the next object.
</label>
- <param indent="1" name="min_distance" type="float" gui-text="Minimum distance (mm)" min="0" max="3">1</param>
- <param indent="1" name="max_distance" type="float" gui-text="Maximum distance (mm)" min="1" max="10">3</param>
+ <spacer />
+ <separator />
+ <spacer />
+ <param indent="1" name="satin_only" type="boolean" gui-text="Restrict to Satin">false</param>
+ <param indent="1" name="min_distance" type="float" gui-text="Minimum distance (mm)" min="0" max="20">1</param>
+ <param indent="1" name="max_distance" type="float" gui-text="Maximum distance (mm)" min="1" max="20">3</param>
<separator />
<param indent="1" name="last_element" type="boolean" gui-text="Add force lock stitches attribute to the last element of each glyph">false</param>
<script>