mirror of
https://github.com/BelfrySCAD/BOSL2.git
synced 2025-01-17 01:49:48 +00:00
Allow non-overlapping cuboid() chamfers and roundings larger than half the cube size.
This commit is contained in:
parent
d21dd1c6ba
commit
a52039eec7
1 changed files with 51 additions and 40 deletions
|
@ -215,43 +215,48 @@ module cuboid(
|
||||||
cnt = sum(e);
|
cnt = sum(e);
|
||||||
r = first_defined([chamfer, rounding]);
|
r = first_defined([chamfer, rounding]);
|
||||||
dummy=assert(is_finite(r) && !approx(r,0));
|
dummy=assert(is_finite(r) && !approx(r,0));
|
||||||
c = [min(r,size.x/2), min(r,size.y/2), min(r,size.z/2)];
|
c = [r,r,r];
|
||||||
|
m = 0.01;
|
||||||
c2 = v_mul(corner,c/2);
|
c2 = v_mul(corner,c/2);
|
||||||
|
c3 = v_mul(corner,c-[1,1,1]*m/2);
|
||||||
$fn = is_finite(chamfer)? 4 : quantup(segs(r),4);
|
$fn = is_finite(chamfer)? 4 : quantup(segs(r),4);
|
||||||
translate(v_mul(corner, size/2-c)) {
|
translate(v_mul(corner, size/2-c)) {
|
||||||
if (cnt == 0 || approx(r,0)) {
|
intersection() {
|
||||||
translate(c2) cube(c, center=true);
|
if (cnt == 0 || approx(r,0)) {
|
||||||
} else if (cnt == 1) {
|
translate(c3) cube(m, center=true);
|
||||||
if (e.x) right(c2.x) xtcyl(l=c.x, r=r);
|
} else if (cnt == 1) {
|
||||||
if (e.y) back (c2.y) ytcyl(l=c.y, r=r);
|
if (e.x) right(c3.x) xtcyl(l=m, r=r);
|
||||||
if (e.z) up (c2.z) zcyl(l=c.z, r=r);
|
if (e.y) back (c3.y) ytcyl(l=m, r=r);
|
||||||
} else if (cnt == 2) {
|
if (e.z) up (c3.z) zcyl(l=m, r=r);
|
||||||
if (!e.x) {
|
} else if (cnt == 2) {
|
||||||
intersection() {
|
if (!e.x) {
|
||||||
ytcyl(l=c.y*2, r=r);
|
intersection() {
|
||||||
zcyl(l=c.z*2, r=r);
|
ytcyl(l=c.y*2, r=r);
|
||||||
}
|
zcyl(l=c.z*2, r=r);
|
||||||
} else if (!e.y) {
|
}
|
||||||
intersection() {
|
} else if (!e.y) {
|
||||||
xtcyl(l=c.x*2, r=r);
|
intersection() {
|
||||||
zcyl(l=c.z*2, r=r);
|
xtcyl(l=c.x*2, r=r);
|
||||||
|
zcyl(l=c.z*2, r=r);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
intersection() {
|
||||||
|
xtcyl(l=c.x*2, r=r);
|
||||||
|
ytcyl(l=c.y*2, r=r);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
intersection() {
|
if (trimcorners) {
|
||||||
xtcyl(l=c.x*2, r=r);
|
tsphere(r=r);
|
||||||
ytcyl(l=c.y*2, r=r);
|
} else {
|
||||||
}
|
intersection() {
|
||||||
}
|
xtcyl(l=c.x*2, r=r);
|
||||||
} else {
|
ytcyl(l=c.y*2, r=r);
|
||||||
if (trimcorners) {
|
zcyl(l=c.z*2, r=r);
|
||||||
tsphere(r=r);
|
}
|
||||||
} else {
|
|
||||||
intersection() {
|
|
||||||
xtcyl(l=c.x*2, r=r);
|
|
||||||
ytcyl(l=c.y*2, r=r);
|
|
||||||
zcyl(l=c.z*2, r=r);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
translate(c2) cube(c, center=true); // Trim to just the octant.
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -281,15 +286,22 @@ module cuboid(
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (is_finite(chamfer)) {
|
rr = max(default(chamfer,0), default(rounding,0));
|
||||||
if (any(edges[0])) assert(chamfer <= size.y/2 && chamfer <=size.z/2, "chamfer must be smaller than half the cube length or height.");
|
if (rr>0) {
|
||||||
if (any(edges[1])) assert(chamfer <= size.x/2 && chamfer <=size.z/2, "chamfer must be smaller than half the cube width or height.");
|
rv = [for (i=[0:2])
|
||||||
if (any(edges[2])) assert(chamfer <= size.x/2 && chamfer <=size.y/2, "chamfer must be smaller than half the cube width or length.");
|
[for (j=[0:3])
|
||||||
}
|
(edges[i][j]>0?rr:0) * v_abs(EDGE_OFFSETS[i][j])
|
||||||
if (is_finite(rounding)) {
|
]
|
||||||
if (any(edges[0])) assert(rounding <= size.y/2 && rounding<=size.z/2, "rounding radius must be smaller than half the cube length or height.");
|
];
|
||||||
if (any(edges[1])) assert(rounding <= size.x/2 && rounding<=size.z/2, "rounding radius must be smaller than half the cube width or height.");
|
grays = pair([0,1,3,2],wrap=true); // gray code ordering.
|
||||||
if (any(edges[2])) assert(rounding <= size.x/2 && rounding<=size.y/2, "rounding radius must be smaller than half the cube width or length.");
|
minx = max([for (i=[1,2], j=grays) rv[i][j[0]].x + rv[i][j[1]].x]);
|
||||||
|
miny = max([for (i=[0,2], j=grays) rv[i][j[0]].y + rv[i][j[1]].y]);
|
||||||
|
minz = max([for (i=[0,1], j=grays) rv[i][j[0]].z + rv[i][j[1]].z]);
|
||||||
|
check =
|
||||||
|
assert(minx <= size.x, "Rounding or chamfering too large for cuboid size in the X axis.")
|
||||||
|
assert(miny <= size.y, "Rounding or chamfering too large for cuboid size in the Y axis.")
|
||||||
|
assert(minz <= size.z, "Rounding or chamfering too large for cuboid size in the Z axis.")
|
||||||
|
;
|
||||||
}
|
}
|
||||||
majrots = [[0,90,0], [90,0,0], [0,0,0]];
|
majrots = [[0,90,0], [90,0,0], [0,0,0]];
|
||||||
attachable(anchor,spin,orient, size=size) {
|
attachable(anchor,spin,orient, size=size) {
|
||||||
|
@ -2312,7 +2324,6 @@ function teardrop(h, r, ang=45, cap_h, r1, r2, d, d1, d2, cap_h1, cap_h2, l, anc
|
||||||
profile2 = teardrop2d(r=r2, ang=ang, cap_h=cap_h2, $fn=sides),
|
profile2 = teardrop2d(r=r2, ang=ang, cap_h=cap_h2, $fn=sides),
|
||||||
tip_y1 = max(column(profile1,1)),
|
tip_y1 = max(column(profile1,1)),
|
||||||
tip_y2 = max(column(profile2,1)),
|
tip_y2 = max(column(profile2,1)),
|
||||||
feef=echo(tip_y1=tip_y1, tip_y2=tip_y2),
|
|
||||||
_cap_h1 = min(default(cap_h1, tip_y1), tip_y1),
|
_cap_h1 = min(default(cap_h1, tip_y1), tip_y1),
|
||||||
_cap_h2 = min(default(cap_h2, tip_y2), tip_y2),
|
_cap_h2 = min(default(cap_h2, tip_y2), tip_y2),
|
||||||
capvec = unit([0, _cap_h1-_cap_h2, l]),
|
capvec = unit([0, _cap_h1-_cap_h2, l]),
|
||||||
|
|
Loading…
Reference in a new issue