chiark / gitweb /
lock-inframe-bracket: Add a couple of toplevels, before join rework
[reprap-play.git] / lock-inframe-bracket.scad
index 376662eb0d55bcab7b0f8c5e8b70e6cf9ae53dc1..362bffdfb160a3a28c213d6dc74a425a51375713 100644 (file)
@@ -10,6 +10,7 @@ lock_w = 42.5 + 0.5;
 lock_d = 28.0 + 0.5;
 main_h = 45.0;
 backflange_d = 12;
+backflange_hole_dy = -1;
 lockshaft_dia = 14.35;
 
 cliprecess_h = 16;
@@ -27,6 +28,8 @@ clip_d = 22.0;
 mountscrew_dia = 4 + 0.5;
 clipbolt_dia = 5 + 0.6;
 
+mountscrew_washer = 10;
+
 backflange_th = 4.5;
 
 $fn=50;
@@ -55,7 +58,7 @@ front_th = main_th;
 
 tube_or = tube_dia/2 + tube_th;
 back_ohw = back_gap/2 + backflange_th;
-backflange_ymin = tube_or+backflange_d;
+backflange_ymin = tube_dia/2 + backflange_d;
 
 lock_0y = tube_dia/2 + lock_d/2 + midweb_d;
 lock_0x = lock_w/2 - lock_d/2;
@@ -122,7 +125,7 @@ module DividePlanInPlace(xl=10){
     DividePlan(xl);
 }
 
-module MainPlan(){
+module MainPlan(){ ////toplevel
   difference(){
     union(){
       difference(){
@@ -211,18 +214,24 @@ module ExtrudeClipElevation(extra=0){
     children(0);
 }
 
-module ThroughHole(r, y, z) {
-  translate([-50, y, z])
+module ThroughHole(r, y, z, x=-50) {
+  translate([x, y, z])
     rotate([0, 90, 0])
     cylinder(r=r, h=100, $fn=20);
 }
 
-module ThroughHoles(){
+module MountingHoleCylinders(r, x=-50){
   for (z=[ 1/4, 3/4 ]) {
-    ThroughHole( mountscrew_dia/2,
-                -tube_or -0.5*backflange_d,
-                total_h * z );
+    rotate([0,0, backflange_angle])
+      ThroughHole( r,
+                  -tube_dia/2 -0.5*backflange_d + backflange_hole_dy,
+                  total_h * z,
+                  x);
   }
+}
+
+module ThroughHoles(){
+  MountingHoleCylinders(mountscrew_dia/2);
 
   ThroughHole( clipbolt_dia/2,
               lock_0y + lock_d/2 + clip_d/2 + front_th/2,
@@ -269,6 +278,17 @@ module TestClipBoltHole(){ ////toplevel
   }
 }
 
+module Demo(){ ////toplevel
+  Bracket();
+  color("blue") MountingHoleCylinders(mountscrew_dia/2 - 0.1);
+  color("black") MountingHoleCylinders(mountscrew_washer/2,
+                                      back_ohw + 0.25);
+}
+
+module DividePlanDemo(){ ////toplevel
+  DividePlan();
+}
+
 //MainPlan();
 //ClipElevationPositive();
 //ClipElevation();
@@ -276,7 +296,6 @@ module TestClipBoltHole(){ ////toplevel
 //%ThroughHoles();
 //TestTopEdge();
 //TestClipBoltHole();
-//DividePlan();
 
 //Bracket();