mirror of
https://github.com/BelfrySCAD/BOSL2.git
synced 2025-01-21 03:49:38 +00:00
normalize h/l/length/height in masks3d and some doc fixes, default
angle on teardrop masks
This commit is contained in:
parent
2c54188c24
commit
3c17e6c73f
1 changed files with 23 additions and 21 deletions
44
masks3d.scad
44
masks3d.scad
|
@ -15,13 +15,13 @@
|
||||||
|
|
||||||
// Module: chamfer_edge_mask()
|
// Module: chamfer_edge_mask()
|
||||||
// Usage:
|
// Usage:
|
||||||
// chamfer_edge_mask(l, chamfer, [excess]) [ATTACHMENTS];
|
// chamfer_edge_mask(l|h=|length=|height=, chamfer, [excess]) [ATTACHMENTS];
|
||||||
// Description:
|
// Description:
|
||||||
// Creates a shape that can be used to chamfer a 90 degree edge.
|
// Creates a shape that can be used to chamfer a 90 degree edge.
|
||||||
// Difference it from the object to be chamfered. The center of
|
// Difference it from the object to be chamfered. The center of
|
||||||
// the mask object should align exactly with the edge to be chamfered.
|
// the mask object should align exactly with the edge to be chamfered.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// l = Length of mask.
|
// l/h/length/height = Length of mask.
|
||||||
// chamfer = Size of chamfer.
|
// chamfer = Size of chamfer.
|
||||||
// excess = The extra amount to add to the length of the mask so that it differences away from other shapes cleanly. Default: `0.1`
|
// excess = The extra amount to add to the length of the mask so that it differences away from other shapes cleanly. Default: `0.1`
|
||||||
// ---
|
// ---
|
||||||
|
@ -41,8 +41,9 @@
|
||||||
// edge_mask(TOP+RIGHT)
|
// edge_mask(TOP+RIGHT)
|
||||||
// #chamfer_edge_mask(l=50, chamfer=10);
|
// #chamfer_edge_mask(l=50, chamfer=10);
|
||||||
// }
|
// }
|
||||||
function chamfer_edge_mask(l=1, chamfer=1, excess=0.1, anchor=CENTER, spin=0, orient=UP) = no_function("chamfer_edge_mask");
|
function chamfer_edge_mask(l, chamfer=1, excess=0.1, h, length, height, anchor=CENTER, spin=0, orient=UP) = no_function("chamfer_edge_mask");
|
||||||
module chamfer_edge_mask(l=1, chamfer=1, excess=0.1, anchor=CENTER, spin=0, orient=UP) {
|
module chamfer_edge_mask(l, chamfer=1, excess=0.1, h, length, height, anchor=CENTER, spin=0, orient=UP) {
|
||||||
|
l = one_defined([l, h, height, length], "l,h,height,length");
|
||||||
attachable(anchor,spin,orient, size=[chamfer*2, chamfer*2, l]) {
|
attachable(anchor,spin,orient, size=[chamfer*2, chamfer*2, l]) {
|
||||||
cylinder(r=chamfer, h=l+excess, center=true, $fn=4);
|
cylinder(r=chamfer, h=l+excess, center=true, $fn=4);
|
||||||
children();
|
children();
|
||||||
|
@ -149,14 +150,14 @@ module chamfer_cylinder_mask(r, chamfer, d, ang=45, from_end=false, anchor=CENTE
|
||||||
|
|
||||||
// Module: rounding_edge_mask()
|
// Module: rounding_edge_mask()
|
||||||
// Usage:
|
// Usage:
|
||||||
// rounding_edge_mask(l|h, r|d, [excess=]) [ATTACHMENTS];
|
// rounding_edge_mask(l|h=|length=|height=, r|d=, [excess=]) [ATTACHMENTS];
|
||||||
// rounding_edge_mask(l|h, r1=|d1=, r2=|d2=, [excess=]) [ATTACHMENTS];
|
// rounding_edge_mask(l|h=|length=|height=, r1=|d1=, r2=|d2=, [excess=]) [ATTACHMENTS];
|
||||||
// Description:
|
// Description:
|
||||||
// Creates a shape that can be used to round a vertical 90 degree edge.
|
// Creates a shape that can be used to round a vertical 90 degree edge.
|
||||||
// Difference it from the object to be rounded. The center of the mask
|
// Difference it from the object to be rounded. The center of the mask
|
||||||
// object should align exactly with the edge to be rounded.
|
// object should align exactly with the edge to be rounded.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// l/h = Length of mask.
|
// l/h/length/height = Length of mask.
|
||||||
// r = Radius of the rounding.
|
// r = Radius of the rounding.
|
||||||
// ---
|
// ---
|
||||||
// r1 = Bottom radius of rounding.
|
// r1 = Bottom radius of rounding.
|
||||||
|
@ -193,10 +194,10 @@ module chamfer_cylinder_mask(r, chamfer, d, ang=45, from_end=false, anchor=CENTE
|
||||||
// rounding_edge_mask(l=p.z, r=25);
|
// rounding_edge_mask(l=p.z, r=25);
|
||||||
// }
|
// }
|
||||||
// }
|
// }
|
||||||
function rounding_edge_mask(l, r, r1, r2, d, d1, d2, excess=0.1, anchor=CENTER, spin=0, orient=UP, h=undef) = no_function("rounding_edge_mask");
|
function rounding_edge_mask(l, r, r1, r2, d, d1, d2, excess=0.1, anchor=CENTER, spin=0, orient=UP, h,height,length) = no_function("rounding_edge_mask");
|
||||||
module rounding_edge_mask(l, r, r1, r2, d, d1, d2, excess=0.1, anchor=CENTER, spin=0, orient=UP, h=undef)
|
module rounding_edge_mask(l, r, r1, r2, d, d1, d2, excess=0.1, anchor=CENTER, spin=0, orient=UP, h,height,length)
|
||||||
{
|
{
|
||||||
l = first_defined([l, h, 1]);
|
l = one_defined([l, h, height, length], "l,h,height,length");
|
||||||
r1 = get_radius(r1=r1, r=r, d1=d1, d=d, dflt=1);
|
r1 = get_radius(r1=r1, r=r, d1=d1, d=d, dflt=1);
|
||||||
r2 = get_radius(r1=r2, r=r, d1=d2, d=d, dflt=1);
|
r2 = get_radius(r1=r2, r=r, d1=d2, d=d, dflt=1);
|
||||||
sides = quantup(segs(max(r1,r2)),4);
|
sides = quantup(segs(max(r1,r2)),4);
|
||||||
|
@ -275,14 +276,14 @@ module rounding_corner_mask(r, d, style="octa", excess=0.1, anchor=CENTER, spin=
|
||||||
|
|
||||||
// Module: rounding_angled_edge_mask()
|
// Module: rounding_angled_edge_mask()
|
||||||
// Usage:
|
// Usage:
|
||||||
// rounding_angled_edge_mask(h, r|d=, [ang=]) [ATTACHMENTS];
|
// rounding_angled_edge_mask(h|l=|length=|height=, r|d=, [ang=]) [ATTACHMENTS];
|
||||||
// rounding_angled_edge_mask(h, r1=|d1=, r2=|d2=, [ang=]) [ATTACHMENTS];
|
// rounding_angled_edge_mask(h|l=|length=|height=, r1=|d1=, r2=|d2=, [ang=]) [ATTACHMENTS];
|
||||||
// Description:
|
// Description:
|
||||||
// Creates a vertical mask that can be used to round the edge where two face meet, at any arbitrary
|
// Creates a vertical mask that can be used to round the edge where two face meet, at any arbitrary
|
||||||
// angle. Difference it from the object to be rounded. The center of the mask should align exactly
|
// angle. Difference it from the object to be rounded. The center of the mask should align exactly
|
||||||
// with the edge to be rounded.
|
// with the edge to be rounded.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// h = Height of vertical mask.
|
// h/l/height/length = Height of vertical mask.
|
||||||
// r = Radius of the rounding.
|
// r = Radius of the rounding.
|
||||||
// ---
|
// ---
|
||||||
// r1 = Bottom radius of rounding.
|
// r1 = Bottom radius of rounding.
|
||||||
|
@ -304,8 +305,8 @@ module rounding_corner_mask(r, d, style="octa", excess=0.1, anchor=CENTER, spin=
|
||||||
// pie_slice(ang=70, h=50, d=100, center=true);
|
// pie_slice(ang=70, h=50, d=100, center=true);
|
||||||
// #rounding_angled_edge_mask(h=51, r1=10, r2=25, ang=70, $fn=32);
|
// #rounding_angled_edge_mask(h=51, r1=10, r2=25, ang=70, $fn=32);
|
||||||
// }
|
// }
|
||||||
function rounding_angled_edge_mask(h, r, r1, r2, d, d1, d2, ang=90, anchor=CENTER, spin=0, orient=UP) = no_function("rounding_angled_edge_mask");
|
function rounding_angled_edge_mask(h, r, r1, r2, d, d1, d2, ang=90, anchor=CENTER, spin=0, orient=UP,l,height,length) = no_function("rounding_angled_edge_mask");
|
||||||
module rounding_angled_edge_mask(h, r, r1, r2, d, d1, d2, ang=90, anchor=CENTER, spin=0, orient=UP)
|
module rounding_angled_edge_mask(h, r, r1, r2, d, d1, d2, ang=90, anchor=CENTER, spin=0, orient=UP,l,height,length)
|
||||||
{
|
{
|
||||||
function _mask_shape(r) = [
|
function _mask_shape(r) = [
|
||||||
for (i = [0:1:n]) let (a=90+ang+i*sweep/n) [r*cos(a)+x, r*sin(a)+r],
|
for (i = [0:1:n]) let (a=90+ang+i*sweep/n) [r*cos(a)+x, r*sin(a)+r],
|
||||||
|
@ -313,7 +314,7 @@ module rounding_angled_edge_mask(h, r, r1, r2, d, d1, d2, ang=90, anchor=CENTER,
|
||||||
[min(-1, r*cos(270-ang)+x-1), r*sin(270-ang)-r],
|
[min(-1, r*cos(270-ang)+x-1), r*sin(270-ang)-r],
|
||||||
[min(-1, r*cos(90+ang)+x-1), r*sin(90+ang)+r],
|
[min(-1, r*cos(90+ang)+x-1), r*sin(90+ang)+r],
|
||||||
];
|
];
|
||||||
|
h = one_defined([l, h, height, length], "l,h,height,length");
|
||||||
sweep = 180-ang;
|
sweep = 180-ang;
|
||||||
r1 = get_radius(r1=r1, r=r, d1=d1, d=d, dflt=1);
|
r1 = get_radius(r1=r1, r=r, d1=d1, d=d, dflt=1);
|
||||||
r2 = get_radius(r1=r2, r=r, d1=d2, d=d, dflt=1);
|
r2 = get_radius(r1=r2, r=r, d1=d2, d=d, dflt=1);
|
||||||
|
@ -445,10 +446,10 @@ module rounding_cylinder_mask(r, rounding, d, anchor=CENTER, spin=0, orient=UP)
|
||||||
// hole to be rounded.
|
// hole to be rounded.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// r = Radius of hole.
|
// r = Radius of hole.
|
||||||
// d = Diameter of hole to rounding.
|
|
||||||
// rounding = Radius of the rounding.
|
// rounding = Radius of the rounding.
|
||||||
// excess = The extra thickness of the mask. Default: `0.1`.
|
// excess = The extra thickness of the mask. Default: `0.1`.
|
||||||
// ---
|
// ---
|
||||||
|
// d = Diameter of hole to rounding.
|
||||||
// anchor = Translate so anchor point is at origin (0,0,0). See [anchor](attachments.scad#subsection-anchor). Default: `CENTER`
|
// anchor = Translate so anchor point is at origin (0,0,0). See [anchor](attachments.scad#subsection-anchor). Default: `CENTER`
|
||||||
// spin = Rotate this many degrees around the Z axis after anchor. See [spin](attachments.scad#subsection-spin). Default: `0`
|
// spin = Rotate this many degrees around the Z axis after anchor. See [spin](attachments.scad#subsection-spin). Default: `0`
|
||||||
// orient = Vector to rotate top towards, after spin. See [orient](attachments.scad#subsection-orient). Default: `UP`
|
// orient = Vector to rotate top towards, after spin. See [orient](attachments.scad#subsection-orient). Default: `UP`
|
||||||
|
@ -486,11 +487,11 @@ module rounding_hole_mask(r, rounding, excess=0.1, d, anchor=CENTER, spin=0, ori
|
||||||
|
|
||||||
// Module: teardrop_edge_mask()
|
// Module: teardrop_edge_mask()
|
||||||
// Usage:
|
// Usage:
|
||||||
// teardrop_edge_mask(l, r|d=, [angle], [excess], [anchor], [spin], [orient]) [ATTACHMENTS];
|
// teardrop_edge_mask(l|h=|length=|height=, r|d=, [angle], [excess], [anchor], [spin], [orient]) [ATTACHMENTS];
|
||||||
// Description:
|
// Description:
|
||||||
// Makes an apropriate 3D corner rounding mask that keeps within `angle` degrees of vertical.
|
// Makes an apropriate 3D corner rounding mask that keeps within `angle` degrees of vertical.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// l = length of mask
|
// l/h/length/height = length of mask
|
||||||
// r = Radius of the mask rounding.
|
// r = Radius of the mask rounding.
|
||||||
// angle = Maximum angle from vertical. Default: 45
|
// angle = Maximum angle from vertical. Default: 45
|
||||||
// excess = Excess mask size. Default: 0.1
|
// excess = Excess mask size. Default: 0.1
|
||||||
|
@ -509,9 +510,10 @@ module rounding_hole_mask(r, rounding, excess=0.1, d, anchor=CENTER, spin=0, ori
|
||||||
// corner_mask(BOT)
|
// corner_mask(BOT)
|
||||||
// teardrop_corner_mask(r=10, angle=40);
|
// teardrop_corner_mask(r=10, angle=40);
|
||||||
// }
|
// }
|
||||||
function teardrop_edge_mask(l, r, angle, excess=0.1, d, anchor, spin, orient) = no_function("teardrop_edge_mask");
|
function teardrop_edge_mask(l, r, angle=45, excess=0.1, d, anchor, spin, orient,h,height,length) = no_function("teardrop_edge_mask");
|
||||||
module teardrop_edge_mask(l, r, angle, excess=0.1, d, anchor=CTR, spin=0, orient=UP)
|
module teardrop_edge_mask(l, r, angle=45, excess=0.1, d, anchor=CTR, spin=0, orient=UP,h,height,length)
|
||||||
{
|
{
|
||||||
|
l = one_defined([l, h, height, length], "l,h,height,length");
|
||||||
check =
|
check =
|
||||||
assert(is_num(l) && l>0, "Length of mask must be positive")
|
assert(is_num(l) && l>0, "Length of mask must be positive")
|
||||||
assert(is_num(angle) && angle>0 && angle<90, "Angle must be a number between 0 and 90")
|
assert(is_num(angle) && angle>0 && angle<90, "Angle must be a number between 0 and 90")
|
||||||
|
|
Loading…
Reference in a new issue