chiark / gitweb /
ksafe-base: introduce SomeBaseProfile (nfc)
[reprap-play.git] / lock-inframe-bracket.scad
index 618be89..f150567 100644 (file)
@@ -97,34 +97,6 @@ module JoinCircs(jr){
   }
 }
 
-module DividePlan(xl=10){
-  w = divide_shaft_w;
-  g = divide_gap;
-  l = divide_shaft_l + g;
-  t = divide_head_th + g;
-  dx = divide_head_dx;
-  for (m=[0,1]) mirror([m,0]) {
-    translate([w, 0]) square([xl, g]);
-    for (i=[0:divide_heads-1]) {
-      translate([w, i*(l + t)]) {
-       translate([0, 0]) square([g, l + g]);
-       translate([0, l]) square([divide_head_dx + g, g]);
-       translate([dx, l]) square([g, t + g]);
-       translate([0, l + t])
-         square([divide_head_dx + g, g]);
-      }
-    }
-    translate([-0.1, (l + t) * divide_heads])
-      square([w + g, g]);
-  }
-}
-
-module DividePlanInPlace(xl=10){
-  rotate([0,0, -divide_angle])
-    translate([ -tube_dia/2 -tube_th/2 - divide_fudge_r, 0])
-    DividePlan(xl);
-}
-
 module DivideHook(){ ////toplevel
   w = tube_th/2;
   d = divide_gap;
@@ -143,6 +115,7 @@ module DivideHook(){ ////toplevel
 module DivideCut(){
   w = tube_th/2;
   d = divide_gap;
+  br = tube_dia/2 + tube_th;
 
   difference(){
     offset(r=divide_gap) DivideHook();
@@ -151,10 +124,20 @@ module DivideCut(){
   }
 }
 
-module DivideInPlace(){
-  rotate([0,0, -divide_angle])
-    translate([ -tube_dia/2 -tube_th/2, 0])
-    children();
+module DivideCutB(){
+  w = tube_th/2;
+  d = divide_gap;
+  br = tube_dia/2 + tube_th;
+  
+  intersection(){
+    translate([br - tube_th/2,0]) {
+      difference(){
+       circle(r=br + d);
+       circle(r=br);
+      }
+    }
+    translate([-2*w, 0]) mirror([0,1]) square(4*w);
+  }
 }
 
 module DivideSurround(){
@@ -169,6 +152,12 @@ module DivideSurround(){
   }
 }
 
+module DivideInPlace(){
+  rotate([0,0, -divide_angle])
+    translate([ -tube_dia/2 -tube_th/2, 0])
+    children();
+}
+
 module MainPlan(){ ////toplevel
   difference(){
     union(){
@@ -209,6 +198,7 @@ module MainPlan(){ ////toplevel
     circle(r = tube_dia/2);
 
     DivideInPlace() DivideCut();
+    DivideInPlace() DivideCutB();
   }
 }
 
@@ -324,10 +314,6 @@ module Demo(){ ////toplevel
                                       back_ohw + 0.25);
 }
 
-module DividePlanDemo(){ ////toplevel
-  DividePlan();
-}
-
 module DivideDemo(){ ////toplevel
   color("black") translate([0,0,-2]) MainPlan();
   color("grey") DivideInPlace() DivideHook();