-rw-r--r-- | another.scad | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/another.scad b/another.scad index 1c6d836..0d67286 100644 --- a/another.scad +++ b/another.scad | |||
@@ -357,49 +357,49 @@ module the_extruder( | |||
357 | cube(size=[body_h-ls_z+1,st_split_w+st_split_w_tolerance,fsw+1]); | 357 | cube(size=[body_h-ls_z+1,st_split_w+st_split_w_tolerance,fsw+1]); |
358 | }//translate | 358 | }//translate |
359 | translate([0,0,st_thickshell+st_nut_h+st_nut_h_tolerance+st_thinshell+hf-epsilon]) | 359 | translate([0,0,st_thickshell+st_nut_h+st_nut_h_tolerance+st_thinshell+hf-epsilon]) |
360 | cylinder(d=bigd,h=fsw+1,$fn=fnd*bigd); | 360 | cylinder(d=bigd,h=fsw+1,$fn=fnd*bigd); |
361 | }//mirror | 361 | }//mirror |
362 | }//translate | 362 | }//translate |
363 | 363 | ||
364 | // label | 364 | // label |
365 | body_label(); | 365 | body_label(); |
366 | 366 | ||
367 | }//difference | 367 | }//difference |
368 | 368 | ||
369 | }//body module | 369 | }//body module |
370 | module body_label() { | 370 | module body_label() { |
371 | if(body_label) { | 371 | if(body_label) { |
372 | label=body_label; | 372 | label=body_label; |
373 | label_thickness=body_label_thickness; | 373 | label_thickness=body_label_thickness; |
374 | label_len = len(label); | 374 | label_len = len(label); |
375 | 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]; | 375 | 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]; |
376 | translate([0,0,body_h-label_thickness]) | 376 | translate([0,0,body_h-label_thickness]) |
377 | linear_extrude(height=label_thickness+epsilon,convexity=64) | 377 | linear_extrude(height=label_thickness+epsilon,convexity=64) |
378 | 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]) | 378 | 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]) |
379 | mirror([left?0:1,0]) | 379 | mirror([left?0:1,0]) |
380 | text(text=label,size=labelspace.x/label_len,halign="center",valign="center",font="Arial Black"); | 380 | text(text=label,size=labelspace.x/label_len,halign="center",valign="center",font="Arial Black"); |
381 | }//if(body_label) | 381 | }else sphere(d=epsilon); // to avoid makefile breakage |
382 | } | 382 | } |
383 | 383 | ||
384 | module springpad() { | 384 | module springpad() { |
385 | smalld=st_screw_d+st_screw_d_tolerance+min_xy_shell; | 385 | smalld=st_screw_d+st_screw_d_tolerance+min_xy_shell; |
386 | bigd = spring_d+spring_d_clearance/2; | 386 | bigd = spring_d+spring_d_clearance/2; |
387 | hf = (bigd-smalld)/2; | 387 | hf = (bigd-smalld)/2; |
388 | h = hf*3.5; | 388 | h = hf*3.5; |
389 | translate([-gearbox_d/2+st_thickshell+st_nut_h+st_nut_h_tolerance+st_thinshell+1,-longwing,filament_elevation]) | 389 | translate([-gearbox_d/2+st_thickshell+st_nut_h+st_nut_h_tolerance+st_thinshell+1,-longwing,filament_elevation]) |
390 | rotate([0,90,0]) difference() { | 390 | rotate([0,90,0]) difference() { |
391 | union() { | 391 | union() { |
392 | cylinder(d1=smalld,d2=bigd,h=hf,$fn=fnd*bigd); | 392 | cylinder(d1=smalld,d2=bigd,h=hf,$fn=fnd*bigd); |
393 | translate([0,0,hf-epsilon]) | 393 | translate([0,0,hf-epsilon]) |
394 | cylinder(d=bigd,h=h-hf,$fn=fnd*bigd); | 394 | cylinder(d=bigd,h=h-hf,$fn=fnd*bigd); |
395 | translate([0,0,h]) | 395 | translate([0,0,h]) |
396 | sphere(d=spring_d*3/4,$fn=fnd*spring_d*3/4); | 396 | sphere(d=spring_d*3/4,$fn=fnd*spring_d*3/4); |
397 | l = body_h-ls_z; | 397 | l = body_h-ls_z; |
398 | w = st_split_w; | 398 | w = st_split_w; |
399 | hull() translate([0,-st_split_w/2,0]) mirror([1,0,0]) { | 399 | hull() translate([0,-st_split_w/2,0]) mirror([1,0,0]) { |
400 | translate([0,0,w]) | 400 | translate([0,0,w]) |
401 | cube(size=[l,st_split_w,w]); | 401 | cube(size=[l,st_split_w,w]); |
402 | cube(size=[l-w,st_split_w,2*w]); | 402 | cube(size=[l-w,st_split_w,2*w]); |
403 | } | 403 | } |
404 | } | 404 | } |
405 | translate([0,0,-epsilon]) | 405 | translate([0,0,-epsilon]) |
@@ -422,49 +422,49 @@ module the_extruder( | |||
422 | } | 422 | } |
423 | } | 423 | } |
424 | difference() { | 424 | difference() { |
425 | hull() { | 425 | hull() { |
426 | cylinder(d=gearbox_d-2*ch,h=knob_h,$fn=fnd*gearbox_d); | 426 | cylinder(d=gearbox_d-2*ch,h=knob_h,$fn=fnd*gearbox_d); |
427 | translate([0,0,ch]) | 427 | translate([0,0,ch]) |
428 | cylinder(d=gearbox_d,h=knob_h-2*ch,$fn=fnd*gearbox_d); | 428 | cylinder(d=gearbox_d,h=knob_h-2*ch,$fn=fnd*gearbox_d); |
429 | } | 429 | } |
430 | for(a=[0:360/knob_indents:359]) rotate([0,0,a]) | 430 | for(a=[0:360/knob_indents:359]) rotate([0,0,a]) |
431 | translate([0,gearbox_d/2,-1]) | 431 | translate([0,gearbox_d/2,-1]) |
432 | cylinder(d=knob_indent_d,h=knob_h+2,$fn=fnd*knob_indent_d); | 432 | cylinder(d=knob_indent_d,h=knob_h+2,$fn=fnd*knob_indent_d); |
433 | translate([0,0,-body_h-epsilon]) knob_label(); | 433 | translate([0,0,-body_h-epsilon]) knob_label(); |
434 | } | 434 | } |
435 | } | 435 | } |
436 | }//knob module | 436 | }//knob module |
437 | module knob_label() { | 437 | module knob_label() { |
438 | if(knob_label) { | 438 | if(knob_label) { |
439 | ll = len(knob_label); | 439 | ll = len(knob_label); |
440 | lsl = gearbox_d-knob_indent_d; | 440 | lsl = gearbox_d-knob_indent_d; |
441 | ts = knob_label_size?knob_label_size:min(lsl/ll,gearbox_d/4); | 441 | ts = knob_label_size?knob_label_size:min(lsl/ll,gearbox_d/4); |
442 | translate([0,0,body_h+epsilon+knob_h-knob_label_thickness]) | 442 | translate([0,0,body_h+epsilon+knob_h-knob_label_thickness]) |
443 | linear_extrude(height=knob_label_thickness+epsilon,convexity=64) | 443 | linear_extrude(height=knob_label_thickness+epsilon,convexity=64) |
444 | mirror([left?0:1,0]) | 444 | mirror([left?0:1,0]) |
445 | text(text=knob_label,size=ts,halign="center",valign="center",font="Arial Black"); | 445 | text(text=knob_label,size=ts,halign="center",valign="center",font="Arial Black"); |
446 | } | 446 | }else sphere(d=epsilon); // to avoid makefile breakage |
447 | } | 447 | } |
448 | 448 | ||
449 | module debug() { | 449 | module debug() { |
450 | difference() { | 450 | difference() { |
451 | children(); | 451 | children(); |
452 | if(debug) { | 452 | if(debug) { |
453 | // spring tensioner debug cutout | 453 | // spring tensioner debug cutout |
454 | translate([-gearbox_d/2,-longwing,ls_z]) rotate([0,-90,0]) | 454 | translate([-gearbox_d/2,-longwing,ls_z]) rotate([0,-90,0]) |
455 | translate([0,-lever_thickness/2-1,-gearbox_d]) | 455 | translate([0,-lever_thickness/2-1,-gearbox_d]) |
456 | cube(size=[body_h/2+1,lever_thickness/2+1,gearbox_d+2]); | 456 | cube(size=[body_h/2+1,lever_thickness/2+1,gearbox_d+2]); |
457 | // lever axis debug cutout | 457 | // lever axis debug cutout |
458 | translate([mount_d/2,0,-1]) | 458 | translate([mount_d/2,0,-1]) |
459 | rotate([0,0,-45]) | 459 | rotate([0,0,-45]) |
460 | cube(size=[gearbox_d-mount_d,gearbox_d-mount_d,body_h+knob_h+2]); | 460 | cube(size=[gearbox_d-mount_d,gearbox_d-mount_d,body_h+knob_h+2]); |
461 | // idler debug cutout | 461 | // idler debug cutout |
462 | translate([0,0,ls_z]) | 462 | translate([0,0,ls_z]) |
463 | place_idler() | 463 | place_idler() |
464 | rotate([0,0,-45]) | 464 | rotate([0,0,-45]) |
465 | translate([0,0,-lever_thickness/2-epsilon]) | 465 | translate([0,0,-lever_thickness/2-epsilon]) |
466 | cube(size=[lsd*sqrt(2)/2+1,lsd*sqrt(2)/2+1, | 466 | cube(size=[lsd*sqrt(2)/2+1,lsd*sqrt(2)/2+1, |
467 | lever_thickness+2*epsilon]); | 467 | lever_thickness+2*epsilon]); |
468 | // pushfit debug cutout | 468 | // pushfit debug cutout |
469 | place_idler() | 469 | place_idler() |
470 | translate([-idler_d/2+filament_offset,0,ls_z]) | 470 | translate([-idler_d/2+filament_offset,0,ls_z]) |