3 include <commitid.scad>
11 eclip_prong_th = 2.25;
12 eclip_outer_strt = 0.5;
13 eclip_inner_xstrt = 0.5;
16 eclip_base_epsilon = 0.5;
19 eclip_each_every = 29;
25 test_len = eclip_each_len + eclip_each_every*(test_eclips-1);
26 echo("test_len",test_len);
34 eclip_inner_strt = eclip_outer_strt + eclip_inner_xstrt;
37 r1 = r0 + eclip_gap_rad;
38 r2 = r1 + eclip_prong_th;
39 r2e = r1 + eclip_base_epsilon;
41 ppxl = -(r0 / sqrt(2)) + (eclip_inner_strt / sqrt(2));
45 eclip_base_offset = r1;
46 eclip_wall_offset = -ppxl;
48 eclip_ra_offset = r2 - 0.1;
50 eclip_rhs_offset = ppxl + rgap + eclip_prong_th;
51 // does not include main_th
55 module EclipLPlanCore(alpha){
56 FArcSegment(0,0, r1,r2,
57 180-eclip_ult_angle, eclip_ult_angle-alpha +1);
63 rotate(-alpha) mirror([1,1]) square([r2e, 50]);
65 rotate(-alpha) mirror([1,1]) square([r2e, r2]);
71 module EclipRPlan(alpha, main_th){
74 translate([ppxl + main_th + rgap, -r2*2])
75 square([eclip_prong_th, r2*(2 + 1/sqrt(2))]);
76 translate([-r2, -r2e])
77 square([r2*3, eclip_base_epsilon + r2*4]);
81 module EclipLPlan(alpha){
82 rotate(alpha) EclipLPlanCore(alpha);
85 module EclipPPlan(main_th){
89 rotate(90-eclip_ult_angle) square([r0,r0]);
91 translate([-(r0+.1), -(r0+.1)])
92 square([(r0+.1) + main_th + ppxl, r2*2]);
94 translate([ppxl, 0]) square([main_th, r2]);
97 module TestBase(){ ////toplevel
98 translate([0,0, eclip_base_offset]){
99 for (i=[1 : 2: test_eclips-2]) {
100 translate([0, i*eclip_each_every])
102 linear_extrude(height=eclip_each_len)
103 EclipLPlan(test_alpha);
105 for (j=[0 : 2: test_eclips-1]) {
106 translate([0, j*eclip_each_every])
108 linear_extrude(height=eclip_each_len)
109 EclipRPlan(test_alpha, test_main_th);
112 translate([-r2, -eclip_each_len, -test_base_th]){
117 mirror([0,0,1]) Commitid_BestCount_M([r2*2, test_len]);
122 module TestProtr(){ ////toplevel
124 translate([0,0, test_main_th - eclip_wall_offset])
126 linear_extrude(height=test_len)
127 EclipPPlan(test_main_th);
128 mirror([0,0,1]) Commitid_BestCount_M([test_len, r2]);
132 module TestRAProtr(){ ////toplevel
133 rotate([-90,0,0]) TestProtr();
135 translate([-test_len,
137 -(eclip_ra_offset + test_base_th)])
143 module TestPlanDemo(){
144 color("red") EclipLPlan(test_alpha);
145 color("blue") rotate(test_alpha) EclipPPlan(test_main_th);
146 color("green") EclipRPlan(test_alpha, test_main_th);
149 beta = asin(front_setback / front_height);
151 uf = [-sin(beta), cos(beta)];
152 ur = [-uf[0], uf[1]];
155 pq = pp + uf*front_height + ur*eclip_ra_offset;
156 pr = [ pq[0] - eclip_base_offset + eclip_wall_offset, 0 ];
159 polygon([pq, pp, pr]);
162 thicks = [ 2, 2, 2 ];
164 module Joins(alpha, objnum, objnum_f, objnum_m) {
165 pitch = (front_width - eclip_each_len) / (num_eclips-1);
167 echo("Joins",objnum, objnum_f, objnum_m);
168 thm = thicks[objnum_m];
169 stride = (front_width - eclip_each_len) / (num_eclips-1);
171 if (objnum==objnum_f) {
172 for (i=[ 1 : 2 : num_eclips-1 ]) {
173 translate([0, i*stride + eclip_each_len, 0]) {
175 linear_extrude(height=eclip_each_len)
179 for (i=[ 0 : 2 : num_eclips-1 ]) {
180 translate([0, i*stride + eclip_each_len, 0]) {
182 linear_extrude(height=eclip_each_len)
183 EclipRPlan(alpha, thm);
187 if (objnum==objnum_m)
190 linear_extrude(height=front_width)
195 function r3(pc) = [ pc[0], 0, pc[1] ];
197 module ObjectJoins(objnum){
198 echo("Object",objnum);
199 translate(r3(pp)) Joins(beta, objnum, 0,1);
200 translate(r3(pr)) mirror([1,0,0]) Joins(0, objnum, 0,2);
201 translate(r3(pq)) rotate([0,90,0]) Joins(beta, objnum, 2,1);
205 xmin = pr[0] - eclip_rhs_offset - thicks[2];
206 xmax = pp[0] + eclip_rhs_offset + thicks[1]
207 + eclip_prong_th * (1/cos(beta) - 1)
208 + eclip_base_offset * tan(beta);
220 -eclip_base_offset - thicks[0]])
228 rotate([0, 90-beta, 0])
229 translate([0, 0, ppxl])
231 cube([front_width, front_height, thicks[1]]);
240 color("blue") Front();
241 color("black") Back();