Fix for issue #666

This commit is contained in:
Garth Minette 2022-07-28 18:40:21 -07:00
parent 6047cee208
commit 60b84331e9
2 changed files with 30 additions and 13 deletions

View file

@ -552,6 +552,9 @@ module stroke(
// --- // ---
// width = The width of the dashed line to draw. Module only. Default: 1 // width = The width of the dashed line to draw. Module only. Default: 1
// closed = If true, treat path as a closed polygon. Default: false // closed = If true, treat path as a closed polygon. Default: false
// fit = If true, shrink or stretch the dash pattern so that the path ends ofter a logical dash. Default: true
// roundcaps = (Module only) If true, draws dashes with rounded caps. This often looks better. Default: true
// mindash = (Function only) Specifies the minimal dash length to return at the end of a path when fit is false. Default: 0.5
// Example(2D): Open Path // Example(2D): Open Path
// path = [for (a=[-180:10:180]) [a/3,20*sin(a)]]; // path = [for (a=[-180:10:180]) [a/3,20*sin(a)]];
// dashed_stroke(path, [3,2], width=1); // dashed_stroke(path, [3,2], width=1);
@ -562,31 +565,44 @@ module stroke(
// Example(FlatSpin,VPD=250): 3D Dashed Path // Example(FlatSpin,VPD=250): 3D Dashed Path
// path = [for (a=[-180:5:180]) [a/3, 20*cos(3*a), 20*sin(3*a)]]; // path = [for (a=[-180:5:180]) [a/3, 20*cos(3*a), 20*sin(3*a)]];
// dashed_stroke(path, [3,2], width=1); // dashed_stroke(path, [3,2], width=1);
function dashed_stroke(path, dashpat=[3,3], closed=false) = function dashed_stroke(path, dashpat=[3,3], closed=false, fit=true, mindash=0.5) =
is_region(path) ? [for(p=path) each dashed_stroke(p,dashpat,closed=true)] : is_region(path) ? [
for (p = path)
each dashed_stroke(p, dashpat, closed=true, fit=fit)
] :
let( let(
path = closed? close_path(path) : path, path = closed? close_path(path) : path,
dashpat = len(dashpat)%2==0? dashpat : concat(dashpat,[0]), dashpat = len(dashpat)%2==0? dashpat : concat(dashpat,[0]),
plen = path_length(path), plen = path_length(path),
dlen = sum(dashpat), dlen = sum(dashpat),
doff = cumsum(dashpat), doff = cumsum(dashpat),
reps = floor(plen / dlen), freps = plen / dlen,
step = plen / reps, reps = max(1, fit? round(freps) : floor(freps)),
tlen = !fit? plen :
reps * dlen + (closed? 0 : dashpat[0]),
sc = plen / tlen,
cuts = [ cuts = [
for (i=[0:1:reps-1], off=doff) for (i = [0:1:reps], off = doff*sc)
let (st=i*step, x=st+off) let (x = i*dlen*sc + off)
if (x > 0 && x < plen) x if (x > 0 && x < plen) x
], ],
dashes = path_cut(path, cuts, closed=false), dashes = path_cut(path, cuts, closed=false),
evens = [for (i=idx(dashes)) if (i%2==0) dashes[i]] dcnt = len(dashes),
evens = [
for (i = idx(dashes))
if (i % 2 == 0)
let( dash = dashes[i] )
if (i < dcnt-1 || path_length(dash) > mindash)
dashes[i]
]
) evens; ) evens;
module dashed_stroke(path, dashpat=[3,3], width=1, closed=false) { module dashed_stroke(path, dashpat=[3,3], width=1, closed=false, fit=true, roundcaps=false) {
no_children($children); no_children($children);
segs = dashed_stroke(path, dashpat=dashpat*width, closed=closed); segs = dashed_stroke(path, dashpat=dashpat*width, closed=closed, fit=fit, mindash=0.5*width);
for (seg = segs) for (seg = segs)
stroke(seg, width=width, endcaps=false); stroke(seg, width=width, endcaps=roundcaps? "round" : false);
} }

View file

@ -16,7 +16,8 @@
// Usage: // Usage:
// nema_stepper_motor(size, h, shaft_len, ...) [attachments]; // nema_stepper_motor(size, h, shaft_len, ...) [attachments];
// Topics: Parts, Motors // Topics: Parts, Motors
// Description: Creates a model of a NEMA 11 stepper motor. // Description:
// Creates a model of a NEMA standard stepper motor.
// Arguments: // Arguments:
// size = The NEMA standard size of the stepper motor. // size = The NEMA standard size of the stepper motor.
// h = Length of motor body. Default: 24mm // h = Length of motor body. Default: 24mm