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;
eclip_ra_offset = r2 - 0.1;
+eclip_rhs_offset = ppxl + rgap + eclip_prong_th;
+// does not include main_th
+
$fn=70;
module EclipLPlanCore(alpha){
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]);
module Joins(alpha, objnum, objnum_f, objnum_m) {
pitch = (front_width - eclip_each_len) / (num_eclips-1);
- echo("Joins",objnum, objnum_f, objnum_m);
thm = thicks[objnum_m];
stride = (front_width - eclip_each_len) / (num_eclips-1);
function r3(pc) = [ pc[0], 0, pc[1] ];
module ObjectJoins(objnum){
- echo("Object",objnum);
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]) Joins(beta, objnum, 2,1);
+ 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(){