added grouping to offset paths and path type option
This commit is contained in:
parent
2071c0227f
commit
908a389eea
@ -32,7 +32,11 @@
|
|||||||
</param>
|
</param>
|
||||||
<param name="copy_org" type="bool" gui-text="Keep original path" gui-description="If enabled, keeps original path as a copy">false</param>
|
<param name="copy_org" type="bool" gui-text="Keep original path" gui-description="If enabled, keeps original path as a copy">false</param>
|
||||||
<param name="individual" type="bool" gui-text="Separate into individual paths" gui-description="If enabled, each offset curve will be an individual svg element">false</param>
|
<param name="individual" type="bool" gui-text="Separate into individual paths" gui-description="If enabled, each offset curve will be an individual svg element">false</param>
|
||||||
|
<param name="path_types" type="optiongroup" appearance="combo" gui-text="Path types to apply" gui-description="Process open, closed or all paths!">
|
||||||
|
<option value="both">all paths</option>
|
||||||
|
<option value="open_paths">open paths</option>
|
||||||
|
<option value="closed_paths">closed paths</option>
|
||||||
|
</param>
|
||||||
</page>
|
</page>
|
||||||
<page name="tab_about" gui-text="About">
|
<page name="tab_about" gui-text="About">
|
||||||
<label appearance="header">Offset Paths</label>
|
<label appearance="header">Offset Paths</label>
|
||||||
|
@ -4,9 +4,13 @@
|
|||||||
Based on
|
Based on
|
||||||
- https://github.com/TimeTravel-0/ofsplot
|
- https://github.com/TimeTravel-0/ofsplot
|
||||||
|
|
||||||
|
ToDo's
|
||||||
|
- break apart combined paths
|
||||||
|
- option to handle groups
|
||||||
|
|
||||||
Author: Mario Voigt / FabLab Chemnitz
|
Author: Mario Voigt / FabLab Chemnitz
|
||||||
Mail: mario.voigt@stadtfabrikanten.org
|
Mail: mario.voigt@stadtfabrikanten.org
|
||||||
Last Patch: 22.04.2021
|
Last Patch: 10.06.2021
|
||||||
License: GNU GPL v3
|
License: GNU GPL v3
|
||||||
|
|
||||||
"""
|
"""
|
||||||
@ -33,7 +37,7 @@ class OffsetPaths(inkex.EffectExtension):
|
|||||||
pars.add_argument("--clipperscale", type=int, default=1024, help="Scaling factor. Should be a multiplicator of 2, like 2^4=16 or 2^10=1024. The higher the scale factor the higher the quality.")
|
pars.add_argument("--clipperscale", type=int, default=1024, help="Scaling factor. Should be a multiplicator of 2, like 2^4=16 or 2^10=1024. The higher the scale factor the higher the quality.")
|
||||||
pars.add_argument("--copy_org", type=inkex.Boolean, default=True, help="copy original path")
|
pars.add_argument("--copy_org", type=inkex.Boolean, default=True, help="copy original path")
|
||||||
pars.add_argument("--individual", type=inkex.Boolean, default=True, help="Separate into individual paths")
|
pars.add_argument("--individual", type=inkex.Boolean, default=True, help="Separate into individual paths")
|
||||||
|
pars.add_argument("--path_types", default="both", help="Process open, closed or all paths!")
|
||||||
|
|
||||||
|
|
||||||
def effect(self):
|
def effect(self):
|
||||||
@ -47,11 +51,25 @@ class OffsetPaths(inkex.EffectExtension):
|
|||||||
for pathElement in pathElements:
|
for pathElement in pathElements:
|
||||||
csp = CubicSuperPath(pathElement.get('d'))
|
csp = CubicSuperPath(pathElement.get('d'))
|
||||||
|
|
||||||
scale_factor = self.options.clipperscale # 2 ** 32 = 1024 - see also https://github.com/fonttools/pyclipper/wiki/Deprecating-SCALING_FACTOR
|
'''
|
||||||
|
check for closed or open paths
|
||||||
|
'''
|
||||||
|
isClosed = False
|
||||||
|
raw = pathElement.path.to_arrays()
|
||||||
|
if raw[-1][0] == 'Z' or \
|
||||||
|
(raw[-1][0] == 'L' and raw[0][1] == raw[-1][1]) or \
|
||||||
|
(raw[-1][0] == 'C' and raw[0][1] == [raw[-1][1][-2], raw[-1][1][-1]]) \
|
||||||
|
: #if first is last point the path is also closed. The "Z" command is not required
|
||||||
|
isClosed = True
|
||||||
|
if self.options.path_types == "open_paths" and isClosed is True:
|
||||||
|
continue #skip this loop iteration
|
||||||
|
elif self.options.path_types == "closed_paths" and isClosed is False:
|
||||||
|
continue #skip this loop iteration
|
||||||
|
|
||||||
|
scale_factor = self.options.clipperscale # 2 ** 32 = 1024 - see also https://github.com/fonttools/pyclipper/wiki/Deprecating-SCALING_FACTOR
|
||||||
pco = pyclipper.PyclipperOffset(self.options.miterlimit)
|
pco = pyclipper.PyclipperOffset(self.options.miterlimit)
|
||||||
|
|
||||||
JT = None
|
JT = None #join types
|
||||||
if self.options.jointype == "0":
|
if self.options.jointype == "0":
|
||||||
JT = pyclipper.JT_SQUARE
|
JT = pyclipper.JT_SQUARE
|
||||||
elif self.options.jointype == "1":
|
elif self.options.jointype == "1":
|
||||||
@ -59,7 +77,7 @@ class OffsetPaths(inkex.EffectExtension):
|
|||||||
elif self.options.jointype == "2":
|
elif self.options.jointype == "2":
|
||||||
JT = pyclipper.JT_MITER
|
JT = pyclipper.JT_MITER
|
||||||
|
|
||||||
ET = None
|
ET = None #end types
|
||||||
if self.options.endtype == "0":
|
if self.options.endtype == "0":
|
||||||
ET = pyclipper.ET_CLOSEDPOLYGON
|
ET = pyclipper.ET_CLOSEDPOLYGON
|
||||||
elif self.options.endtype == "1":
|
elif self.options.endtype == "1":
|
||||||
@ -107,16 +125,18 @@ class OffsetPaths(inkex.EffectExtension):
|
|||||||
newPaths.append(sol_p)
|
newPaths.append(sol_p)
|
||||||
|
|
||||||
if self.options.individual is True:
|
if self.options.individual is True:
|
||||||
|
parentGroup = pathElement.getparent().add(inkex.Group(id="g-offset-{}".format(pathElement.attrib["id"])))
|
||||||
parent = pathElement.getparent()
|
parent = pathElement.getparent()
|
||||||
idx = parent.index(pathElement)
|
idx = parent.index(pathElement) + 1
|
||||||
idSuffix = 0
|
idSuffix = 0
|
||||||
for newPath in newPaths:
|
for newPath in newPaths:
|
||||||
copyElement = copy.copy(pathElement)
|
copyElement = copy.copy(pathElement)
|
||||||
elementId = copyElement.get('id')
|
elementId = copyElement.get('id')
|
||||||
copyElement.path = CubicSuperPath(newPath)
|
copyElement.path = CubicSuperPath(newPath)
|
||||||
copyElement.set('id', elementId + str(idSuffix))
|
copyElement.set('id', elementId + str(idSuffix))
|
||||||
parent.insert(idx, copyElement)
|
parentGroup.append(copyElement)
|
||||||
idSuffix += 1
|
idSuffix += 1
|
||||||
|
parent.insert(idx, parentGroup)
|
||||||
if self.options.copy_org is False:
|
if self.options.copy_org is False:
|
||||||
pathElement.delete()
|
pathElement.delete()
|
||||||
else:
|
else:
|
||||||
|
Reference in New Issue
Block a user