mirror of
https://github.com/revarbat/BOSL2.git
synced 2025-01-16 21:58:27 +01:00
rework rounding docs, change "length=" to "width=" for chamfers.
This commit is contained in:
parent
43ae4efe5c
commit
600175f205
@ -116,7 +116,7 @@ include <structs.scad>
|
|||||||
// stroke(fwd(1,
|
// stroke(fwd(1,
|
||||||
// select(round_corners(example, joint=18, method="chamfer",closed=false),1,-2)),
|
// select(round_corners(example, joint=18, method="chamfer",closed=false),1,-2)),
|
||||||
// width=strokewidth,endcaps="arrow2");
|
// width=strokewidth,endcaps="arrow2");
|
||||||
// translate([w,.3])text("length", size=1.4,halign="center");
|
// translate([w,.3])text("width", size=1.4,halign="center");
|
||||||
// }
|
// }
|
||||||
// color("green"){ stroke([[w,h], [w,h-18*cos(vector_angle(example)/2)]], width=strokewidth, endcaps="arrow2");
|
// color("green"){ stroke([[w,h], [w,h-18*cos(vector_angle(example)/2)]], width=strokewidth, endcaps="arrow2");
|
||||||
// translate([w-1.75,h-5.5])scale(.1)rotate(textangle)text("cut",size=14); }
|
// translate([w-1.75,h-5.5])scale(.1)rotate(textangle)text("cut",size=14); }
|
||||||
@ -323,7 +323,7 @@ include <structs.scad>
|
|||||||
// polygon(round_corners(path,joint = halflen, method="circle",verbose=true));
|
// polygon(round_corners(path,joint = halflen, method="circle",verbose=true));
|
||||||
// Example(2D): Chamfering, specifying the chamfer length
|
// Example(2D): Chamfering, specifying the chamfer length
|
||||||
// path = star(5, step=2, d=100);
|
// path = star(5, step=2, d=100);
|
||||||
// path2 = round_corners(path, method="chamfer", length=5);
|
// path2 = round_corners(path, method="chamfer", width=5);
|
||||||
// polygon(path2);
|
// polygon(path2);
|
||||||
// Example(2D): Chamfering, specifying the cut
|
// Example(2D): Chamfering, specifying the cut
|
||||||
// path = star(5, step=2, d=100);
|
// path = star(5, step=2, d=100);
|
||||||
@ -353,15 +353,15 @@ include <structs.scad>
|
|||||||
// cut=chamfcut),
|
// cut=chamfcut),
|
||||||
// radius=radii);
|
// radius=radii);
|
||||||
// stroke(path2, closed=true);
|
// stroke(path2, closed=true);
|
||||||
// Example(2D): Specifying by corner index. Use {{list_set()}} to construct the full chamfer cut list.
|
// Example(2D,Med,NoAxes): Specifying by corner index. Use {{list_set()}} to construct the full chamfer cut list.
|
||||||
// path = star(47, ir=25, or=50); // long path, lots of corners
|
// path = star(47, ir=25, or=50); // long path, lots of corners
|
||||||
// chamfind = [8, 28, 60]; // But only want 3 chamfers
|
// chamfind = [8, 28, 60]; // But only want 3 chamfers
|
||||||
// chamfcut = list_set([],chamfind,[10,13,15],minlen=len(path)-1);
|
// chamfcut = list_set([],chamfind,[10,13,15],minlen=len(path)-1);
|
||||||
// rpath = round_corners(path, cut=chamfcut, method="chamfer");
|
// rpath = round_corners(path, cut=chamfcut, method="chamfer");
|
||||||
// polygon(rpath);
|
// polygon(rpath);
|
||||||
// Example(2D): Two-pass to chamfer and round by index. Use {{repeat_entries()}} to correct for first pass chamfers.
|
// Example(2D,Med,NoAxes): Two-pass to chamfer and round by index. Use {{repeat_entries()}} to correct for first pass chamfers.
|
||||||
// $fn=32;
|
// $fn=32;
|
||||||
// path = star(47, ir=25, or=50); // long path, lots of corners
|
// path = star(47, ir=32, or=65); // long path, lots of corners
|
||||||
// chamfind = [8, 28, 60]; // But only want 3 chamfers
|
// chamfind = [8, 28, 60]; // But only want 3 chamfers
|
||||||
// roundind = [7,9,27,29,59,61]; // And 6 roundovers
|
// roundind = [7,9,27,29,59,61]; // And 6 roundovers
|
||||||
// chamfcut = list_set([],chamfind,[10,13,15],minlen=len(path)-1);
|
// chamfcut = list_set([],chamfind,[10,13,15],minlen=len(path)-1);
|
||||||
@ -370,12 +370,12 @@ include <structs.scad>
|
|||||||
// rpath1 = round_corners(path, cut=chamfcut, method="chamfer");
|
// rpath1 = round_corners(path, cut=chamfcut, method="chamfer");
|
||||||
// rpath2 = round_corners(rpath1, cut=repeat_entries(roundcut,dups));
|
// rpath2 = round_corners(rpath1, cut=repeat_entries(roundcut,dups));
|
||||||
// polygon(rpath2);
|
// polygon(rpath2);
|
||||||
module round_corners(path, method="circle", radius, r, cut, joint, length, k, closed=true, verbose=false) {no_module();}
|
module round_corners(path, method="circle", radius, r, cut, joint, width, k, closed=true, verbose=false) {no_module();}
|
||||||
function round_corners(path, method="circle", radius, r, cut, joint, length, k, closed=true, verbose=false) =
|
function round_corners(path, method="circle", radius, r, cut, joint, width, k, closed=true, verbose=false) =
|
||||||
assert(in_list(method,["circle", "smooth", "chamfer"]), "method must be one of \"circle\", \"smooth\" or \"chamfer\"")
|
assert(in_list(method,["circle", "smooth", "chamfer"]), "method must be one of \"circle\", \"smooth\" or \"chamfer\"")
|
||||||
let(
|
let(
|
||||||
default_k = 0.5,
|
default_k = 0.5,
|
||||||
size=one_defined([radius, r, cut, joint, length], "radius,r,cut,joint,length"),
|
size=one_defined([radius, r, cut, joint, width], "radius,r,cut,joint,width"),
|
||||||
path = force_path(path),
|
path = force_path(path),
|
||||||
size_ok = is_num(size) || len(size)==len(path) || (!closed && len(size)==len(path)-2),
|
size_ok = is_num(size) || len(size)==len(path) || (!closed && len(size)==len(path)-2),
|
||||||
k_ok = is_undef(k) || (method=="smooth" && (is_num(k) || len(k)==len(path) || (!closed && len(k)==len(path)-2))),
|
k_ok = is_undef(k) || (method=="smooth" && (is_num(k) || len(k)==len(path) || (!closed && len(k)==len(path)-2))),
|
||||||
@ -383,7 +383,7 @@ function round_corners(path, method="circle", radius, r, cut, joint, length, k,
|
|||||||
: is_def(r) ? "radius"
|
: is_def(r) ? "radius"
|
||||||
: is_def(cut) ? "cut"
|
: is_def(cut) ? "cut"
|
||||||
: is_def(joint) ? "joint"
|
: is_def(joint) ? "joint"
|
||||||
: "length"
|
: "width"
|
||||||
)
|
)
|
||||||
assert(is_path(path,[2,3]), "input path must be a 2d or 3d path")
|
assert(is_path(path,[2,3]), "input path must be a 2d or 3d path")
|
||||||
assert(len(path)>2,str("Path has length ",len(path),". Length must be 3 or more."))
|
assert(len(path)>2,str("Path has length ",len(path),". Length must be 3 or more."))
|
||||||
@ -391,7 +391,7 @@ function round_corners(path, method="circle", radius, r, cut, joint, length, k,
|
|||||||
assert(k_ok,method=="smooth" ? str("Input k must be a number or list with length ",len(path), closed?"":str(" or ",len(path)-2)) :
|
assert(k_ok,method=="smooth" ? str("Input k must be a number or list with length ",len(path), closed?"":str(" or ",len(path)-2)) :
|
||||||
"Input k is only allowed with method=\"smooth\"")
|
"Input k is only allowed with method=\"smooth\"")
|
||||||
assert(method=="circle" || measure!="radius", "radius parameter allowed only with method=\"circle\"")
|
assert(method=="circle" || measure!="radius", "radius parameter allowed only with method=\"circle\"")
|
||||||
assert(method=="chamfer" || measure!="length", "length parameter allowed only with method=\"chamfer\"")
|
assert(method=="chamfer" || measure!="width", "width parameter allowed only with method=\"chamfer\"")
|
||||||
let(
|
let(
|
||||||
parm = is_num(size) ? repeat(size, len(path)) :
|
parm = is_num(size) ? repeat(size, len(path)) :
|
||||||
len(size)<len(path) ? [0, each size, 0] :
|
len(size)<len(path) ? [0, each size, 0] :
|
||||||
@ -425,7 +425,7 @@ function round_corners(path, method="circle", radius, r, cut, joint, length, k,
|
|||||||
str("Path turns back on itself at index ",i," with nonzero rounding"))
|
str("Path turns back on itself at index ",i," with nonzero rounding"))
|
||||||
(method=="chamfer" && measure=="joint")? [parm[i]] :
|
(method=="chamfer" && measure=="joint")? [parm[i]] :
|
||||||
(method=="chamfer" && measure=="cut") ? [parm[i]/cos(angle)] :
|
(method=="chamfer" && measure=="cut") ? [parm[i]/cos(angle)] :
|
||||||
(method=="chamfer" && measure=="length") ? [parm[i]/sin(angle)/2] :
|
(method=="chamfer" && measure=="width") ? [parm[i]/sin(angle)/2] :
|
||||||
(method=="smooth" && measure=="joint") ? [parm[i],k[i]] :
|
(method=="smooth" && measure=="joint") ? [parm[i],k[i]] :
|
||||||
(method=="smooth" && measure=="cut") ? [8*parm[i]/cos(angle)/(1+4*k[i]),k[i]] :
|
(method=="smooth" && measure=="cut") ? [8*parm[i]/cos(angle)/(1+4*k[i]),k[i]] :
|
||||||
(method=="circle" && measure=="radius")? [parm[i]/tan(angle), parm[i]] :
|
(method=="circle" && measure=="radius")? [parm[i]/tan(angle), parm[i]] :
|
||||||
|
Loading…
x
Reference in New Issue
Block a user