forked from jcrocholl/rostock
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathspool.scad
45 lines (42 loc) · 1.39 KB
/
spool.scad
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
include <configuration.scad>;
m3_nut_radius = 3.2;
m3_wide_radius=1.7;
motor_shaft_radius=2.5;
radius = 9;
width = 16;
top = 5;
smoothness = 60;
module spool() {
difference() {
union() {
# cylinder(r=radius, h=width, center=true, $fn=smoothness);
translate([0, 0, width/2])
cylinder(r1=radius, r2=radius+2, h=2, center=true, $fn=smoothness);
translate([0, 0, -width/2])
cylinder(r2=radius, r1=radius+2, h=2, center=true, $fn=smoothness);
translate([0, 0, width/2+top/2+1])
cylinder(r=radius+2, h=top, center=true, $fn=smoothness);
}
// Motor shaft.
cylinder(r=motor_shaft_radius, h=50, center=true, $fn=24);
// Filament tunnels.
translate([0, radius, width/2-1.5]) rotate([-30, 0, 0])
#cube([1, 2*radius, 1.5], center=true);
translate([0, radius, -width/2+1.5]) rotate([30, 0, 0])
#cube([1, 2*radius, 1.5], center=true);
translate([0, 5, 0])
#cylinder(r=1, h=40, center=true, $fn=6);
// M3 screws and nuts on three sides.
for (a = [0:120:359]) {
rotate([0, 0, a]) translate([0, 4.5, width/2+3]) rotate([90, 0, 0]) {
cylinder(r=m3_wide_radius, h=radius+5, center=true, $fn=12);
translate([0, 0, 1-radius]) cylinder(r=10, h=6, center=true);
for (z = [0:10]) {
translate([0, z, 1.5]) rotate([0, 0, 30])
cylinder(r=m3_nut_radius, h=5, center=true, $fn=6);
}
}
}
}
}
translate([0, 0, width/2+1]) spool();