chiark / gitweb /
earring-stand: back wip
[reprap-play.git] / earring-stand.scad
index e3df5ac49ac68db3046ff23e5d56cbc2fce4224f..bf049ea88d4dda4d96eb6abeaf39426b65898ba8 100644 (file)
@@ -23,7 +23,8 @@ test_main_th = 1.5;
 test_eclips = 5;
 test_base_th = 2.5;
 test_len = eclip_each_len + eclip_each_every*(test_eclips-1);
-echo("test_len",test_len);
+
+num_eclips = 5;
 
 // calculated
 
@@ -45,6 +46,9 @@ eclip_wall_offset = -ppxl;
 
 eclip_ra_offset = r2 - 0.1;
 
+eclip_rhs_offset = ppxl + rgap + eclip_prong_th;
+// does not include main_th
+
 $fn=70;
 
 module EclipLPlanCore(alpha){
@@ -144,11 +148,14 @@ module TestPlanDemo(){
 beta = asin(front_setback / front_height);
 
 uf = [-sin(beta), cos(beta)];
-ur = [-uf[0], uf[1]];
+ur = [ -uf[1], uf[0]];
 
 pp = [0, 0];
 pq = pp + uf*front_height + ur*eclip_ra_offset;
-pr = [ pq[0] - eclip_base_offset + eclip_wall_offset, 0 ];
+pr = [ pq[0] - eclip_base_offset - eclip_wall_offset,
+       0 ];
+
+echo("uf ur P Q R", uf, ur, pp, pq, pr);
 
 module Sketch(){
   polygon([pq, pp, pr]);
@@ -157,40 +164,97 @@ module Sketch(){
 thicks = [ 2, 2, 2 ];
 
 module Joins(alpha, objnum, objnum_f, objnum_m) {
-  echo("Joins",objnum, objnum_f, objnum_m);
+  pitch = (front_width - eclip_each_len) / (num_eclips-1);
+  
   thm = thicks[objnum_m];
+  stride = (front_width - eclip_each_len) / (num_eclips-1);
+
   if (objnum==objnum_f) {
-    EclipLPlan(alpha);
-    EclipRPlan(alpha, thm);
+    for (i=[ 1 : 2 : num_eclips-1 ]) {
+      translate([0, i*stride + eclip_each_len, 0]) {
+       rotate([90,0,0])
+       linear_extrude(height=eclip_each_len)
+         EclipLPlan(alpha);
+      }
+    }
+    for (i=[ 0 : 2 : num_eclips-1 ]) {
+      translate([0, i*stride + eclip_each_len, 0]) {
+       rotate([90,0,0])
+       linear_extrude(height=eclip_each_len)
+         EclipRPlan(alpha, thm);
+      }
+    }
   }
   if (objnum==objnum_m)
-    rotate(alpha)
+    mirror([0,1,0])
+      rotate([90,0,0])
+      linear_extrude(height=front_width)
+      rotate(alpha)
       EclipPPlan(thm);
 }
 
+function r3(pc) = [ pc[0], 0, pc[1] ];
+
 module ObjectJoins(objnum){
-  echo("Object",objnum);
-  translate(pp)                   Joins(beta, objnum, 0,1);
-  translate(pr) mirror([1,0,0])   Joins(0,    objnum, 0,2);
-  translate(pq) rotate([0,0,-90]) Joins(beta, objnum, 2,1);
+  translate(r3(pp))                   Joins(beta, objnum, 0,1);
+  translate(r3(pr)) mirror([1,0,0])   Joins(0,    objnum, 0,2);
+  translate(r3(pq)) rotate([0,90,0]) mirror([1,0,0]) Joins(-beta, objnum, 2,1);
 }
 
 module Base(){
-  ObjectJoins(0);
+  xmin = pr[0] - eclip_rhs_offset - thicks[2];
+  xmax = pp[0] + eclip_rhs_offset + thicks[1]
+    + eclip_prong_th * (1/cos(beta) - 1)
+    + eclip_base_offset * tan(beta);
+  intersection(){
+    ObjectJoins(0);
+    translate([xmin,
+              -1,
+              -50])
+      cube([xmax - xmin,
+           front_width + 2,
+           300]);
+  }
+  translate([xmin,
+            0,
+            -eclip_base_offset - thicks[0]])
+    cube([xmax - xmin,
+         front_width,
+         thicks[0]]);
 }
 
 module Front(){
   ObjectJoins(1);
+  rotate([0, 90-beta, 0])
+    translate([0, 0, ppxl])
+    rotate([0,0,90]) {
+    cube([front_width,
+         front_height - eclip_wall_offset + thicks[1],
+         thicks[1]]);
+  }
 }
 
 module Back(){
   ObjectJoins(2);
+
+  zmin = pr[1];
+  zmax = pq[1] + eclip_prong_th;
+  height = zmax - zmin;
+
+  translate([pr[0] + eclip_wall_offset - thicks[2],
+            0, 0])
+    rotate([0,90,0])
+    rotate([0,0,90]) {
+    cube([front_width,
+         height,
+         thicks[2]]);
+  }
 }
 
 module Demo(){
-  Base();
-  Front();
-  Back();
+  color("red") Base();
+  color("blue") Front();
+  color("black") Back();
 }
 
 //PlanDemo();
@@ -198,4 +262,4 @@ module Demo(){
 //TestProtr();
 //TestRAProtr();
 //Sketch();
-//Demo();
+Demo();