-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 | |||
@@ -264,32 +264,45 @@ module the_extruder( | |||
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); |