chiark / gitweb /
filamenttrestle wip square pin holes, before make triangular
[reprap-play.git] / filamenttrestle.scad
index 74f6fb609a54a04c646e8f392f346c2e4fe96dcd..bb8c029402fb5b4ddcead73ae76233a66eb97a6e 100644 (file)
@@ -1,6 +1,8 @@
 // -*- C -*-
 
 spoolwidth = 80; // fixme needs to be measured
+trestleheight = 80; // fixme needs to be checked
+trestlebase = 80; // fixme needs to be checked
 
 include <doveclip.scad>
 
@@ -11,24 +13,35 @@ guidewidth = 3;
 guiderad = 20;
 
 plugl = 12;
-plugwmin = 4;
+plugwmin = 3;
 plugh = 10;
 plugslope = 0.5;
-plugwmax = plugwmin + plugh * plugslope;
+plugwmax = plugwmin + plugh * plugslope * 2;
+
+trestlelegw = 10;
+trestlebaseh = 10;
+trestleplugd = 1;
+
+topcylthick = 3;
+topcylbasedepth = 4;
+
+pinminh = 1.0;
+pinmaxh = 1.5;
+pinwidth = 3;
+pindh = 0.5;
+pindwidth = 1.5;
 
 module Plug(d=0){
-  a = atan(plugslope);
+  a = -atan(plugslope);
   tdx = d * cos(a);
   tdy = d * sin(a);
   bdx = d / cos(a);
-  rotate([90,0,90]) linear_extrude(height=plugl+0.1){
-    polygon([[-(plugwmax + bdx),  0],
-            [-(plugwmin + tdx),  plugh + tdy],
-            [+(plugwmin + tdx),  plugh + tdy],
-            [+(plugwmax + bdx),  0]]);
+  translate([-d,0,0]) rotate([90,0,90]) linear_extrude(height=plugl+0.1+d*2){
+    polygon([[-(plugwmin/2 + bdx),  0],
+            [-(plugwmax/2 + tdx),  plugh + tdy],
+            [+(plugwmax/2 + tdx),  plugh + tdy],
+            [+(plugwmin/2 + bdx),  0]]);
   }
-  translate([plugl + DoveClip_depth()*0.7, 0, 0])
-    DoveClipPairSane(count=1, h=plugh);
 }
 
 module Bar(){
@@ -54,5 +67,62 @@ module Bar(){
   }
 }
 
-Bar();
+module Trestle(){
+  legang = atan2(trestlebase/2, trestleheight);
+  eplen = sqrt(trestleheight*trestleheight + trestlebase*trestlebase*0.25);
+  topcylw = plugwmax + topcylthick*2;
+
+  pinholewidth = pinwidth + pindwidth;
+  pinholeminh = pinminh + pindh;
+  pinholemaxh = pinmaxh + pindh;
+
+  difference(){
+    union(){
+      for (mir=[0,1]) {
+       mirror([mir,0,0]) {
+         rotate([0,0, -90-legang])
+           ExtenderPillars(length=eplen+trestlelegw,
+                           width=trestlelegw,
+                           height=plugl,
+                           baseweb=true);
+
+         translate([-trestlebase/2, -trestleheight, 0])
+           cylinder(r=trestlelegw/2*1.2, h=plugl);
+       }
+      }
+      translate([-topcylw/2, -topcylbasedepth, 0])
+       cube([topcylw, topcylbasedepth + plugh + topcylthick, plugl]);
+
+      translate([-trestlebase/2, -trestleheight, 0])
+       ExtenderPillars(length=trestlebase, width=trestlebaseh*2, height=plugl);
+    }
+    translate([-300, -trestleheight-50, -1])
+      cube([600, 50, plugl+2]);
+
+    rotate([-90,-90,0])
+      Plug(d=trestleplugd);
+
+    for (rot=[0,180]) {
+      translate([0,0,plugl/2]) rotate([0,rot,0]) translate([0,0,-plugl/2]) {
+       translate([0, plugh, (plugl - pinholewidth*2)/3])
+#      linear_extrude(height = pinholewidth){
+         for (mir=[0,1]) {
+           mirror([0,mir,0]) {
+             polygon([[-(topcylw/2+0.1), -0.1],
+                      [-(topcylw/2+0.1), pinholeminh],
+                      [0,                pinholeminh],
+                      [+(topcylw/2+0.1), pinholemaxh],
+                      [+(topcylw/2+0.1), -0.1]]);
+           }
+         }
+       }    
+      }
+    }
+  }
+}
+
+//Bar();
+Trestle();
+
 //Plug(d=1);
+//ExtenderPillars(80,12,8, baseweb=true);