1 changed files with 112 additions and 0 deletions
@ -0,0 +1,112 @@ |
|||||
|
// When a small distance is needed to overlap shapes for boolean cutting, etc. |
||||
|
epsilon = 0.01; |
||||
|
|
||||
|
module bevel(l, w, h){ |
||||
|
polyhedron( |
||||
|
points=[[0,0,0], [l,0,0], [l,w,0], [0,w,0], [0,0,h], [l,0,h]], |
||||
|
faces=[[0,1,2,3],[5,4,3,2],[0,4,5,1],[0,3,4],[5,2,1]] |
||||
|
); |
||||
|
} |
||||
|
|
||||
|
module shim(l, w, h){ |
||||
|
polyhedron( |
||||
|
points=[[-l/2,-w/2,0], [l/2,-w/2,0], [l/2,w/2,0], [-l/2,w/2,0], [-l/2+w/4,0,h], [l/2-w/4,0,h]], |
||||
|
faces=[[0,1,2,3],[5,4,3,2],[0,4,5,1],[0,3,4],[5,2,1]] |
||||
|
); |
||||
|
} |
||||
|
|
||||
|
module halfBevel(l, w, h) { |
||||
|
bevel(l,h,h); |
||||
|
translate([0,w,0]) |
||||
|
rotate(a = 270) |
||||
|
bevel(w,h,h); |
||||
|
} |
||||
|
|
||||
|
module fullBevel(l, w, h, b) { |
||||
|
halfBevel(l, w, b); |
||||
|
translate([l,w,0]) |
||||
|
rotate(a = 180) |
||||
|
halfBevel(l, w, 1); |
||||
|
|
||||
|
translate([0,0,h]) |
||||
|
rotate(a = 90, v = [0, 1, 0]) |
||||
|
bevel(h,b,b); |
||||
|
translate([l,0,h]) |
||||
|
rotate(a = 90) |
||||
|
rotate(a = 90, v = [0, 1, 0]) |
||||
|
bevel(h,b,b); |
||||
|
translate([l,w,h]) |
||||
|
rotate(a = 180) |
||||
|
rotate(a = 90, v = [0, 1, 0]) |
||||
|
bevel(h,b,b); |
||||
|
translate([0,w,h]) |
||||
|
rotate(a = 270) |
||||
|
rotate(a = 90, v = [0, 1, 0]) |
||||
|
bevel(h,b,b); |
||||
|
|
||||
|
} |
||||
|
|
||||
|
module tubeBevel(l, w, h, b) { |
||||
|
translate([0,0,h]) |
||||
|
rotate(a = 90, v = [0, 1, 0]) |
||||
|
bevel(h,b,b); |
||||
|
translate([l,0,h]) |
||||
|
rotate(a = 90) |
||||
|
rotate(a = 90, v = [0, 1, 0]) |
||||
|
bevel(h,b,b); |
||||
|
translate([l,w,h]) |
||||
|
rotate(a = 180) |
||||
|
rotate(a = 90, v = [0, 1, 0]) |
||||
|
bevel(h,b,b); |
||||
|
translate([0,w,h]) |
||||
|
rotate(a = 270) |
||||
|
rotate(a = 90, v = [0, 1, 0]) |
||||
|
bevel(h,b,b); |
||||
|
} |
||||
|
|
||||
|
module beveledCube(l, w, h, b) { |
||||
|
difference() { |
||||
|
cube([l,w,h]); |
||||
|
translate([-epsilon, -epsilon, -epsilon]) |
||||
|
fullBevel(l + 2 * epsilon, w + 2 * epsilon, h + 2 * epsilon, 1); |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
module squareTube(l, w, h, t) { |
||||
|
difference() { |
||||
|
cube([l,w,h]); |
||||
|
translate([t,t,-epsilon]) |
||||
|
cube([l - 2 * t, w - 2 * t, h + 2 * epsilon]); |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
module beveledTube(l, w, h, t, b) { |
||||
|
difference() { |
||||
|
squareTube(l, w, h, 2); |
||||
|
translate([-epsilon,-epsilon,epsilon]) |
||||
|
tubeBevel(l + 2 * epsilon, w + 2 * epsilon, h + epsilon, b); |
||||
|
} |
||||
|
translate([t,t,0]) |
||||
|
tubeBevel(l - 2 * t, w - 2 * t, h, b); |
||||
|
} |
||||
|
|
||||
|
module endCap(cl, cw, ch, tl, tw, th, sl, sw, sh, t, b) { |
||||
|
translate([ (cl - tl) / 2, (cw - tw) / 2, 0]) |
||||
|
beveledTube(tl, tw, th, t, b); |
||||
|
|
||||
|
translate([ 0, 0, -ch ]) |
||||
|
beveledCube(cl, cw, ch, b); |
||||
|
|
||||
|
|
||||
|
translate([ cl / 2, (cw - tw) / 2, th / 2 ]) |
||||
|
rotate(a = 90, v = [1, 0, 0]) |
||||
|
shim(sl, sw, sh); |
||||
|
|
||||
|
translate([ cl / 2, cw / 2 + tw / 2, th / 2 ]) |
||||
|
rotate(a = 270, v = [1, 0, 0]) |
||||
|
shim(sl, sw, sh); |
||||
|
|
||||
|
} |
||||
|
|
||||
|
endCap(50, 30, 4, 46.5, 27.14, 13, 4, 2, 0.5, 2, 1); |
||||
|
|
||||
Loading…
Reference in new issue