mirror of
https://github.com/BelfrySCAD/BOSL2.git
synced 2025-01-15 17:09:40 +00:00
Compare commits
No commits in common. "606b6acde2f4c787413c6dd302293cfa5f0ef8c3" and "94583da6727cbe3425bc29dc62282e6cde981a1f" have entirely different histories.
606b6acde2
...
94583da672
1 changed files with 13 additions and 83 deletions
|
@ -1423,8 +1423,8 @@ module rect_tube(
|
||||||
assert(checksignr2, "irounding/irounding2 must be non-negative")
|
assert(checksignr2, "irounding/irounding2 must be non-negative")
|
||||||
assert(checksignc1, "ichamfer/ichamfer1 must be non-negative")
|
assert(checksignc1, "ichamfer/ichamfer1 must be non-negative")
|
||||||
assert(checksignc2, "ichamfer/ichamfer2 must be non-negative")
|
assert(checksignc2, "ichamfer/ichamfer2 must be non-negative")
|
||||||
assert(checkconflict1, "irounding1 and ichamfer1 (possibly inherited from irounding and ichamfer) cannot both be nonzero at the same corner")
|
assert(checkconflict1, "irounding1 and ichamfer1 (possibly inherited from irounding and ichamfer) cannot both be nonzero at the swame corner")
|
||||||
assert(checkconflict2, "irounding2 and ichamfer2 (possibly inherited from irounding and ichamfer) cannot both be nonzero at the same corner");
|
assert(checkconflict2, "irounding2 and ichamfer2 (possibly inherited from irounding and ichamfer) cannot both be nonzero at the swame corner");
|
||||||
irounding1 = _rect_tube_rounding(1,irounding1_temp, rounding1, ichamfer1_temp, size1, isize1);
|
irounding1 = _rect_tube_rounding(1,irounding1_temp, rounding1, ichamfer1_temp, size1, isize1);
|
||||||
irounding2 = _rect_tube_rounding(1,irounding2_temp, rounding2, ichamfer2_temp, size2, isize2);
|
irounding2 = _rect_tube_rounding(1,irounding2_temp, rounding2, ichamfer2_temp, size2, isize2);
|
||||||
ichamfer1 = _rect_tube_rounding(1/sqrt(2),ichamfer1_temp, chamfer1, irounding1_temp, size1, isize1);
|
ichamfer1 = _rect_tube_rounding(1/sqrt(2),ichamfer1_temp, chamfer1, irounding1_temp, size1, isize1);
|
||||||
|
@ -2355,6 +2355,7 @@ module zcyl(
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// Module: tube()
|
// Module: tube()
|
||||||
// Synopsis: Creates a cylindrical or conical tube.
|
// Synopsis: Creates a cylindrical or conical tube.
|
||||||
// SynTags: Geom
|
// SynTags: Geom
|
||||||
|
@ -2371,9 +2372,6 @@ module zcyl(
|
||||||
// Usage: Conical tubes
|
// Usage: Conical tubes
|
||||||
// tube(h|l, ir1=|id1=, ir2=|id2=, or1=|od1=, or2=|od2=, ...) [ATTACHMENTS];
|
// tube(h|l, ir1=|id1=, ir2=|id2=, or1=|od1=, or2=|od2=, ...) [ATTACHMENTS];
|
||||||
// tube(h|l, or1=|od1=, or2=|od2=, wall=, ...) [ATTACHMENTS];
|
// tube(h|l, or1=|od1=, or2=|od2=, wall=, ...) [ATTACHMENTS];
|
||||||
// Usage: Rounded and chamfered tubes
|
|
||||||
// tube(..., [rounding=], [irounding=], [orounding=], [rounding1=], [rounding2=], [irounding1=], [irounding2=], [orounding1=], [orounding2=], [teardrop=]);
|
|
||||||
// tube(..., [chamfer=], [ichamfer=], [ochamfer=], [chamfer1=], [chamfer2=], [ichamfer1=], [ichamfer2=], [ochamfer1=], [ochamfer2=]);
|
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// h / l = height of tube. Default: 1
|
// h / l = height of tube. Default: 1
|
||||||
// or = Outer radius of tube. Default: 1
|
// or = Outer radius of tube. Default: 1
|
||||||
|
@ -2391,25 +2389,6 @@ module zcyl(
|
||||||
// ir2 = Inner radius of top of tube.
|
// ir2 = Inner radius of top of tube.
|
||||||
// id1 = Inner diameter of bottom of tube.
|
// id1 = Inner diameter of bottom of tube.
|
||||||
// id2 = Inner diameter of top of tube.
|
// id2 = Inner diameter of top of tube.
|
||||||
// rounding = The radius of the rounding on the ends of the tube. Default: none.
|
|
||||||
// rounding1 = The radius of the rounding on the bottom end of the tube.
|
|
||||||
// rounding2 = The radius of the rounding on the top end of the tube.
|
|
||||||
// irounding = The radius of the rounding on the inside of the ends of the tube.
|
|
||||||
// irounding1 = The radius of the rounding on the bottom inside end of the tube.
|
|
||||||
// irounding2 = The radius of the rounding on the top inside end of the tube.
|
|
||||||
// orounding = The radius of the rounding on the outside of the ends of the tube.
|
|
||||||
// orounding1 = The radius of the rounding on the bottom outside end of the tube.
|
|
||||||
// orounding2 = The radius of the rounding on the top outside end of the tube.
|
|
||||||
// chamfer = The size of the chamfer on the ends of the tube. Default: none.
|
|
||||||
// chamfer1 = The size of the chamfer on the bottom end of the tube.
|
|
||||||
// chamfer2 = The size of the chamfer on the top end of the tube.
|
|
||||||
// ichamfer = The size of the chamfer on the inside of the ends of the tube.
|
|
||||||
// ichamfer1 = The size of the chamfer on the bottom inside end of the tube.
|
|
||||||
// ichamfer2 = The size of the chamfer on the top inside end of the tube.
|
|
||||||
// ochamfer = The size of the chamfer on the outside of the ends of the tube.
|
|
||||||
// ochamfer1 = The size of the chamfer on the bottom outside end of the tube.
|
|
||||||
// ochamfer2 = The size of the chamfer on the top outside end of the tube.
|
|
||||||
// teardrop = if true roundings on the bottom use a teardrop shape. Default: false
|
|
||||||
// realign = If true, rotate the tube by half the angle of one face.
|
// realign = If true, rotate the tube by half the angle of one face.
|
||||||
// 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`
|
||||||
|
@ -2428,35 +2407,23 @@ module zcyl(
|
||||||
// tube(h=30, or1=40, or2=30, ir1=20, ir2=30);
|
// tube(h=30, or1=40, or2=30, ir1=20, ir2=30);
|
||||||
// Example: Standard Connectors
|
// Example: Standard Connectors
|
||||||
// tube(h=30, or=40, wall=5) show_anchors();
|
// tube(h=30, or=40, wall=5) show_anchors();
|
||||||
// Example: Chamfered tube
|
|
||||||
// back_half()
|
|
||||||
// tube(ir=10,or=20, h=30, chamfer=2);
|
|
||||||
// Example: Rounded conical tube, with negative rounding at base
|
|
||||||
// back_half()
|
|
||||||
// tube(ir=10,or=20,or2=5,ir2=2, h=30, rounding1=-5,rounding2=1.5);
|
|
||||||
// Example: Mixing chamfers and roundings
|
|
||||||
// back_half()
|
|
||||||
// tube(ir=10,or=20,h=30, ochamfer1=-5,irounding1=-3, orounding2=6, ichamfer2=2);
|
|
||||||
|
|
||||||
function tube(
|
function tube(
|
||||||
h, or, ir, center,
|
h, or, ir, center,
|
||||||
od, id, wall,
|
od, id, wall,
|
||||||
or1, or2, od1, od2,
|
or1, or2, od1, od2,
|
||||||
ir1, ir2, id1, id2,
|
ir1, ir2, id1, id2,
|
||||||
realign=false, l, length, height,
|
realign=false, l, length, height,
|
||||||
anchor, spin=0, orient=UP, orounding1,irounding1,orounding2,irounding2,rounding1,rounding2,rounding,
|
anchor, spin=0, orient=UP
|
||||||
ochamfer1,ichamfer1,ochamfer2,ichamfer2,chamfer1,chamfer2,chamfer,irounding,ichamfer,orounding,ochamfer, teardrop=false
|
|
||||||
) = no_function("tube");
|
) = no_function("tube");
|
||||||
|
|
||||||
|
|
||||||
module tube(
|
module tube(
|
||||||
h, or, ir, center,
|
h, or, ir, center,
|
||||||
od, id, wall,
|
od, id, wall,
|
||||||
or1, or2, od1, od2,
|
or1, or2, od1, od2,
|
||||||
ir1, ir2, id1, id2,
|
ir1, ir2, id1, id2,
|
||||||
realign=false, l, length, height,
|
realign=false, l, length, height,
|
||||||
anchor, spin=0, orient=UP, orounding1,irounding1,orounding2,irounding2,rounding1,rounding2,rounding,
|
anchor, spin=0, orient=UP
|
||||||
ochamfer1,ichamfer1,ochamfer2,ichamfer2,chamfer1,chamfer2,chamfer,irounding,ichamfer,orounding,ochamfer, teardrop=false
|
|
||||||
) {
|
) {
|
||||||
h = one_defined([h,l,height,length],"h,l,height,length",dflt=1);
|
h = one_defined([h,l,height,length],"h,l,height,length",dflt=1);
|
||||||
orr1 = get_radius(r1=or1, r=or, d1=od1, d=od, dflt=undef);
|
orr1 = get_radius(r1=or1, r=or, d1=od1, d=od, dflt=undef);
|
||||||
|
@ -2471,51 +2438,15 @@ module tube(
|
||||||
checks =
|
checks =
|
||||||
assert(all_defined([r1, r2, ir1, ir2]), "Must specify two of inner radius/diam, outer radius/diam, and wall width.")
|
assert(all_defined([r1, r2, ir1, ir2]), "Must specify two of inner radius/diam, outer radius/diam, and wall width.")
|
||||||
assert(ir1 <= r1, "Inner radius is larger than outer radius.")
|
assert(ir1 <= r1, "Inner radius is larger than outer radius.")
|
||||||
assert(ir2 <= r2, "Inner radius is larger than outer radius.")
|
assert(ir2 <= r2, "Inner radius is larger than outer radius.");
|
||||||
assert(num_defined([rounding,chamfer])<2, "Cannot give both rounding and chamfer")
|
sides = segs(max(r1,r2));
|
||||||
assert(num_defined([irounding,ichamfer])<2, "Cannot give both irounding and ichamfer")
|
|
||||||
assert(num_defined([orounding,ochamfer])<2, "Cannot give both orounding and ochamfer")
|
|
||||||
assert(num_defined([rounding1,chamfer1])<2, "Cannot give both rounding1 and chamfer1")
|
|
||||||
assert(num_defined([irounding1,ichamfer1])<2, "Cannot give both irounding1 and ichamfern")
|
|
||||||
assert(num_defined([orounding1,ochamfer1])<2, "Cannot give both orounding1 and ochamfer1")
|
|
||||||
assert(num_defined([rounding2,chamfer2])<2, "Cannot give both rounding2 and chamfer2")
|
|
||||||
assert(num_defined([irounding2,ichamfer2])<2, "Cannot give both irounding2 and ichamfern")
|
|
||||||
assert(num_defined([orounding2,ochamfer2])<2, "Cannot give both orounding2 and ochamfer2");
|
|
||||||
names = ["irounding","orounding","rounding","irounding1","irounding2","orounding1","orounding2",
|
|
||||||
"ichamfer","ochamfer","chamfer","ichamfer1","ichamfer2","ochamfer1","ochamfer2"];
|
|
||||||
vals = [irounding,orounding,rounding,irounding1,irounding2,orounding1,orounding2,
|
|
||||||
ichamfer,ochamfer,chamfer,ichamfer1,ichamfer2,ochamfer1,ochamfer2];
|
|
||||||
bad = [for(i=idx(names)) if (is_def(vals[i]) && !is_finite(vals[i])) i];
|
|
||||||
checks2 = assert(bad==[],str("Rounding/chamfer parameters must be numbers. The following are invalid: ",
|
|
||||||
select(names,bad)));
|
|
||||||
findval = function (factor,vlist,i=0)
|
|
||||||
i>=len(vlist) || is_def(vlist[i][1]) ? undef
|
|
||||||
: is_def(vlist[i][0]) ? factor*vlist[i][0]
|
|
||||||
: findval(factor,vlist,i+1);
|
|
||||||
irounding1 = findval(-1,[[irounding1,ichamfer1],[rounding1,chamfer1],[irounding,ichamfer],[rounding,chamfer]]);
|
|
||||||
irounding2 = findval(-1,[[irounding2,ichamfer2],[rounding2,chamfer2],[irounding,ichamfer],[rounding,chamfer]]);
|
|
||||||
orounding1 = findval(1,[[orounding1,ochamfer1],[rounding1,chamfer1],[orounding,ochamfer],[rounding,chamfer]]);
|
|
||||||
orounding2 = findval(1,[[orounding2,ochamfer2],[rounding2,chamfer2],[orounding,ochamfer],[rounding,chamfer]]);
|
|
||||||
ichamfer1 = findval(-1,[[ichamfer1,irounding1],[chamfer1,rounding1],[ichamfer,irounding],[chamfer,rounding]]);
|
|
||||||
ichamfer2 = findval(-1,[[ichamfer2,irounding2],[chamfer2,rounding2],[ichamfer,irounding],[chamfer,rounding]]);
|
|
||||||
ochamfer1 = findval(1,[[ochamfer1,orounding1],[chamfer1,rounding1],[ochamfer,orounding],[chamfer,rounding]]);
|
|
||||||
ochamfer2 = findval(1,[[ochamfer2,orounding2],[chamfer2,rounding2],[ochamfer,orounding],[chamfer,rounding]]);
|
|
||||||
|
|
||||||
/* This is too restrictive, at least on cones
|
|
||||||
dummy =
|
|
||||||
assert( first_defined([irounding1,ichamfer1,0])+first_defined([orounding1,ochamfer1,0]) <= r1-ir1, "Chamfer/rounding doesn't fit at bottom")
|
|
||||||
assert( first_defined([irounding2,ichamfer2,0])+first_defined([orounding2,ochamfer2,0]) <= r2-ir2, "Chamfer/rounding doesn't fit at top")
|
|
||||||
assert( -first_defined([irounding1,ichamfer1,0])<ir1, "Negative inside chamfer/rounding doesn't fit at bottom")
|
|
||||||
assert( -first_defined([irounding2,ichamfer2,0])<ir1, "Negative inside chamfer/rounding doesn't fit at top");
|
|
||||||
*/
|
|
||||||
|
|
||||||
anchor = get_anchor(anchor, center, BOT, CENTER);
|
anchor = get_anchor(anchor, center, BOT, CENTER);
|
||||||
attachable(anchor,spin,orient, r1=r1, r2=r2, l=h) {
|
attachable(anchor,spin,orient, r1=r1, r2=r2, l=h) {
|
||||||
difference() {
|
zrot(realign? 180/sides : 0) {
|
||||||
cyl(h=h, r1=r1, r2=r2, realign=realign, teardrop=teardrop,
|
difference() {
|
||||||
rounding1=orounding1,rounding2=orounding2,chamfer1=ochamfer1, chamfer2=ochamfer2);
|
cyl(h=h, r1=r1, r2=r2, $fn=sides) children();
|
||||||
cyl(h=h+0.01, r1=ir1, r2=ir2, realign=realign, teardrop=teardrop,
|
cyl(h=h+0.05, r1=ir1, r2=ir2);
|
||||||
rounding1=irounding1,rounding2=irounding2, chamfer1=ichamfer1, chamfer2=ichamfer2);
|
}
|
||||||
}
|
}
|
||||||
children();
|
children();
|
||||||
}
|
}
|
||||||
|
@ -2523,7 +2454,6 @@ module tube(
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// Function&Module: pie_slice()
|
// Function&Module: pie_slice()
|
||||||
// Synopsis: Creates a pie slice shape.
|
// Synopsis: Creates a pie slice shape.
|
||||||
// SynTags: Geom, VNF
|
// SynTags: Geom, VNF
|
||||||
|
|
Loading…
Reference in a new issue