Files
spoolmount/v1/scad/lib/generic/spoolmount.scad

79 lines
1.9 KiB
OpenSCAD
Raw Normal View History

2024-07-12 09:08:58 -07:00
use <../util/torus.scad>
module spoolmount() {
difference() {
2024-07-07 16:15:35 -07:00
// Cylinder body
2024-07-19 22:05:23 -07:00
cylinder(h=5, r=44, $fn=200);
2024-07-07 16:15:35 -07:00
// Central through hole
2024-07-10 19:09:18 -07:00
cylinder(h=5, r=25.1, $fn=200);
2024-07-19 22:05:23 -07:00
// Cutouts for rounded edges
for (z = [-1, 4.5]) {
translate([0, 0, z])
cylinder(h=1.5, r=25.45, $fn=200);
}
// Holes
for (a = [0 : 30 : 330]) {
rotate([0, 0, a])
translate([34.75, 0, 0])
rotate([90, 0, 90])
linear_extrude(9.25, center=true)
polygon(points=[
[4, -1],
[4, 2],
[6, 4],
[6, 6],
[-6, 6],
[-6, 4],
[-4, 2],
[-4, -1],
]);
}
}
2024-07-10 19:09:18 -07:00
2024-07-19 22:05:23 -07:00
intersection() {
cylinder(h=5, r=25.1, $fn=200);
2024-07-10 19:09:18 -07:00
2024-07-19 22:05:23 -07:00
for (a = [45 : 90 : 335]) {
// Locking bumps
rotate([0, 0, a - 10])
rotate_extrude(angle=20, $fn=200)
translate([23.1, 0, 0])
2024-07-07 16:15:35 -07:00
polygon(points=[
2024-07-19 22:05:23 -07:00
[2.0, 0],
[2.0, 0.5],
[0, 2.5],
[2.0, 4.5],
[2.0, 5],
2024-07-07 16:15:35 -07:00
]);
2024-07-19 22:05:23 -07:00
// Rounded bump ends
for (o = [-10, 10]) {
rotate([0, 0, a + o])
translate([0, 30.1, 0])
scale([0.2, 1.0, 1.0])
rotate_extrude($fn=200)
translate([5, 0, 0])
polygon(points=[
[0, 0.5],
[2.0, 2.5],
[0, 4.5],
]);
}
2024-07-07 16:15:35 -07:00
}
}
2024-07-07 16:15:35 -07:00
// Rounded outer edge
2024-07-19 22:05:23 -07:00
translate([0, 0, 2.5])
torus(r_major=44, r_minor=2.5, xs=0.7, $fn=200);
2024-07-10 19:09:18 -07:00
// Rounded inner edges
2024-07-19 22:05:23 -07:00
for (z = [0.5, 4.5]) {
translate([0, 0, z])
2024-07-10 19:09:18 -07:00
torus(r_major=25.45, r_minor=0.5, xs=0.7, $fn=200);
}
}
spoolmount();