author | Michael Krelin <hacker@klever.net> | 2018-08-02 19:29:40 (UTC) |
---|---|---|
committer | Michael Krelin <hacker@klever.net> | 2018-08-02 19:29:40 (UTC) |
commit | 7fe5273a70a70beeba8ff622a7af1e2cfdf1a28f (patch) (unidiff) | |
tree | 290a2328fd74cadd18e09c90e7afbc6a32556364 | |
parent | 8dd86c90ff31dca9cf4ce5260e199bf1d38a359a (diff) | |
download | extrudery-7fe5273a70a70beeba8ff622a7af1e2cfdf1a28f.zip extrudery-7fe5273a70a70beeba8ff622a7af1e2cfdf1a28f.tar.gz extrudery-7fe5273a70a70beeba8ff622a7af1e2cfdf1a28f.tar.bz2 |
cutout on the back side
in the unfortunate event of filament grinding it may serve as an
escape way for filament powder
-rw-r--r-- | another.scad | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/another.scad b/another.scad index 4af7d29..38a9aae 100644 --- a/another.scad +++ b/another.scad | |||
@@ -152,230 +152,243 @@ module the_extruder( | |||
152 | 152 | ||
153 | // idler space and mounting hole | 153 | // idler space and mounting hole |
154 | place_idler() { | 154 | place_idler() { |
155 | difference() { | 155 | difference() { |
156 | cylinder(d=idler_d+idler_clearance*2,h=idler_h+idler_v_tolerance,center=true,$fn=60); | 156 | cylinder(d=idler_d+idler_clearance*2,h=idler_h+idler_v_tolerance,center=true,$fn=60); |
157 | if(supports) for(y=[-lsd/2+extrusion_width:(lsd-2*extrusion_width)/3:lsd/2-extrusion_width]) | 157 | if(supports) for(y=[-lsd/2+extrusion_width:(lsd-2*extrusion_width)/3:lsd/2-extrusion_width]) |
158 | translate([-lsd/2-1,y-extrusion_width/2,-idler_h/2-idler_v_tolerance/2-1]) | 158 | translate([-lsd/2-1,y-extrusion_width/2,-idler_h/2-idler_v_tolerance/2-1]) |
159 | cube(size=[lsd+2,extrusion_width,idler_h+idler_v_tolerance+2]); | 159 | cube(size=[lsd+2,extrusion_width,idler_h+idler_v_tolerance+2]); |
160 | } | 160 | } |
161 | cylinder(d=mount_screw_d+mount_screw_d_tolerance,h=lever_thickness+2,center=true,$fn=30); | 161 | cylinder(d=mount_screw_d+mount_screw_d_tolerance,h=lever_thickness+2,center=true,$fn=30); |
162 | translate([0,0,lever_thickness/2-mount_screwhead_h]) | 162 | translate([0,0,lever_thickness/2-mount_screwhead_h]) |
163 | cylinder(d=mount_screwhead_d,h=mount_screwhead_h+1,$fn=fnd*mount_screwhead_d); | 163 | cylinder(d=mount_screwhead_d,h=mount_screwhead_h+1,$fn=fnd*mount_screwhead_d); |
164 | } | 164 | } |
165 | // mounting screw hole | 165 | // mounting screw hole |
166 | translate([mount_d/2,0,0]) | 166 | translate([mount_d/2,0,0]) |
167 | cylinder(d=mount_screw_d+mount_screw_d_tolerance,h=lever_thickness+2,center=true,$fn=fnd*mount_screw_d); | 167 | cylinder(d=mount_screw_d+mount_screw_d_tolerance,h=lever_thickness+2,center=true,$fn=fnd*mount_screw_d); |
168 | 168 | ||
169 | // lever end | 169 | // lever end |
170 | translate([mount_d/2,0,0]) rotate([0,90,0]) { | 170 | translate([mount_d/2,0,0]) rotate([0,90,0]) { |
171 | translate([0,-longwing,lsd/2]) finger_indent(d=lever_thickness-1,r=15); | 171 | translate([0,-longwing,lsd/2]) finger_indent(d=lever_thickness-1,r=15); |
172 | translate([0,-longwing,0]) | 172 | translate([0,-longwing,0]) |
173 | mirror([0,0,1]) | 173 | mirror([0,0,1]) |
174 | difference() { | 174 | difference() { |
175 | cylinder(d=spring_d+spring_d_clearance,h=lsd,$fn=fnd*(spring_d+spring_d_clearance)); | 175 | cylinder(d=spring_d+spring_d_clearance,h=lsd,$fn=fnd*(spring_d+spring_d_clearance)); |
176 | sphere(d=spring_d*3/4,$fn=fnd*spring_d*3/4); | 176 | sphere(d=spring_d*3/4,$fn=fnd*spring_d*3/4); |
177 | } | 177 | } |
178 | }//rotate-translate | 178 | }//rotate-translate |
179 | }//difference | 179 | }//difference |
180 | // bridging patch | 180 | // bridging patch |
181 | place_idler() | 181 | place_idler() |
182 | translate([0,0,lever_thickness/2-mount_screwhead_h]) | 182 | translate([0,0,lever_thickness/2-mount_screwhead_h]) |
183 | mirror([0,0,1]) | 183 | mirror([0,0,1]) |
184 | cylinder(d=mount_screwhead_d,h=layer_height); | 184 | cylinder(d=mount_screwhead_d,h=layer_height); |
185 | }//translate | 185 | }//translate |
186 | }//lever module | 186 | }//lever module |
187 | 187 | ||
188 | module body() { | 188 | module body() { |
189 | difference() { | 189 | difference() { |
190 | union() { | 190 | union() { |
191 | cylinder(d=gearbox_d,h=body_h,$fn=fnd*gearbox_d); | 191 | cylinder(d=gearbox_d,h=body_h,$fn=fnd*gearbox_d); |
192 | // finger and spring support | 192 | // finger and spring support |
193 | fsw = gearbox_d-(gearbox_d-mount_d)/2-spring_lc; | 193 | fsw = gearbox_d-(gearbox_d-mount_d)/2-spring_lc; |
194 | translate([-gearbox_d/2,0,0]) difference() { | 194 | translate([-gearbox_d/2,0,0]) difference() { |
195 | union() { | 195 | union() { |
196 | hull() { | 196 | hull() { |
197 | translate([0,-longwing,ls_z]) | 197 | translate([0,-longwing,ls_z]) |
198 | rotate([0,90,0]) | 198 | rotate([0,90,0]) |
199 | cylinder(d=lever_thickness,h=fsw,$fn=fnd*lever_thickness); | 199 | cylinder(d=lever_thickness,h=fsw,$fn=fnd*lever_thickness); |
200 | hh=body_h-ls_z; | 200 | hh=body_h-ls_z; |
201 | translate([0,0,ls_z-lever_thickness/2]) | 201 | translate([0,0,ls_z-lever_thickness/2]) |
202 | mirror([0,1,0]) cube(size=[fsw,longwing-hh+lever_thickness/sqrt(2),hh+lever_thickness/2]); | 202 | mirror([0,1,0]) cube(size=[fsw,longwing-hh+lever_thickness/sqrt(2),hh+lever_thickness/2]); |
203 | hhh=ls_z; | 203 | hhh=ls_z; |
204 | translate([0,0,0]) | 204 | translate([0,0,0]) |
205 | mirror([0,1,0]) cube(size=[fsw,longwing-hhh+lever_thickness/sqrt(2),hhh+lever_thickness/2]); | 205 | mirror([0,1,0]) cube(size=[fsw,longwing-hhh+lever_thickness/sqrt(2),hhh+lever_thickness/2]); |
206 | } | 206 | } |
207 | } | 207 | } |
208 | translate([0,-longwing,ls_z]) rotate([0,-90,0]) { | 208 | translate([0,-longwing,ls_z]) rotate([0,-90,0]) { |
209 | if(!tensioner) finger_indent(d=lever_thickness-1,r=15); else { | 209 | if(!tensioner) finger_indent(d=lever_thickness-1,r=15); else { |
210 | if(debug) translate([0,-lever_thickness/2-1,-gearbox_d]) cube(size=[body_h/2+1,lever_thickness/2+1,gearbox_d+2]); | 210 | if(debug) translate([0,-lever_thickness/2-1,-gearbox_d]) cube(size=[body_h/2+1,lever_thickness/2+1,gearbox_d+2]); |
211 | mirror([0,0,1]) { | 211 | mirror([0,0,1]) { |
212 | translate([0,0,st_shell]) | 212 | translate([0,0,st_shell]) |
213 | hull() for(o=[0,spring_d]) translate([0,-o,0]) | 213 | hull() for(o=[0,spring_d]) translate([0,-o,0]) |
214 | rotate([0,0,30]) | 214 | rotate([0,0,30]) |
215 | cylinder(d=st_nut_d,h=st_nut_h,$fn=6); | 215 | cylinder(d=st_nut_d,h=st_nut_h,$fn=6); |
216 | translate([0,0,-1]) cylinder(d=st_screw_d,h=fsw+2,$fn=fnd*st_screw_d); | 216 | translate([0,0,-1]) cylinder(d=st_screw_d,h=fsw+2,$fn=fnd*st_screw_d); |
217 | bigd = spring_d+spring_d_clearance; | 217 | bigd = spring_d+spring_d_clearance; |
218 | hf = (bigd-st_screw_d)/2; | 218 | hf = (bigd-st_screw_d)/2; |
219 | translate([0,0,st_shell+st_nut_h+st_shell-epsilon]) | 219 | translate([0,0,st_shell+st_nut_h+st_shell-epsilon]) |
220 | cylinder(d1=st_screw_d,d2=bigd, | 220 | cylinder(d1=st_screw_d,d2=bigd, |
221 | h=hf+epsilon, $fn=fnd*bigd); | 221 | h=hf+epsilon, $fn=fnd*bigd); |
222 | translate([0,0,st_shell+st_nut_h+st_shell+hf-epsilon]) | 222 | translate([0,0,st_shell+st_nut_h+st_shell+hf-epsilon]) |
223 | cylinder(d=bigd,h=fsw+1,$fn=fnd*bigd); | 223 | cylinder(d=bigd,h=fsw+1,$fn=fnd*bigd); |
224 | } | 224 | } |
225 | } | 225 | } |
226 | } | 226 | } |
227 | } // translate | 227 | } // translate |
228 | 228 | ||
229 | // pushfit bracket | 229 | // pushfit bracket |
230 | translate([0,0,filament_elevation]) | 230 | translate([0,0,filament_elevation]) |
231 | rotate([0,0,45]) translate([pulley_d/2,0,0]) | 231 | rotate([0,0,45]) translate([pulley_d/2,0,0]) |
232 | rotate([-90,0,0]) | 232 | rotate([-90,0,0]) |
233 | translate([0,0,mount_d/sqrt(2)/2+mount_screw_d-gearbox_d/2/*TODO:*/]) | 233 | translate([0,0,mount_d/sqrt(2)/2+mount_screw_d-gearbox_d/2/*TODO:*/]) |
234 | cylinder(r=min(body_h-filament_elevation,filament_elevation)/sin(60)-epsilon,h=pf_h(pf)+gearbox_d/2/*TODO:*/,$fn=6); | 234 | cylinder(r=min(body_h-filament_elevation,filament_elevation)/sin(60)-epsilon,h=pf_h(pf)+gearbox_d/2/*TODO:*/,$fn=6); |
235 | }//union (first child of difference) | 235 | }//union (first child of difference) |
236 | 236 | ||
237 | // protrusion | 237 | // protrusion |
238 | translate([0,0,-1]) | 238 | translate([0,0,-1]) |
239 | cylinder(d=protrusion_d+protrusion_tolerance_h,h=protrusion_h+protrusion_tolerance_v+1,$fn=fnd*(protrusion_d+protrusion_tolerance_h)); | 239 | cylinder(d=protrusion_d+protrusion_tolerance_h,h=protrusion_h+protrusion_tolerance_v+1,$fn=fnd*(protrusion_d+protrusion_tolerance_h)); |
240 | // mount screw holes | 240 | // mount screw holes |
241 | for(zr=[0:90:359]) rotate([0,0,zr]) translate([mount_d/2,0,0]) { | 241 | for(zr=[0:90:359]) rotate([0,0,zr]) translate([mount_d/2,0,0]) { |
242 | translate([0,0,mount_screw_l-mounthole_depth/2-layer_height-1]) | 242 | translate([0,0,mount_screw_l-mounthole_depth/2-layer_height-1]) |
243 | mirror([0,0,1]) | 243 | mirror([0,0,1]) |
244 | cylinder(d=mount_screw_d+mount_screw_d_tolerance, | 244 | cylinder(d=mount_screw_d+mount_screw_d_tolerance, |
245 | h=mount_screw_l-mounthole_depth/2-layer_height+1, | 245 | h=mount_screw_l-mounthole_depth/2-layer_height+1, |
246 | $fn=fnd*(mount_screw_d+mount_screw_d_tolerance)); | 246 | $fn=fnd*(mount_screw_d+mount_screw_d_tolerance)); |
247 | translate([0,0,mount_screw_l-mounthole_depth/2]) | 247 | translate([0,0,mount_screw_l-mounthole_depth/2]) |
248 | cylinder(d=mount_screwhead_d,h=body_h+1,$fn=fnd*mount_screwhead_d); | 248 | cylinder(d=mount_screwhead_d,h=body_h+1,$fn=fnd*mount_screwhead_d); |
249 | }//for | 249 | }//for |
250 | // pushfit | 250 | // pushfit |
251 | translate([0,0,filament_elevation]) | 251 | translate([0,0,filament_elevation]) |
252 | rotate([0,0,45]) translate([pulley_d/2,0,0]) | 252 | rotate([0,0,45]) translate([pulley_d/2,0,0]) |
253 | rotate([-90,0,0]) | 253 | rotate([-90,0,0]) |
254 | translate([0,0,mount_d/sqrt(2)/2+mount_screw_d+epsilon]) | 254 | translate([0,0,mount_d/sqrt(2)/2+mount_screw_d+epsilon]) |
255 | rotate([0,0,180]) { | 255 | rotate([0,0,180]) { |
256 | pushfit(pf); | 256 | pushfit(pf); |
257 | cylinder(d=filament_guide_d,h=gearbox_d,center=true,$fn=fnd*filament_guide_d); | 257 | cylinder(d=filament_guide_d,h=gearbox_d,center=true,$fn=fnd*filament_guide_d); |
258 | translate([0,-filament_guide_d/2/sqrt(2),0]) | 258 | translate([0,-filament_guide_d/2/sqrt(2),0]) |
259 | rotate([0,0,45]) | 259 | rotate([0,0,45]) |
260 | cube(size=[filament_guide_d/2,filament_guide_d/2,gearbox_d],center=true); | 260 | cube(size=[filament_guide_d/2,filament_guide_d/2,gearbox_d],center=true); |
261 | }//rotate translate rotate translate rotate translate | 261 | }//rotate translate rotate translate rotate translate |
262 | // pulley | 262 | // pulley |
263 | cylinder(d=pulley_d+pulley_clearance,h=body_h+1,$fn=fnd*(pulley_d+pulley_clearance)); | 263 | cylinder(d=pulley_d+pulley_clearance,h=body_h+1,$fn=fnd*(pulley_d+pulley_clearance)); |
264 | // leverspace | 264 | // leverspace |
265 | hull() for(x=[0,gearbox_d]) | 265 | hull() for(x=[0,gearbox_d]) |
266 | rotate([0,0,45]) | 266 | rotate([0,0,45]) |
267 | translate([x,0,ls_z-ls_h/2]) | 267 | translate([x,0,ls_z-ls_h/2]) |
268 | cylinder(d=idler_d+idler_clearance,h=ls_h,$fn=fnd*(idler_d+idler_clearance)); | 268 | cylinder(d=idler_d+idler_clearance,h=ls_h,$fn=fnd*(idler_d+idler_clearance)); |
269 | 269 | ||
270 | // idler clearance | 270 | // idler clearance |
271 | a=cos(45)*(pulley_d+idler_d)/2; | 271 | a=cos(45)*(pulley_d+idler_d)/2; |
272 | b=mount_d/2-a; | 272 | b=mount_d/2-a; |
273 | x=sqrt(pow(a,2)+pow(b,2)); | 273 | x=sqrt(pow(a,2)+pow(b,2)); |
274 | translate([mount_d/2,0,ls_z]) | 274 | translate([mount_d/2,0,ls_z]) |
275 | intersection() { | 275 | intersection() { |
276 | r = x+idler_d/2+idler_clearance; | 276 | r = x+idler_d/2+idler_clearance; |
277 | cylinder(r=r,h=ls_h,center=true); | 277 | cylinder(r=r,h=ls_h,center=true); |
278 | translate([-r-1,0,-ls_h/2-1]) cube(size=[2*r+2,r+1,ls_h+2]); | 278 | translate([-r-1,0,-ls_h/2-1]) cube(size=[2*r+2,r+1,ls_h+2]); |
279 | } | 279 | } |
280 | |||
281 | // back side cutout | ||
282 | a0 = asin((mount_screwhead_d+2*extrusion_width)/mount_d); | ||
283 | a1 = atan((longwing-lever_thickness/2)/(gearbox_d/2)); | ||
284 | translate([0,0,ls_z]) hull() { | ||
285 | rotate([0,0,-180+a0]) | ||
286 | rotate_extrude(angle=a1-a0) | ||
287 | translate([0,-ls_h/2]) | ||
288 | square([sqrt(pow(gearbox_d/2,2)+pow(longwing-lever_thickness/2,2))+1, | ||
289 | ls_h]); | ||
290 | cylinder(d=bore_d/2/*TODO:recalculate angles based on this, | ||
291 | too lazy to do that now*/, | ||
292 | h=ls_h,center=true); | ||
280 | } | 293 | } |
281 | 294 | ||
282 | rotate([0,0,-45]) | 295 | rotate([0,0,-45]) |
283 | translate([0,0,ls_z-ls_h/2]) | 296 | translate([0,0,ls_z-ls_h/2]) |
284 | cube(size=[gearbox_d,gearbox_d,lever_thickness+lever_v_clearance]); | 297 | cube(size=[gearbox_d,gearbox_d,lever_thickness+lever_v_clearance]); |
285 | translate([0,0,ls_z-ls_h/2]) { | 298 | translate([0,0,ls_z-ls_h/2]) { |
286 | translate([mount_screwhead_d/2,0,0]) | 299 | translate([mount_screwhead_d/2,0,0]) |
287 | mirror([0,1,0]) | 300 | mirror([0,1,0]) |
288 | cube(size=[gearbox_d,gearbox_d/2+1,lever_thickness+lever_v_clearance]); | 301 | cube(size=[gearbox_d,gearbox_d/2+1,lever_thickness+lever_v_clearance]); |
289 | } | 302 | } |
290 | //translate([-mount_d/2,-longwing,filament_elevation]) | 303 | //translate([-mount_d/2,-longwing,filament_elevation]) |
291 | if(!tensioner) /* XXX: this seems to be bullshit, but it's so old, that it's historical bullshit */ | 304 | if(!tensioner) /* XXX: this seems to be bullshit, but it's so old, that it's historical bullshit */ |
292 | translate([mount_d/2,-longwing,filament_elevation]) | 305 | translate([mount_d/2,-longwing,filament_elevation]) |
293 | rotate([0,-90,0]) difference() { | 306 | rotate([0,-90,0]) difference() { |
294 | cylinder(d=spring_d+spring_d_clearance,h=spring_lc+spring_dl,$fn=fnd*(spring_d+spring_d_clearance)); | 307 | cylinder(d=spring_d+spring_d_clearance,h=spring_lc+spring_dl,$fn=fnd*(spring_d+spring_d_clearance)); |
295 | translate([0,0,spring_lc+spring_dl]) sphere(d=spring_d*3/4,$fn=fnd*spring_d*3/4); | 308 | translate([0,0,spring_lc+spring_dl]) sphere(d=spring_d*3/4,$fn=fnd*spring_d*3/4); |
296 | } | 309 | } |
297 | 310 | ||
298 | }//difference | 311 | }//difference |
299 | 312 | ||
300 | if(supports) intersection() { | 313 | if(supports) intersection() { |
301 | difference() { | 314 | difference() { |
302 | translate([0,0,ls_z-ls_h/2-epsilon]) | 315 | translate([0,0,ls_z-ls_h/2-epsilon]) |
303 | cylinder(d=gearbox_d,h=ls_h+2*epsilon,$fn=fnd*gearbox_d); | 316 | cylinder(d=gearbox_d,h=ls_h+2*epsilon,$fn=fnd*gearbox_d); |
304 | cylinder(d=pulley_d+pulley_clearance,h=body_h+1,$fn=fnd*(pulley_d+pulley_clearance)); | 317 | cylinder(d=pulley_d+pulley_clearance,h=body_h+1,$fn=fnd*(pulley_d+pulley_clearance)); |
305 | } | 318 | } |
306 | // supports | 319 | // supports |
307 | // TODO: hardcoded stuff below… | 320 | // TODO: hardcoded stuff below… |
308 | if(false) { // parallel | 321 | if(false) { // parallel |
309 | for(y=[-gearbox_d:4:gearbox_d]) | 322 | for(y=[-gearbox_d:4:gearbox_d]) |
310 | translate([0,y-extrusion_width/2,0]) | 323 | translate([0,y-extrusion_width/2,0]) |
311 | cube(size=[gearbox_d,extrusion_width,body_h]); | 324 | cube(size=[gearbox_d,extrusion_width,body_h]); |
312 | }else{ // radial | 325 | }else{ // radial |
313 | for(zr=[-65:(65+50)/7:50]) | 326 | for(zr=[-65:(65+50)/7:50]) |
314 | rotate([0,0,zr]) translate([0,-extrusion_width/2,0]) | 327 | rotate([0,0,zr]) translate([0,-extrusion_width/2,0]) |
315 | cube(size=[gearbox_d,extrusion_width,body_h]); | 328 | cube(size=[gearbox_d,extrusion_width,body_h]); |
316 | } | 329 | } |
317 | } | 330 | } |
318 | 331 | ||
319 | }//body module | 332 | }//body module |
320 | 333 | ||
321 | module springpad() { | 334 | module springpad() { |
322 | smalld=st_screw_d+2*extrusion_width; | 335 | smalld=st_screw_d+2*extrusion_width; |
323 | bigd = spring_d+spring_d_clearance/2; | 336 | bigd = spring_d+spring_d_clearance/2; |
324 | hf = (bigd-smalld)/2; | 337 | hf = (bigd-smalld)/2; |
325 | translate([-gearbox_d/2+st_shell+st_nut_h+st_shell+smalld,-longwing,filament_elevation]) | 338 | translate([-gearbox_d/2+st_shell+st_nut_h+st_shell+smalld,-longwing,filament_elevation]) |
326 | rotate([0,90,0]) difference() { | 339 | rotate([0,90,0]) difference() { |
327 | union() { | 340 | union() { |
328 | cylinder(d1=smalld,d2=bigd,h=hf,$fn=fnd*bigd); | 341 | cylinder(d1=smalld,d2=bigd,h=hf,$fn=fnd*bigd); |
329 | translate([0,0,hf-epsilon]) | 342 | translate([0,0,hf-epsilon]) |
330 | cylinder(d=bigd,h=hf*2,$fn=fnd*bigd); | 343 | cylinder(d=bigd,h=hf*2,$fn=fnd*bigd); |
331 | } | 344 | } |
332 | translate([0,0,-epsilon]) | 345 | translate([0,0,-epsilon]) |
333 | cylinder(d=st_screw_d,h=2*hf+epsilon,$fn=fnd*st_screw_d); | 346 | cylinder(d=st_screw_d,h=2*hf+epsilon,$fn=fnd*st_screw_d); |
334 | } | 347 | } |
335 | } | 348 | } |
336 | 349 | ||
337 | module knob() { | 350 | module knob() { |
338 | ch = knob_indent_d/2; | 351 | ch = knob_indent_d/2; |
339 | translate([0,0,body_h+epsilon]) { | 352 | translate([0,0,body_h+epsilon]) { |
340 | mirror([0,0,1]) translate([0,0,-epsilon]) { | 353 | mirror([0,0,1]) translate([0,0,-epsilon]) { |
341 | difference() { | 354 | difference() { |
342 | cylinder(d=pulley_d,h=knob_bore_l,$fn=fnd*pulley_d); | 355 | cylinder(d=pulley_d,h=knob_bore_l,$fn=fnd*pulley_d); |
343 | translate([0,0,-1]) difference() { | 356 | translate([0,0,-1]) difference() { |
344 | cylinder(d=bore_d+knob_bore_d_tolerance,h=knob_bore_l+2); | 357 | cylinder(d=bore_d+knob_bore_d_tolerance,h=knob_bore_l+2); |
345 | translate([-bore_d/2-1,bore_dd-bore_d/2+knob_bore_d_tolerance/2,-1]) | 358 | translate([-bore_d/2-1,bore_dd-bore_d/2+knob_bore_d_tolerance/2,-1]) |
346 | cube([bore_d+2,bore_d/2,knob_bore_l+4]); | 359 | cube([bore_d+2,bore_d/2,knob_bore_l+4]); |
347 | } | 360 | } |
348 | } | 361 | } |
349 | } | 362 | } |
350 | difference() { | 363 | difference() { |
351 | union() { | 364 | union() { |
352 | cylinder(d1=gearbox_d-2*ch,d2=gearbox_d,h=ch+epsilon,$fn=fnd*gearbox_d); | 365 | cylinder(d1=gearbox_d-2*ch,d2=gearbox_d,h=ch+epsilon,$fn=fnd*gearbox_d); |
353 | translate([0,0,ch]) | 366 | translate([0,0,ch]) |
354 | cylinder(d=gearbox_d,h=knob_h-2*ch+epsilon,$fn=fnd*gearbox_d); | 367 | cylinder(d=gearbox_d,h=knob_h-2*ch+epsilon,$fn=fnd*gearbox_d); |
355 | translate([0,0,knob_h-ch]) | 368 | translate([0,0,knob_h-ch]) |
356 | cylinder(d1=gearbox_d,d2=gearbox_d-2*ch,h=ch,$fn=fnd*gearbox_d); | 369 | cylinder(d1=gearbox_d,d2=gearbox_d-2*ch,h=ch,$fn=fnd*gearbox_d); |
357 | } | 370 | } |
358 | for(a=[0:360/knob_indents:359]) rotate([0,0,a]) | 371 | for(a=[0:360/knob_indents:359]) rotate([0,0,a]) |
359 | translate([0,gearbox_d/2,-1]) | 372 | translate([0,gearbox_d/2,-1]) |
360 | cylinder(d=knob_indent_d,h=knob_h+2,$fn=fnd*knob_indent_d); | 373 | cylinder(d=knob_indent_d,h=knob_h+2,$fn=fnd*knob_indent_d); |
361 | } | 374 | } |
362 | } | 375 | } |
363 | }//knob module | 376 | }//knob module |
364 | 377 | ||
365 | mirrorleft() | 378 | mirrorleft() |
366 | if(what=="lever") color("green",0.7) lever(); | 379 | if(what=="lever") color("green",0.7) lever(); |
367 | else if(what=="body") color("yellow",0.7) body(); | 380 | else if(what=="body") color("yellow",0.7) body(); |
368 | else if(what=="knob") color("red",0.7) knob(); | 381 | else if(what=="knob") color("red",0.7) knob(); |
369 | else if(what=="springpad") color("blue",0.7) springpad(); | 382 | else if(what=="springpad") color("blue",0.7) springpad(); |
370 | else if(what=="both") { | 383 | else if(what=="both") { |
371 | color("green",0.7) lever(); | 384 | color("green",0.7) lever(); |
372 | color("yellow",0.7) body(); | 385 | color("yellow",0.7) body(); |
373 | }else{ | 386 | }else{ |
374 | color("green",0.7) lever(); | 387 | color("green",0.7) lever(); |
375 | color("yellow",0.7) body(); | 388 | color("yellow",0.7) body(); |
376 | color("red",0.7) knob(); | 389 | color("red",0.7) knob(); |
377 | color("blue",0.7) springpad(); | 390 | color("blue",0.7) springpad(); |
378 | } | 391 | } |
379 | } | 392 | } |
380 | 393 | ||
381 | the_extruder(what="both",left=false); | 394 | the_extruder(what="both",left=false); |