chiark / gitweb /
sewing-table: Machine_Rear: reartablet, and fix x
[reprap-play.git] / sewing-table.scad.m4
index 7094f914a5e5ab30f820794df41d3d8b8ac74c8b..45694567c8e9474010d5d1fcd84d89883df27abb 100644 (file)
@@ -58,6 +58,10 @@ rearcurve_rad_slop = 0.5;
 
 rearcurve_avoid_y = rearcurve_rad + 10;
 
+reartablet_z = 2.54;
+reartablet_x = 5 + 1;
+reartablet_y = 5;
+
 // calculated
 
 TEST = false;
@@ -347,33 +351,51 @@ module Machine_Arm(){
   }
 }
 
-module Machine_Rear(){
+module Machine_Rear(){ ////toplevel
   big_rad = rearcurve_total_len - rearcurve_strt_len + rearcurve_rad;
   small_rad = rearcurve_rad + rearcurve_rad_slop;
-  translate([ 250 + rearedge_len - cutout_l_end_y + big_rad,
+  translate([ 250 - cutout_l_end_x + rearedge_len,
              cutout_tile11_y,
              0 ]){
-    translate([ 0,
+    //%cube([20,20,20]);
+    translate([ -reartablet_x,
+               -1,
+               -reartablet_z])
+      mirror([0,0,1])
+      cube([ reartablet_x+1,
+            reartablet_y+1,
+            20 ]);
+    translate([ rearcurve_strt_len,
                0,
-               -rearcurve_rad
-               ]){
-      rotate([0,-90,0]){
-       cylinder(r = small_rad, h= rearcurve_strt_len);
+               0 ]){
+      translate([ 0,
+                 0,
+                 -rearcurve_rad
+                 ]){
+       rotate([0,-90,0]){
+         rotate([0,0, 360/8/2])
+           cylinder(r = small_rad, h= rearcurve_strt_len);
+       }
       }
-    }
-    translate([ 0,
-               0,
-               big_rad - rearcurve_rad ]) {
-      intersection(){
-       rotate([90,0,0]){
-         rotate_extrude(convexity=10) {
-           translate([ big_rad,
-                       0 ])
-             circle(r= small_rad);
+      translate([ 0,
+                 0,
+                 big_rad - rearcurve_rad ]) {
+       intersection(){
+         rotate([90,0,0]){
+           rotate_extrude(convexity=10) {
+             translate([ big_rad,
+                         0 ]) {
+               hull(){
+                 circle(r= small_rad);
+                 translate([200,0])
+                   circle(r= small_rad);
+               }
+             }
+           }
          }
+         mirror([0,0,1])
+           cube([150,150,150]);
        }
-       mirror([0,0,1])
-         cube([100,100,100]);
       }
     }
   }
@@ -381,11 +403,7 @@ module Machine_Rear(){
 
 module Machine(){ ////toplevel
   Machine_Arm();
-  minkowski(){
-    Machine_Rear();
-    translate([0,-5,-5])
-      cube([50,5,5]);
-  }
+  Machine_Rear();
 }
   
 function Rectangle_corners(c0, sz) =
@@ -512,22 +530,26 @@ module Tile10(){ ////toplevel
   c0 = [sz[0],0];
   c = Rectangle_corners(c0, sz);
   cnr_posts = Rectangle_corners2posts(c);
-  posts = [ cnr_posts[0],
-           cnr_posts[1] + [ -rearedge_len + cutout_l_end_x, 0 ],
-           cnr_posts[1] + [ 0, rearcurve_avoid_y ],
+  cty = cutout_tile11_y;
+  rcy = cty + rearcurve_avoid_y;
+  posts = [ cnr_posts[0] + [ 0,                             cty ],
+           cnr_posts[1] + [ -sz[1] + rearedge_len - cutout_l_end_x, cty ],
+           cnr_posts[1] + [ 0,                             rcy ],
            cnr_posts[2],
            cnr_posts[3] ];
+  rcs = [R_EDGE(c,2)];
   difference(){
     union(){
       Rectangle_TileBase(c);
       Posts(posts);
+      RoundEdge(R_EDGE(c,1));
       RoundEdge(R_EDGE(c,2));
-      //InterlockEdge(tile_01_11_cnr, c[3]);
-      //InterlockEdge(R_EDGE(c,3));
+      InterlockEdge(c[3], tile_11_10_cnr);
     }
-    //InterlockEdge(c[1], tile_01_00_cnr, 1);
+    RoundCornerCut(rcs);
     Machine();
   }
+  RoundCornerAdd(rcs);
 }
 
 module Demo(){ ////toplevel