chiark / gitweb /
earring-stand: introduce test_main_th (nfc)
[reprap-play.git] / earring-stand.scad
1 // -*- C -*-
2
3 eclip_inner_rad = 2.5;
4 eclip_gap_rad = 0.5;
5 eclip_prong_th = 3;
6 eclip_outer_strt = 0.5;
7 eclip_inner_xstrt = 0.5;
8
9 eclip_ult_angle = 44;
10 eclip_base_epsilon = 0.5;
11
12 test_alpha = 10;
13 test_main_th = 1.5;
14
15 // calculated
16
17 include <utils.scad>
18
19 eclip_inner_strt = eclip_outer_strt + eclip_inner_xstrt;
20
21 r0 = eclip_inner_rad;
22 r1 = r0 + eclip_inner_rad;
23 r2 = r1 + eclip_prong_th;
24 r2e = r1 + eclip_base_epsilon;
25
26 ppxl = -(r0 / sqrt(2)) + (eclip_inner_strt / sqrt(2));
27
28 $fn=70;
29
30 module EclipLPlanCore(alpha){
31   FArcSegment(0,0, r1,r2,
32               180-eclip_ult_angle, eclip_ult_angle-alpha +1);
33
34   difference(){
35     hull(){
36       intersection(){
37         circle(r2);
38         rotate(-alpha) mirror([1,1]) square([r2e, 50]);
39      }
40       rotate(-alpha) mirror([1,1]) square([r2e, r2]);
41     }
42     circle(r1);
43   }
44 }
45
46 module EclipLPlan(alpha){
47   rotate(alpha) EclipLPlanCore(alpha);
48 }
49
50 module EclipPPlan(main_th){
51   intersection(){
52     hull(){
53       circle(r0);
54       rotate(90-eclip_ult_angle) square([r0,r0]);
55     }
56     translate([-(r0+.1), -(r0+.1)])
57       square([(r0+.1) + main_th + ppxl, r2*2]);
58   }
59   translate([ppxl, 0]) square([main_th, r2]);
60 }
61
62 color("red") EclipLPlan(test_alpha);
63 color("blue") rotate(test_alpha) EclipPPlan(test_main_th);