chiark / gitweb /
filamentspool: 3mm: Slight reduce radii
[reprap-play.git] / filamentspool.scad
index 40e893d1dd85a9ebe885a2c472d103d9944e1e87..f78c6048f7188879ffac0e6bcdcb5382db2396de 100644 (file)
@@ -8,9 +8,11 @@ bigslop=slop*2;
 function selsz(sm,lg) = fdia < 2 ? sm : lg;
 function usedove() = selsz(true,false);
 
+num_arms = selsz(3,4);
+
 exteffrad = 70;
-hubeffrad = selsz(30, 60);
-hubbigrad = selsz(20, 50);
+hubeffrad = selsz(30, 50);
+hubbigrad = selsz(20, 45);
 hublwidth = selsz(3, 5);
 hubstemwidth = 2;
 hublthick = 10;
@@ -80,6 +82,10 @@ ratchetpawl=ratchetstep-ratchettooth-bigslop*2;
 nondove_armbase = 100;
 nondove_armhole_x = 60;
 nondove_armhole_hole = 4;
+nondove_armhole_support = 7;
+nondove_armhole_wall = 4;
+nondove_armhole_slop = 0.5;
+nondove_armhole_slop_x = 0.5;
 
 include <doveclip.scad>
 include <cliphook.scad>
@@ -241,6 +247,7 @@ module Hub(){ ////toplevel
   xmax = hubbigrad-hublwidth/2;
   hole = hubeffrad - hubbigrad - DoveClip_depth() - hublwidth*2;
   holewidth = DoveClipPairSane_width() - hubstemwidth*2;
+  nondove_allwidth = nondove_armhole_wall*2 + totalwidth;
   difference(){
     union(){
       difference(){
@@ -249,7 +256,7 @@ module Hub(){ ////toplevel
          cylinder($fn=30, h=hublthick+2, r=(hubbigrad-hublwidth));
       }
       cylinder(h=hubaxlelen, r=axlerad+hublwidth);
-      for (ang=[0,120,240])
+      for (ang=[0 : 360/num_arms : 359])
        rotate([0,0,ang]) {
          difference() {
            if (usedove()){
@@ -262,10 +269,28 @@ module Hub(){ ////toplevel
                  cube([hole, holewidth, hublthick+2]);
              }
            } else {
+             difference(){
+               translate([0,
+                          -nondove_allwidth/2,
+                          0])
+                 cube([hubeffrad + nondove_armhole_x
+                       + nondove_armhole_hole/2 + nondove_armhole_support,
+                       nondove_allwidth,
+                       nondove_armhole_wall + totalheight]);
+               translate([hubeffrad - nondove_armhole_slop_x,
+                          -nondove_allwidth/2
+                          + nondove_armhole_wall - nondove_armhole_slop,
+                          nondove_armhole_wall])
+                 cube([nondove_armhole_x + 50,
+                       totalwidth + nondove_armhole_slop*2,
+                       totalheight + 1]);
+               translate([hubeffrad + nondove_armhole_x, 0, -20])
+                  cylinder(r= nondove_armhole_hole/2, h=50, $fn=10);
+             }
            }
          }
        }
-      for (ang = [0 : 60 : 359])
+      for (ang = [0 : 180/num_arms : 359])
        rotate([0,0,ang]) rotate([90,0,0]) {
          translate([0,0,-hublwidth/2])
            linear_extrude(height=hublwidth)