summaryrefslogtreecommitdiff
path: root/another.scad
Unidiff
Diffstat (limited to 'another.scad') (more/less context) (ignore whitespace changes)
-rw-r--r--another.scad4
1 files changed, 2 insertions, 2 deletions
diff --git a/another.scad b/another.scad
index 116344e..461dc26 100644
--- a/another.scad
+++ b/another.scad
@@ -1,438 +1,438 @@
1draft=true; 1draft=true;
2layer_height=0.2; extrusion_width=0.4; 2layer_height=0.2; extrusion_width=0.4;
3epsilon=0.01; 3epsilon=0.01;
4$fs=0.0125; 4$fs=0.0125;
5 5
6use <pushfittery.scad>; 6use <pushfittery.scad>;
7include <pushfit_data.scad>; 7include <pushfit_data.scad>;
8include <pulley_data.scad>; 8include <pulley_data.scad>;
9 9
10module the_extruder( 10module the_extruder(
11 // motor properties 11 // motor properties
12 gearbox_d = 36, 12 gearbox_d = 36,
13 mount_d = 28, // the distance between opposite mounting holes 13 mount_d = 28, // the distance between opposite mounting holes
14 mounthole_depth = 5, 14 mounthole_depth = 5,
15 mounthole_min_depth = 3, mounthole_max_depth = 4, 15 mounthole_min_depth = 3, mounthole_max_depth = 4,
16 protrusion_d = 22, protrusion_h = 2.2, // the dimensions of the protrusion on top of gearbox 16 protrusion_d = 22, protrusion_h = 2.2, // the dimensions of the protrusion on top of gearbox
17 bore_d = 8, bore_l = 17.6, 17 bore_d = 8, bore_l = 17.6,
18 bore_dd = 7, 18 bore_dd = 7,
19 // pulley properties 19 // pulley properties
20 pulley = pulley_e3d, 20 pulley = pulley_e3d,
21 pulley_elevation = 1, // pulley elevation above the protrusion 21 pulley_elevation = 1, // pulley elevation above the protrusion
22 // idler properties 22 // idler properties
23 idler_d = 9.5, idler_h = 4, idler_id = 3,// idler dimensions: outer and inner diameters and height 23 idler_d = 9.5, idler_h = 4, idler_id = 3,// idler dimensions: outer and inner diameters and height
24 // spring properties 24 // spring properties
25 spring_d = 10, spring_lc = 9.6, // spring diameter and compressed length 25 spring_d = 10, spring_lc = 9.6, // spring diameter and compressed length
26 // filament path properties 26 // filament path properties
27 filament_d = 1.75, 27 filament_d = 1.75,
28 filament_path_d = 2, 28 filament_path_d = 2,
29 filament_guide_d = 4, // PTFE filament guide diameter 29 filament_guide_d = 4, // PTFE filament guide diameter
30 // knob properties 30 // knob properties
31 knob_h = 10, 31 knob_h = 10,
32 knob_bore_l = 4, 32 knob_bore_l = 4,
33 knob_indent_d = 4, 33 knob_indent_d = 4,
34 knob_indents = 12, 34 knob_indents = 12,
35 // spring tensioner 35 // spring tensioner
36 st_nut_d = 9, st_nut_h = 4, 36 st_nut_d = 9, st_nut_h = 4,
37 st_screw_d = 5, 37 st_screw_d = 5,
38 st_thickshell = 8*extrusion_width, st_thinshell = 2*extrusion_width, 38 st_thickshell = 8*extrusion_width, st_thinshell = 2*extrusion_width,
39 st_split_w = 4*extrusion_width, 39 st_split_w = 4*extrusion_width,
40 40
41 // screw it 41 // screw it
42 mount_screw_d = 3.1, mount_screw_l = 20, 42 mount_screw_d = 3.1, mount_screw_l = 20,
43 mount_screwhead_d=6, mount_screwhead_h=3, 43 mount_screwhead_d=6, mount_screwhead_h=3,
44 idler_screw_d = 3, 44 idler_screw_d = 3,
45 idler_screwhead_d=6, idler_screwhead_h=3, 45 idler_screwhead_d=6, idler_screwhead_h=3,
46 46
47 pf = pushfit_metal, 47 pf = pushfit_metal,
48 pf_shell = max(3*layer_height,3*extrusion_width), 48 pf_shell = max(3*layer_height,3*extrusion_width),
49 pf_smooth = true, 49 pf_smooth = true,
50 50
51 // empty spaces 51 // empty spaces
52 idler_travel = 3, // how far should idler travel when pressed 52 idler_travel = 3, // how far should idler travel when pressed
53 idler_clearance=1, 53 idler_clearance=.5,
54 pulley_small_d_clearance=0.5, 54 pulley_small_d_clearance=.5,
55 lever_v_clearance=.7, // vertical clearance for the lever 55 lever_v_clearance=.7, // vertical clearance for the lever
56 spring_d_clearance=1, 56 spring_d_clearance=1,
57 protrusion_tolerance_h=.5, // horizontal tolerance for the motor protrusion 57 protrusion_tolerance_h=.5, // horizontal tolerance for the motor protrusion
58 protrusion_tolerance_v=.5, // vertical tolerance for the motor protrusion 58 protrusion_tolerance_v=.5, // vertical tolerance for the motor protrusion
59 mount_screw_d_tolerance=.4, 59 mount_screw_d_tolerance=.4,
60 idler_v_tolerance=.5, 60 idler_v_tolerance=.5,
61 knob_bore_d_tolerance=.6, 61 knob_bore_d_tolerance=.6,
62 st_nut_h_tolerance=.2, 62 st_nut_h_tolerance=.2,
63 st_nut_d_tolerance=.2,/* TODO: make it st_nut_w_tolerance */ 63 st_nut_d_tolerance=.2,/* TODO: make it st_nut_w_tolerance */
64 st_screw_d_tolerance=.5, 64 st_screw_d_tolerance=.5,
65 st_split_w_tolerance = .3, 65 st_split_w_tolerance = .3,
66 66
67 min_z_shell = 4*layer_height, // the very minimal shell thickness along z-axis. 67 min_z_shell = 4*layer_height, // the very minimal shell thickness along z-axis.
68 min_xy_shell = 2*extrusion_width, 68 min_xy_shell = 2*extrusion_width,
69 69
70 what="lever", // lever|body|knob|springpad|* 70 what="lever", // lever|body|knob|springpad|*
71 left=false, 71 left=false,
72 vitamins = true, 72 vitamins = true,
73 bridges = true, 73 bridges = true,
74 debug = false, 74 debug = false,
75 label = "another" 75 label = "another"
76) { 76) {
77 fnd = 2*PI; fnr = 2*fnd; 77 fnd = 2*PI; fnr = 2*fnd;
78 function lu(m,k) = m[search([k],m)[0]][1]; 78 function lu(m,k) = m[search([k],m)[0]][1];
79 79
80 pulley_d = lu(pulley,"d"); 80 pulley_d = lu(pulley,"d");
81 pulley_h = lu(pulley,"h"); 81 pulley_h = lu(pulley,"h");
82 teeth_elevation = lu(pulley,"fe"); 82 teeth_elevation = lu(pulley,"fe");
83 filament_offset = lu(pulley,"g")+filament_d/2; 83 filament_offset = lu(pulley,"g")+filament_d/2;
84 pulley_d_clearance = lu(pulley,"ssrc")*2; 84 pulley_d_clearance = lu(pulley,"ssrc")*2;
85 85
86 idler_filament_offset = filament_path_d/2; 86 idler_filament_offset = filament_path_d/2;
87 lever_shell = mount_screwhead_h+0.5; 87 lever_shell = mount_screwhead_h+0.5;
88 lever_thickness=max(spring_d+spring_d_clearance+layer_height*8,idler_h+idler_v_tolerance+2*lever_shell); 88 lever_thickness=max(spring_d+spring_d_clearance+layer_height*8,idler_h+idler_v_tolerance+2*lever_shell);
89 lsd = idler_d-idler_clearance*2; // the diameter of lever thingie 89 lsd = idler_d-idler_clearance*2; // the diameter of lever thingie
90 longwing=(mount_d+mount_screw_d+mount_screw_d_tolerance+spring_d+spring_d_clearance)/2+min_xy_shell; 90 longwing=(mount_d+mount_screw_d+mount_screw_d_tolerance+spring_d+spring_d_clearance)/2+min_xy_shell;
91 shortwing = let(a=mount_d/2,c=(pulley_d+idler_d)/2/sqrt(2)) 91 shortwing = let(a=mount_d/2,c=(pulley_d+idler_d)/2/sqrt(2))
92 sqrt(c*c+pow(a-c,2)); 92 sqrt(c*c+pow(a-c,2));
93 longwing_travel = idler_travel*longwing/shortwing; 93 longwing_travel = idler_travel*longwing/shortwing;
94 h_ = (pulley_d+idler_d)/(2*sqrt(2)); 94 h_ = (pulley_d+idler_d)/(2*sqrt(2));
95 ri = sqrt( pow(h_,2) + pow(mount_d/2-h_,2) ); 95 ri = sqrt( pow(h_,2) + pow(mount_d/2-h_,2) );
96 spring_dl = idler_travel*longwing/ri; 96 spring_dl = idler_travel*longwing/ri;
97 // finger and spring support 97 // finger and spring support
98 fsw = gearbox_d-(gearbox_d-mount_d)/2-max(spring_lc,longwing_travel+(gearbox_d-mount_d)/2); 98 fsw = gearbox_d-(gearbox_d-mount_d)/2-max(spring_lc,longwing_travel+(gearbox_d-mount_d)/2);
99 99
100 mount_min_depth = mounthole_min_depth ? mounthole_min_depth : mounthole_depth-1; 100 mount_min_depth = mounthole_min_depth ? mounthole_min_depth : mounthole_depth-1;
101 mount_max_depth = mounthole_max_depth ? mounthole_max_depth : mounthole_depth+1; 101 mount_max_depth = mounthole_max_depth ? mounthole_max_depth : mounthole_depth+1;
102 filament_elevation=protrusion_h+pulley_elevation+teeth_elevation; 102 filament_elevation=protrusion_h+pulley_elevation+teeth_elevation;
103 ls_z = filament_elevation; // leverspace mid-z 103 ls_z = filament_elevation; // leverspace mid-z
104 ls_h = lever_thickness+lever_v_clearance; // leverspace height 104 ls_h = lever_thickness+lever_v_clearance; // leverspace height
105 mount_depth = mount_screw_l - (ls_z+ls_h/2+min_z_shell); 105 mount_depth = mount_screw_l - (ls_z+ls_h/2+min_z_shell);
106 body_h = max(protrusion_h+bore_l,mount_screw_l-mount_depth+mount_screwhead_h+min_z_shell,ls_z*2); 106 body_h = max(protrusion_h+bore_l,mount_screw_l-mount_depth+mount_screwhead_h+min_z_shell,ls_z*2);
107 echo("mount depth",mount_depth); 107 echo("mount depth",mount_depth);
108 108
109 module teardrop(r,d,h,center=false,angle=45) { 109 module teardrop(r,d,h,center=false,angle=45) {
110 dd = d ? d : (2*r); 110 dd = d ? d : (2*r);
111 $fn = dd*fnd; 111 $fn = dd*fnd;
112 cylinder(d=dd,h=h,center=center); 112 cylinder(d=dd,h=h,center=center);
113 if(angle>0) translate([0,0,center?-h/2:0]) 113 if(angle>0) translate([0,0,center?-h/2:0])
114 rotate([0,0,angle]) 114 rotate([0,0,angle])
115 cube(size=[d/2,d/2,h]); 115 cube(size=[d/2,d/2,h]);
116 } 116 }
117 117
118 module mirrorleft() { 118 module mirrorleft() {
119 mirror([left?0:1,0,0]) children(); 119 mirror([left?0:1,0,0]) children();
120 } 120 }
121 module place_idler() { 121 module place_idler() {
122 rotate([0,0,45]) 122 rotate([0,0,45])
123 translate([(pulley_d+idler_d)/2,0,0]) 123 translate([(pulley_d+idler_d)/2,0,0])
124 children(); 124 children();
125 } 125 }
126 module finger_indent(d=lever_thickness,depth/*=1*/,r/*=15*/) { 126 module finger_indent(d=lever_thickness,depth/*=1*/,r/*=15*/) {
127 if(depth) { 127 if(depth) {
128 hh = (-4*pow(depth,2)+pow(d,2))/(8*depth); 128 hh = (-4*pow(depth,2)+pow(d,2))/(8*depth);
129 rr = depth+hh; 129 rr = depth+hh;
130 translate([0,0,hh]) sphere(r=rr,$fn=fnr*rr); 130 translate([0,0,hh]) sphere(r=rr,$fn=fnr*rr);
131 }else if(r) { 131 }else if(r) {
132 hh=sqrt(pow(r,2)-pow(d,2)/4); 132 hh=sqrt(pow(r,2)-pow(d,2)/4);
133 translate([0,0,hh]) sphere(r=r,$fn=fnr*r); 133 translate([0,0,hh]) sphere(r=r,$fn=fnr*r);
134 } 134 }
135 } 135 }
136 136
137 % if(vitamins) mirrorleft() { 137 % if(vitamins) mirrorleft() {
138 translate([0,0,-epsilon]) mirror([0,0,1]) cylinder(d=gearbox_d,h=1,$fn=60); 138 translate([0,0,-epsilon]) mirror([0,0,1]) cylinder(d=gearbox_d,h=1,$fn=60);
139 for(zr=[0:90:359]) rotate([0,0,zr]) translate([mount_d/2,0,0]) 139 for(zr=[0:90:359]) rotate([0,0,zr]) translate([mount_d/2,0,0])
140 cylinder(d=mount_screw_d,h=20,$fn=30); 140 cylinder(d=mount_screw_d,h=20,$fn=30);
141 translate([0,0,-epsilon]) cylinder(d=protrusion_d,h=protrusion_h,$fn=30); 141 translate([0,0,-epsilon]) cylinder(d=protrusion_d,h=protrusion_h,$fn=30);
142 translate([0,0,protrusion_h]) { 142 translate([0,0,protrusion_h]) {
143 difference() { 143 difference() {
144 cylinder(d=bore_d,h=bore_l,$fn=30); 144 cylinder(d=bore_d,h=bore_l,$fn=30);
145 translate([-bore_d/2-1,bore_dd-bore_d/2,-1]) 145 translate([-bore_d/2-1,bore_dd-bore_d/2,-1])
146 cube([bore_d+2,bore_d/2,bore_l+2]); 146 cube([bore_d+2,bore_d/2,bore_l+2]);
147 } 147 }
148 translate([0,0,pulley_elevation]) { 148 translate([0,0,pulley_elevation]) {
149 cylinder(d=pulley_d,h=pulley_h,$fn=30); 149 cylinder(d=pulley_d,h=pulley_h,$fn=30);
150 translate([0,0,teeth_elevation]) { 150 translate([0,0,teeth_elevation]) {
151 place_idler() { 151 place_idler() {
152 cylinder(d=idler_d,h=idler_h,center=true,$fn=30); 152 cylinder(d=idler_d,h=idler_h,center=true,$fn=30);
153 cylinder(d=idler_screw_d,h=lever_thickness+2,center=true,$fn=30); 153 cylinder(d=idler_screw_d,h=lever_thickness+2,center=true,$fn=30);
154 }//place idler 154 }//place idler
155 // filament path 155 // filament path
156 rotate([0,0,45]) { 156 rotate([0,0,45]) {
157 translate([pulley_d/2-idler_filament_offset,0,0]) rotate([90,0,0]) { 157 translate([pulley_d/2-idler_filament_offset,0,0]) rotate([90,0,0]) {
158 cylinder(d=filament_d,h=gearbox_d,center=false,$fn=15); 158 cylinder(d=filament_d,h=gearbox_d,center=false,$fn=15);
159 }//rotate translate 159 }//rotate translate
160 translate([pulley_d/2+filament_offset,0,0]) rotate([-90,0,0]) { 160 translate([pulley_d/2+filament_offset,0,0]) rotate([-90,0,0]) {
161 cylinder(d=filament_d,h=gearbox_d,center=false,$fn=15); 161 cylinder(d=filament_d,h=gearbox_d,center=false,$fn=15);
162 translate([0,0,mount_d/sqrt(2)/2+mount_screw_d]) 162 translate([0,0,mount_d/sqrt(2)/2+mount_screw_d])
163 pushfit(pf); 163 pushfit(pf);
164 }//rotate translate 164 }//rotate translate
165 }//rotate 165 }//rotate
166 }//translate teeth 166 }//translate teeth
167 }//translate pulley 167 }//translate pulley
168 }//translate protrusion 168 }//translate protrusion
169 }//vitamins 169 }//vitamins
170 170
171 module lever() { 171 module lever() {
172 translate([0,0,protrusion_h+pulley_elevation+teeth_elevation]) { 172 translate([0,0,protrusion_h+pulley_elevation+teeth_elevation]) {
173 difference() { 173 difference() {
174 union() { 174 union() {
175 hull() { 175 hull() {
176 place_idler() 176 place_idler()
177 cylinder(d=lsd,h=lever_thickness,center=true,$fn=60); 177 cylinder(d=lsd,h=lever_thickness,center=true,$fn=60);
178 translate([mount_d/2,0,0]) 178 translate([mount_d/2,0,0])
179 cylinder(d=lsd,h=lever_thickness,center=true,$fn=60); 179 cylinder(d=lsd,h=lever_thickness,center=true,$fn=60);
180 }//hull 180 }//hull
181 hull() { 181 hull() {
182 translate([mount_d/2,0,0]) 182 translate([mount_d/2,0,0])
183 cylinder(d=lsd,h=lever_thickness,center=true,$fn=60); 183 cylinder(d=lsd,h=lever_thickness,center=true,$fn=60);
184 translate([mount_d/2,-longwing,0]) rotate([0,90,0]) 184 translate([mount_d/2,-longwing,0]) rotate([0,90,0])
185 cylinder(d=lever_thickness,h=lsd,center=true,$fn=60); 185 cylinder(d=lever_thickness,h=lsd,center=true,$fn=60);
186 }//hull 186 }//hull
187 }//union 187 }//union
188 188
189 // filament path 189 // filament path
190 place_idler() 190 place_idler()
191 translate([-idler_d/2-idler_filament_offset,0,0]) 191 translate([-idler_d/2-idler_filament_offset,0,0])
192 rotate([90,0,0]) { 192 rotate([90,0,0]) {
193 mirror([0,1,0]) 193 mirror([0,1,0])
194 teardrop(d=filament_path_d,h=3*gearbox_d,center=true); 194 teardrop(d=filament_path_d,h=3*gearbox_d,center=true);
195 translate([0,0, 195 translate([0,0,
196 sqrt(2)*(mount_d-pulley_d+lsd)/2 196 sqrt(2)*(mount_d-pulley_d+lsd)/2
197 ]) { 197 ]) {
198 cylinder(d1=filament_path_d,d2=2*filament_path_d, 198 cylinder(d1=filament_path_d,d2=2*filament_path_d,
199 h=filament_path_d,$fn=2*filament_path_d*fnd); 199 h=filament_path_d,$fn=2*filament_path_d*fnd);
200 translate([0,0,filament_path_d-epsilon]) 200 translate([0,0,filament_path_d-epsilon])
201 cylinder(d=2*filament_path_d,h=lsd*sqrt(2),$fn=2*filament_path_d*fnd); 201 cylinder(d=2*filament_path_d,h=lsd*sqrt(2),$fn=2*filament_path_d*fnd);
202 }//translate 202 }//translate
203 }//rotate translate place_idler 203 }//rotate translate place_idler
204 204
205 // idler space and mounting hole 205 // idler space and mounting hole
206 place_idler() { 206 place_idler() {
207 cylinder(d=idler_d+idler_clearance*2,h=idler_h+idler_v_tolerance,center=true,$fn=60); 207 cylinder(d=idler_d+idler_clearance*2,h=idler_h+idler_v_tolerance,center=true,$fn=60);
208 cylinder(d=idler_screw_d,h=lever_thickness+2,center=true,$fn=30); 208 cylinder(d=idler_screw_d,h=lever_thickness+2,center=true,$fn=30);
209 translate([0,0,lever_thickness/2-idler_screwhead_h]) 209 translate([0,0,lever_thickness/2-idler_screwhead_h])
210 cylinder(d=idler_screwhead_d,h=idler_screwhead_h+1,$fn=fnd*idler_screwhead_d); 210 cylinder(d=idler_screwhead_d,h=idler_screwhead_h+1,$fn=fnd*idler_screwhead_d);
211 } 211 }
212 // mounting screw hole 212 // mounting screw hole
213 translate([mount_d/2,0,0]) 213 translate([mount_d/2,0,0])
214 cylinder(d=mount_screw_d+mount_screw_d_tolerance,h=lever_thickness+2,center=true,$fn=fnd*mount_screw_d); 214 cylinder(d=mount_screw_d+mount_screw_d_tolerance,h=lever_thickness+2,center=true,$fn=fnd*mount_screw_d);
215 215
216 // lever end 216 // lever end
217 translate([mount_d/2,0,0]) rotate([0,90,0]) { 217 translate([mount_d/2,0,0]) rotate([0,90,0]) {
218 translate([0,-longwing,lsd/2]) finger_indent(d=lever_thickness-1,r=15); 218 translate([0,-longwing,lsd/2]) finger_indent(d=lever_thickness-1,r=15);
219 translate([0,-longwing,0]) 219 translate([0,-longwing,0])
220 mirror([0,0,1]) 220 mirror([0,0,1])
221 difference() { 221 difference() {
222 cylinder(d=spring_d+spring_d_clearance,h=lsd,$fn=fnd*(spring_d+spring_d_clearance)); 222 cylinder(d=spring_d+spring_d_clearance,h=lsd,$fn=fnd*(spring_d+spring_d_clearance));
223 sphere(d=spring_d*3/4,$fn=fnd*spring_d*3/4); 223 sphere(d=spring_d*3/4,$fn=fnd*spring_d*3/4);
224 } 224 }
225 }//rotate-translate 225 }//rotate-translate
226 }//difference 226 }//difference
227 // bridging patch 227 // bridging patch
228 if(bridges) place_idler() 228 if(bridges) place_idler()
229 translate([0,0,lever_thickness/2-mount_screwhead_h]) 229 translate([0,0,lever_thickness/2-mount_screwhead_h])
230 mirror([0,0,1]) 230 mirror([0,0,1])
231 cylinder(d=mount_screwhead_d,h=layer_height); 231 cylinder(d=mount_screwhead_d,h=layer_height);
232 }//translate 232 }//translate
233 }//lever module 233 }//lever module
234 234
235 module body() { 235 module body() {
236 difference() { 236 difference() {
237 union() { 237 union() {
238 cylinder(d=gearbox_d,h=body_h,$fn=fnd*gearbox_d); 238 cylinder(d=gearbox_d,h=body_h,$fn=fnd*gearbox_d);
239 // spring tensioner part 239 // spring tensioner part
240 translate([-gearbox_d/2,0,0]) hull() { 240 translate([-gearbox_d/2,0,0]) hull() {
241 translate([0,-longwing,ls_z]) 241 translate([0,-longwing,ls_z])
242 rotate([0,90,0]) 242 rotate([0,90,0])
243 cylinder(d=lever_thickness,h=fsw,$fn=fnd*lever_thickness); 243 cylinder(d=lever_thickness,h=fsw,$fn=fnd*lever_thickness);
244 hh=body_h-ls_z; 244 hh=body_h-ls_z;
245 translate([0,0,ls_z]) 245 translate([0,0,ls_z])
246 mirror([0,1,0]) cube(size=[fsw,longwing+(st_split_w+st_split_w_tolerance)/2+st_thickshell,body_h-ls_z]); 246 mirror([0,1,0]) cube(size=[fsw,longwing+(st_split_w+st_split_w_tolerance)/2+st_thickshell,body_h-ls_z]);
247 hhh=ls_z; 247 hhh=ls_z;
248 translate([0,0,0]) 248 translate([0,0,0])
249 mirror([0,1,0]) cube(size=[fsw,longwing-hhh+lever_thickness/sqrt(2),hhh+lever_thickness/2]); 249 mirror([0,1,0]) cube(size=[fsw,longwing-hhh+lever_thickness/sqrt(2),hhh+lever_thickness/2]);
250 }//hull translate 250 }//hull translate
251 251
252 // pushfit bracket 252 // pushfit bracket
253 translate([0,0,filament_elevation]) 253 translate([0,0,filament_elevation])
254 rotate([0,0,45]) translate([pulley_d/2+filament_offset,0,0]) 254 rotate([0,0,45]) translate([pulley_d/2+filament_offset,0,0])
255 rotate([-90,0,0]) 255 rotate([-90,0,0])
256 translate([0,0,mount_d/sqrt(2)/2+mount_screw_d-gearbox_d/2/*TODO:*/]) { 256 translate([0,0,mount_d/sqrt(2)/2+mount_screw_d-gearbox_d/2/*TODO:*/]) {
257 pfbl = pf_h(pf)+gearbox_d/2; //TODO: 257 pfbl = pf_h(pf)+gearbox_d/2; //TODO:
258 if(pf_smooth) { 258 if(pf_smooth) {
259 pfbd = pf_d(pf)+2*pf_shell; 259 pfbd = pf_d(pf)+2*pf_shell;
260 hull() { 260 hull() {
261 cylinder(d=pfbd,h=pfbl,$fn=pfbd*fnd); 261 cylinder(d=pfbd,h=pfbl,$fn=pfbd*fnd);
262 translate([-epsilon/2,0,0]) { 262 translate([-epsilon/2,0,0]) {
263 cube(size=[epsilon,filament_elevation,pfbl-filament_elevation+pfbd/2]); 263 cube(size=[epsilon,filament_elevation,pfbl-filament_elevation+pfbd/2]);
264 mirror([0,1,0]) 264 mirror([0,1,0])
265 cube(size=[epsilon,body_h-filament_elevation,pfbl-body_h+filament_elevation+pfbd/2]); 265 cube(size=[epsilon,body_h-filament_elevation,pfbl-body_h+filament_elevation+pfbd/2]);
266 }//translate 266 }//translate
267 }//hull 267 }//hull
268 }else{ 268 }else{
269 pfb2a = pf_d(pf)+2*pf_shell; pfba = pfb2a/2; 269 pfb2a = pf_d(pf)+2*pf_shell; pfba = pfb2a/2;
270 pfbd = pfb2a/cos(30); 270 pfbd = pfb2a/cos(30);
271 pfbs = pfb2a*tan(30); 271 pfbs = pfb2a*tan(30);
272 cylinder(d=pfbd,h=pfbl,$fn=6); 272 cylinder(d=pfbd,h=pfbl,$fn=6);
273 translate([-pfbs/2,0,0]) { 273 translate([-pfbs/2,0,0]) {
274 hull() { 274 hull() {
275 translate([0,-pfba,0]) cube(size=[pfbs,pfb2a,pfbl]); 275 translate([0,-pfba,0]) cube(size=[pfbs,pfb2a,pfbl]);
276 cube(size=[pfbs,filament_elevation,pfbl-filament_elevation+pfba]); 276 cube(size=[pfbs,filament_elevation,pfbl-filament_elevation+pfba]);
277 mirror([0,1,0]) 277 mirror([0,1,0])
278 cube(size=[pfbs,body_h-filament_elevation,pfbl-body_h+filament_elevation+pfba]); 278 cube(size=[pfbs,body_h-filament_elevation,pfbl-body_h+filament_elevation+pfba]);
279 }//hull 279 }//hull
280 }//translate*/ 280 }//translate*/
281 }//if(pf_smooth) 281 }//if(pf_smooth)
282 }//translate rotate translate rotate translate 282 }//translate rotate translate rotate translate
283 }//union (first child of difference) 283 }//union (first child of difference)
284 284
285 // protrusion 285 // protrusion
286 translate([0,0,-1]) 286 translate([0,0,-1])
287 cylinder(d=protrusion_d+protrusion_tolerance_h,h=protrusion_h+protrusion_tolerance_v+1,$fn=fnd*(protrusion_d+protrusion_tolerance_h)); 287 cylinder(d=protrusion_d+protrusion_tolerance_h,h=protrusion_h+protrusion_tolerance_v+1,$fn=fnd*(protrusion_d+protrusion_tolerance_h));
288 // mount screw holes 288 // mount screw holes
289 for(zr=[0:90:359]) rotate([0,0,zr]) translate([mount_d/2,0,0]) { 289 for(zr=[0:90:359]) rotate([0,0,zr]) translate([mount_d/2,0,0]) {
290 translate([0,0,mount_screw_l-mount_depth-(bridges?layer_height:-epsilon)]) 290 translate([0,0,mount_screw_l-mount_depth-(bridges?layer_height:-epsilon)])
291 mirror([0,0,1]) 291 mirror([0,0,1])
292 cylinder(d=mount_screw_d+mount_screw_d_tolerance, 292 cylinder(d=mount_screw_d+mount_screw_d_tolerance,
293 h=mount_screw_l-mount_depth+1, 293 h=mount_screw_l-mount_depth+1,
294 $fn=fnd*(mount_screw_d+mount_screw_d_tolerance)); 294 $fn=fnd*(mount_screw_d+mount_screw_d_tolerance));
295 translate([0,0,mount_screw_l-mount_depth]) 295 translate([0,0,mount_screw_l-mount_depth])
296 cylinder(d=mount_screwhead_d,h=body_h+1,$fn=fnd*mount_screwhead_d); 296 cylinder(d=mount_screwhead_d,h=body_h+1,$fn=fnd*mount_screwhead_d);
297 }//for 297 }//for
298 // pushfit 298 // pushfit
299 pf_offset = mount_d/sqrt(2)/2+mount_screw_d; 299 pf_offset = mount_d/sqrt(2)/2+mount_screw_d;
300 translate([0,0,filament_elevation]) 300 translate([0,0,filament_elevation])
301 rotate([0,0,45]) translate([pulley_d/2+filament_offset,0,0]) 301 rotate([0,0,45]) translate([pulley_d/2+filament_offset,0,0])
302 rotate([-90,0,0]) 302 rotate([-90,0,0])
303 translate([0,0,pf_offset]) 303 translate([0,0,pf_offset])
304 rotate([0,0,180]) { 304 rotate([0,0,180]) {
305 pushfit(pf); 305 pushfit(pf);
306 mirror([0,0,1]) { 306 mirror([0,0,1]) {
307 fh = 1.5* (filament_guide_d-filament_path_d)/2; 307 fh = 1.5* (filament_guide_d-filament_path_d)/2;
308 fo = pf_offset -filament_path_d /*(idler_d+idler_clearance)/2*/-fh; 308 fo = pf_offset -filament_path_d /*(idler_d+idler_clearance)/2*/-fh;
309 translate([0,0,-1]) teardrop(d=filament_guide_d,h=fo/2,angle=225); 309 translate([0,0,-1]) teardrop(d=filament_guide_d,h=fo/2,angle=225);
310 translate([0,0,-1]) teardrop(d=filament_path_d,h=gearbox_d/2+1,angle=-225); 310 translate([0,0,-1]) teardrop(d=filament_path_d,h=gearbox_d/2+1,angle=-225);
311 translate([0,0,fo+epsilon]) 311 translate([0,0,fo+epsilon])
312 cylinder(d1=filament_path_d,d2=filament_guide_d,h=fh,$fn=fnd*filament_guide_d); 312 cylinder(d1=filament_path_d,d2=filament_guide_d,h=fh,$fn=fnd*filament_guide_d);
313 }//mirror 313 }//mirror
314 }//rotate translate rotate translate rotate translate 314 }//rotate translate rotate translate rotate translate
315 // pulley 315 // pulley
316 cylinder(d=pulley_d+pulley_small_d_clearance,h=body_h+1,$fn=fnd*(pulley_d+pulley_d_clearance)); 316 cylinder(d=pulley_d+pulley_small_d_clearance,h=body_h+1,$fn=fnd*(pulley_d+pulley_d_clearance));
317 cylinder(d=pulley_d+pulley_d_clearance,ls_z-max(idler_h,filament_guide_d)/2,$fn=fnd*(pulley_d+pulley_d_clearance)); 317 cylinder(d=pulley_d+pulley_d_clearance,ls_z-max(idler_h,filament_guide_d)/2,$fn=fnd*(pulley_d+pulley_d_clearance));
318 318
319 translate([0,0,ls_z-ls_h/2]) { 319 translate([0,0,ls_z-ls_h/2]) {
320 // idler travel 320 // idler travel
321 translate([mount_d/2,0,0]) 321 translate([mount_d/2,0,0])
322 rotate([0,0,45]) 322 rotate([0,0,45])
323 rotate_extrude(angle=90,$fn=fnr*(shortwing+(idler_d+idler_clearance)/2)) 323 rotate_extrude(angle=90,$fn=fnr*(shortwing+(idler_d+idler_clearance)/2))
324 square([shortwing+(idler_d+idler_clearance)/2,ls_h]); 324 square([shortwing+(idler_d+idler_clearance)/2,ls_h]);
325 // idler itself 325 // idler itself
326 place_idler() 326 place_idler()
327 cylinder(d=idler_d+idler_clearance,h=ls_h,$fn=fnd*(idler_d+idler_clearance)); 327 cylinder(d=idler_d+idler_clearance,h=ls_h,$fn=fnd*(idler_d+idler_clearance));
328 // lever space 328 // lever space
329 rotate([0,0,45]) 329 rotate([0,0,45])
330 rotate_extrude(angle=-135+max(atan(2*fsw/gearbox_d-1),atan(gearbox_d/mount_d-1))) 330 rotate_extrude(angle=-135+max(atan(2*fsw/gearbox_d-1),atan(gearbox_d/mount_d-1)))
331 square([gearbox_d/2+1,ls_h]); 331 square([gearbox_d/2+1,ls_h]);
332 } 332 }
333 333
334 // back side cutout 334 // back side cutout
335 // XXX: this is somewhat ugly and potentially bugged, 335 // XXX: this is somewhat ugly and potentially bugged,
336 // but I want to sleep. 336 // but I want to sleep.
337 a0_ = atan( 337 a0_ = atan(
338 (mount_d/sqrt(2)/2+mount_screw_d+pf_h(pf)+gearbox_d/2) 338 (mount_d/sqrt(2)/2+mount_screw_d+pf_h(pf)+gearbox_d/2)
339 / 339 /
340 ( 340 (
341 pulley_d/2+filament_offset- 341 pulley_d/2+filament_offset-
342 (pf_d(pf)+2*pf_shell)/2/cos(30) 342 (pf_d(pf)+2*pf_shell)/2/cos(30)
343 ) 343 )
344 ); 344 );
345 a0 = -135 + ( (a0_>0) ? a0_ : 180+a0_ ); 345 a0 = -135 + ( (a0_>0) ? a0_ : 180+a0_ );
346 a1 = atan((longwing-lever_thickness/2)/(gearbox_d/2)); 346 a1 = atan((longwing-lever_thickness/2)/(gearbox_d/2));
347 translate([0,0,ls_z]) difference() { 347 translate([0,0,ls_z]) difference() {
348 rotate([0,0,-180+a0]) 348 rotate([0,0,-180+a0])
349 rotate_extrude(angle=a1-a0) 349 rotate_extrude(angle=a1-a0)
350 translate([0,-ls_h/2]) 350 translate([0,-ls_h/2])
351 square([sqrt(pow(gearbox_d/2,2)+pow(longwing-lever_thickness/2,2))+1, 351 square([sqrt(pow(gearbox_d/2,2)+pow(longwing-lever_thickness/2,2))+1,
352 ls_h]); 352 ls_h]);
353 translate([-mount_d/2,0,0]) 353 translate([-mount_d/2,0,0])
354 cylinder(d=gearbox_d-mount_d,h=ls_h+2,center=true,$fn=fnd*(gearbox_d-mount_d)); 354 cylinder(d=gearbox_d-mount_d,h=ls_h+2,center=true,$fn=fnd*(gearbox_d-mount_d));
355 }//difference translate 355 }//difference translate
356 356
357 // spring tensioner 357 // spring tensioner
358 translate([-gearbox_d/2,-longwing,ls_z]) rotate([0,-90,0]) { 358 translate([-gearbox_d/2,-longwing,ls_z]) rotate([0,-90,0]) {
359 mirror([0,0,1]) { 359 mirror([0,0,1]) {
360 translate([0,0,st_thickshell]) 360 translate([0,0,st_thickshell])
361 hull() for(o=[0,spring_d]) translate([0,-o,0]) 361 hull() for(o=[0,spring_d]) translate([0,-o,0])
362 rotate([0,0,30]) 362 rotate([0,0,30])
363 cylinder(d=st_nut_d+st_nut_d_tolerance,h=st_nut_h+st_nut_h_tolerance,$fn=6); 363 cylinder(d=st_nut_d+st_nut_d_tolerance,h=st_nut_h+st_nut_h_tolerance,$fn=6);
364 translate([0,0,-1]) cylinder(d=st_screw_d+st_screw_d_tolerance,h=fsw+2,$fn=fnd*(st_screw_d+st_screw_d_tolerance)); 364 translate([0,0,-1]) cylinder(d=st_screw_d+st_screw_d_tolerance,h=fsw+2,$fn=fnd*(st_screw_d+st_screw_d_tolerance));
365 bigd = spring_d+spring_d_clearance; 365 bigd = spring_d+spring_d_clearance;
366 hf = (bigd-st_screw_d-st_screw_d_tolerance)/2; 366 hf = (bigd-st_screw_d-st_screw_d_tolerance)/2;
367 translate([0,0,st_thickshell+st_nut_h+st_nut_h_tolerance+st_thinshell-epsilon]) { 367 translate([0,0,st_thickshell+st_nut_h+st_nut_h_tolerance+st_thinshell-epsilon]) {
368 cylinder(d1=st_screw_d+st_screw_d_tolerance,d2=bigd, 368 cylinder(d1=st_screw_d+st_screw_d_tolerance,d2=bigd,
369 h=hf+epsilon, $fn=fnd*bigd); 369 h=hf+epsilon, $fn=fnd*bigd);
370 translate([0,-(st_split_w+st_split_w_tolerance)/2,0]) 370 translate([0,-(st_split_w+st_split_w_tolerance)/2,0])
371 cube(size=[body_h-ls_z+1,st_split_w+st_split_w_tolerance,fsw+1]); 371 cube(size=[body_h-ls_z+1,st_split_w+st_split_w_tolerance,fsw+1]);
372 }//translate 372 }//translate
373 translate([0,0,st_thickshell+st_nut_h+st_nut_h_tolerance+st_thinshell+hf-epsilon]) 373 translate([0,0,st_thickshell+st_nut_h+st_nut_h_tolerance+st_thinshell+hf-epsilon])
374 cylinder(d=bigd,h=fsw+1,$fn=fnd*bigd); 374 cylinder(d=bigd,h=fsw+1,$fn=fnd*bigd);
375 }//mirror 375 }//mirror
376 }//translate 376 }//translate
377 377
378 // label 378 // label
379 label_thickness = 2*layer_height; 379 label_thickness = 2*layer_height;
380 label_len = len(label); 380 label_len = len(label);
381 if(label_len) { 381 if(label_len) {
382 labelspace = [gearbox_d/2-mount_screwhead_d/2-min_xy_shell,longwing-(mount_screwhead_d-st_split_w-st_split_w_tolerance)/2-2*min_xy_shell]; 382 labelspace = [gearbox_d/2-mount_screwhead_d/2-min_xy_shell,longwing-(mount_screwhead_d-st_split_w-st_split_w_tolerance)/2-2*min_xy_shell];
383 translate([0,0,body_h-label_thickness]) 383 translate([0,0,body_h-label_thickness])
384 linear_extrude(height=label_thickness+epsilon,convexity=64) 384 linear_extrude(height=label_thickness+epsilon,convexity=64)
385 translate([-mount_screwhead_d/2-min_xy_shell-labelspace.x/2,-longwing+(st_split_w+st_split_w_tolerance)/2+min_xy_shell+labelspace.y/2]) 385 translate([-mount_screwhead_d/2-min_xy_shell-labelspace.x/2,-longwing+(st_split_w+st_split_w_tolerance)/2+min_xy_shell+labelspace.y/2])
386 mirror([left?0:1,0]) 386 mirror([left?0:1,0])
387 text(text=label,size=labelspace.x/label_len,halign="center",valign="center",font="Arial Black"); 387 text(text=label,size=labelspace.x/label_len,halign="center",valign="center",font="Arial Black");
388 }//if(label_len) 388 }//if(label_len)
389 389
390 }//difference 390 }//difference
391 391
392 }//body module 392 }//body module
393 393
394 module springpad() { 394 module springpad() {
395 smalld=st_screw_d+st_screw_d_tolerance+min_xy_shell; 395 smalld=st_screw_d+st_screw_d_tolerance+min_xy_shell;
396 bigd = spring_d+spring_d_clearance/2; 396 bigd = spring_d+spring_d_clearance/2;
397 hf = (bigd-smalld)/2; 397 hf = (bigd-smalld)/2;
398 h = hf*3.5; 398 h = hf*3.5;
399 translate([-gearbox_d/2+st_thickshell+st_nut_h+st_nut_h_tolerance+st_thinshell+1,-longwing,filament_elevation]) 399 translate([-gearbox_d/2+st_thickshell+st_nut_h+st_nut_h_tolerance+st_thinshell+1,-longwing,filament_elevation])
400 rotate([0,90,0]) difference() { 400 rotate([0,90,0]) difference() {
401 union() { 401 union() {
402 cylinder(d1=smalld,d2=bigd,h=hf,$fn=fnd*bigd); 402 cylinder(d1=smalld,d2=bigd,h=hf,$fn=fnd*bigd);
403 translate([0,0,hf-epsilon]) 403 translate([0,0,hf-epsilon])
404 cylinder(d=bigd,h=h-hf,$fn=fnd*bigd); 404 cylinder(d=bigd,h=h-hf,$fn=fnd*bigd);
405 translate([0,0,h]) 405 translate([0,0,h])
406 sphere(d=spring_d*3/4,$fn=fnd*spring_d*3/4); 406 sphere(d=spring_d*3/4,$fn=fnd*spring_d*3/4);
407 l = body_h-ls_z; 407 l = body_h-ls_z;
408 w = st_split_w; 408 w = st_split_w;
409 hull() translate([0,-st_split_w/2,0]) mirror([1,0,0]) { 409 hull() translate([0,-st_split_w/2,0]) mirror([1,0,0]) {
410 translate([0,0,w]) 410 translate([0,0,w])
411 cube(size=[l,st_split_w,w]); 411 cube(size=[l,st_split_w,w]);
412 cube(size=[l-w,st_split_w,2*w]); 412 cube(size=[l-w,st_split_w,2*w]);
413 } 413 }
414 } 414 }
415 translate([0,0,-epsilon]) 415 translate([0,0,-epsilon])
416 cylinder(d=st_screw_d+st_screw_d_tolerance,h=2*hf+epsilon,$fn=fnd*(st_screw_d+st_screw_d_tolerance)); 416 cylinder(d=st_screw_d+st_screw_d_tolerance,h=2*hf+epsilon,$fn=fnd*(st_screw_d+st_screw_d_tolerance));
417 } 417 }
418 } 418 }
419 419
420 module knob() { 420 module knob() {
421 ch = knob_indent_d/2; 421 ch = knob_indent_d/2;
422 translate([0,0,body_h+epsilon]) { 422 translate([0,0,body_h+epsilon]) {
423 mirror([0,0,1]) translate([0,0,-epsilon]) { 423 mirror([0,0,1]) translate([0,0,-epsilon]) {
424 difference() { 424 difference() {
425 cylinder(d=pulley_d,h=knob_bore_l,$fn=fnd*pulley_d); 425 cylinder(d=pulley_d,h=knob_bore_l,$fn=fnd*pulley_d);
426 translate([0,0,-1]) difference() { 426 translate([0,0,-1]) difference() {
427 cylinder(d=bore_d+knob_bore_d_tolerance,h=knob_bore_l+2); 427 cylinder(d=bore_d+knob_bore_d_tolerance,h=knob_bore_l+2);
428 translate([-bore_d/2-1,bore_dd-bore_d/2+knob_bore_d_tolerance/2,-1]) 428 translate([-bore_d/2-1,bore_dd-bore_d/2+knob_bore_d_tolerance/2,-1])
429 cube([bore_d+2,bore_d/2,knob_bore_l+4]); 429 cube([bore_d+2,bore_d/2,knob_bore_l+4]);
430 } 430 }
431 } 431 }
432 } 432 }
433 difference() { 433 difference() {
434 union() { 434 union() {
435 cylinder(d1=gearbox_d-2*ch,d2=gearbox_d,h=ch+epsilon,$fn=fnd*gearbox_d); 435 cylinder(d1=gearbox_d-2*ch,d2=gearbox_d,h=ch+epsilon,$fn=fnd*gearbox_d);
436 translate([0,0,ch]) 436 translate([0,0,ch])
437 cylinder(d=gearbox_d,h=knob_h-2*ch+epsilon,$fn=fnd*gearbox_d); 437 cylinder(d=gearbox_d,h=knob_h-2*ch+epsilon,$fn=fnd*gearbox_d);
438 translate([0,0,knob_h-ch]) 438 translate([0,0,knob_h-ch])