chiark / gitweb /
cable-hole-trunking-cover: nearly done?
[reprap-play.git] / cable-hole-trunking-cover.scad
index 584ee01512405e75a696f698acfcba441e4a59e9..9491027b75737603bdd822bcf6bf2be9f2addadd 100644 (file)
@@ -6,6 +6,8 @@ sidewidth = 5;
 tapewidth = 7;
 tapethick = 1;
 
+cutoutsz= 10;
+
 innerz = 10;
 
 basex = holedia + sidewidth*2;
@@ -33,25 +35,34 @@ module sheared_cube(sz, xperz, yperz) {
     cube(sz);
 }
 
-module Base(){
+module Base(cutouty){
+  echo(cutouty);
   difference(){
     union(){
       for (mir=[0,1]) mirror([0,mir,0]) {
        translate([0, basey/2 - sidewallt, 0])
          sheared_cube([basex, sidewallt, bevelz], 0, bevelslope);
        cube([basex, basey/2, basebaset]);
-       rotate([90, 0, 90])
-         linear_extrude(height=endwallt)
-         polygon([[-0.1,             0],
-                  [basey/2,          0],
-                  [basey/2 + bevely, bevelz],
-                  [basey/2 + bevely, innerz],
-                  [-0.1,             innerz]]);
       }
     }
     translate([basex/2, 0, -1])
       cylinder(r=holedia/2, h=bevelz+2);
   }
+  rotate([90, 0, 90]) {
+    linear_extrude(height=endwallt) {
+      difference(){
+       for (mir=[0,1]) mirror([mir,0,0]) {
+           polygon([[-0.1,             0],
+                    [basey/2,          0],
+                    [basey/2 + bevely, bevelz],
+                    [basey/2 + bevely, innerz],
+                    [-0.1,             innerz]]);
+       }
+       translate([cutouty, 0])
+         square(size=[cutoutsz, 3*innerz], center=true);
+      }
+    }
+  }
 }
 
 module Lid(){
@@ -69,5 +80,18 @@ module Lid(){
   }
 }
 
-Base();
-%Lid();
+module LidT(){ ////toplevel
+  rotate([180,0,0]) Lid();
+}
+
+module BaseCMid(){ ////toplevel
+  Base(0);
+}
+
+module BaseCTop(){ ////toplevel
+  Base(basey/2 + bevely - cutoutsz/2);
+}
+
+//BaseCTop();
+//BaseCMid();
+//LidT();