chiark / gitweb /
trackpump-mutlihead-clip: move baseplate into PumpSide so it can be non-square (nfc)
[reprap-play.git] / trackpump-mutlihead-clip.scad
index a6d1bbd8352e31c206d32ba231a8b0a94fdb74e5..90141af7733792a138376a0fac23d211c886ad11 100644 (file)
@@ -2,14 +2,21 @@
 
 pump_main_dia = 38;
 pump_side_width = 5;
-pump_side_thick = 5;
+pump_side_thick = 4;
 pump_shaft_dia = 14;
-baseplate = 4;
+baseplate = 3;
 
 pump_protr_flat = 3;
-pump_protr_slope = 1.0;
+pump_protr_slope = 0.9;
+
+hose_inner_dia = 20;
+hose_aperture = 11;
+hose_side_width = 5;
+hose_base_offset = 30;
+
+hose_side_thick = 6;
+hose_side_stalk_width = 6;
 
-// need reconfirm:
 pump_protr_protr = 3;
 pump_side_height = 20;
 
@@ -18,8 +25,18 @@ pump_protr_slheight = pump_protr_protr / pump_protr_slope;
 
 pump_side_outer_rad = pump_side_width + pump_main_dia/2;
 
+baseplate_width_rad =
+  sqrt( pow(pump_side_outer_rad, 2)
+       -pow( pump_main_dia/2 - pump_protr_protr, 2) );
+
+xm = baseplate + pump_main_dia/2;
+
+pump_side_total_height =
+  pump_side_thick + pump_side_height + pump_protr_slheight + pump_protr_flat;
+
+$fa=5;
+
 module PumpSidePlan() {
-  xm = baseplate + pump_main_dia/2;
   or = pump_side_outer_rad;
   difference(){
     union(){
@@ -27,10 +44,9 @@ module PumpSidePlan() {
        translate([-xm, 0]) circle(r=or);
        translate([-(xm+or), -or]) square([xm+or, or*2]);
       }
-      translate([-xm, -or]) square([xm, or*2]);
     }
-    translate([-xm*2, 0])
-      square(center=true, [pump_side_width*3, pump_shaft_dia]);
+    translate([-xm-or, 0])
+      square(center=true, [pump_side_width*4, pump_shaft_dia]);
   }
 }
 
@@ -66,15 +82,25 @@ module PumpSideElevation(){
 }
 
 module PumpSide(){
+  br = baseplate_width_rad;
+
   difference(){
     intersection(){
       translate([0,100,0])
        rotate([90,0,0])
        linear_extrude(height=200)
-      PumpSideElevation();
-      translate([0,0,-100])
-       linear_extrude(height=200)
-       PumpSidePlan();
+       PumpSideElevation();
+      union(){
+       translate([0,0,-100])
+         linear_extrude(height=200)
+         PumpSidePlan();
+       // baseplate
+       mirror([0,0,1])
+         translate([-xm, -br, 0])
+         cube([xm,
+               br*2,
+               pump_side_total_height]);
+      }
     }
     translate([-(baseplate + pump_main_dia/2), 0,
                -(pump_side_thick + pump_side_height)])
@@ -82,6 +108,48 @@ module PumpSide(){
   }
 }
 
+module HoseSidePlan(){
+  ro = hose_inner_dia/2 + hose_side_width;
+  ri = (hose_inner_dia/2);
+  st = hose_side_stalk_width/2;
+
+  apx = sqrt( ri*ri - (hose_aperture*hose_aperture)/4 );
+  apsq = hose_base_offset + apx - hose_aperture/2;
+  echo(apx,apsq);
+
+  difference(){
+    union(){
+      translate([-1, -st]) square([hose_base_offset+1, st*2]);
+      translate([hose_base_offset, 0]) circle(r= ro);
+    }
+    translate([hose_base_offset, 0]) circle(r= hose_inner_dia/2);
+    translate([apsq, 0])
+      rotate(-45)
+      square([50,50]);
+  }
+
+  //%translate([hose_base_offset + apx, 0]) square([50,50]);
+  //%square(center=true, [100, hose_aperture]);
+}
+
+module HoseSide(){
+  mirror([0,0,1])
+    linear_extrude(height=hose_side_thick)
+    HoseSidePlan();
+}
+
+module Clip(){
+  PumpSide();
+  HoseSide();
+}
+
+module ClipPrint(){
+  rotate([180,0,0])
+    Clip();
+}
+
 //PumpSidePlan();
-//PumpSideElevation();
-PumpSide();
+//PumpSide();
+//HoseSide();
+//Clip();
+ClipPrint();