5 //tongue_w = 11.92 + 0.4;
9 usb_tongue_d = 8.97 - 0.2;
10 usb_tongue_w_slop = +0.5;
11 usb_wall_h = 4.54 - 2.04;
16 board_l = 17.56 + 0.2;
17 board_w = 19.14 + 0.2;
18 board_th = 1.92 + 0.1;
20 sw_to_edge = board_w/2 + 0.1;
25 wall_y_min = -board_l - side_wall_th; // XXXX remove
26 main_y_min = -board_l - side_wall_th;
27 ceil_y_min = wall_y_min - 5;;
30 [ [0, 0], [-sw_to_edge, -1.0] ],
31 [ [sw_to_edge-4.5, -4.5], [sw_to_edge, -5.7] ],
32 // [ [3.0, -11.72], [sw_to_edge, -13.38] ],
33 [ [-sw_to_edge+3.85, -14.90], [sw_to_edge, -13.38] ],
35 chip_cutout = [[ -sw_to_edge + 4.20, -3.75 ],
36 [ -sw_to_edge + 11.95, -11.90 ]];
40 strain_pitch_across = 5;
41 strain_pitch_along = 10;
49 top_top_z = usb_wall_h;
50 top_base_z = -board_th;
52 strain_0_y_c = main_y_min - strain_w/2;
53 strain_1_y_c = strain_0_y_c - strain_pitch_along;
54 total_y_min = strain_1_y_c - strain_w/2 - side_wall_th;
56 bottom_wall_top_z = (top_top_z + top_base_z) * 0.5 - fit_gap_z/2;
57 cover_wall_top_z = (top_top_z + top_base_z) * 0.5 + fit_gap_z/2;
59 bop_side_wall_x = +board_w/2 + side_wall_th;
68 module FrontWallsPlan(slop) {
70 rectfromto([ -board_w/2 - side_wall_th, 0 ],
71 [ -usb_w/2 - slop, front_wall_th ]);
74 module TopSmallWallsPlan() {
77 rectfromto([ -usb_w/2, -0.01 ],
78 [ -usb_w/2 + usb_wall_w, usb_tongue_d ]);
83 rectfromto(w[0], w[1]);
86 module TopCeilPlan() {
89 rectfromto([ -usb_w/2, -0.01 ],
90 [ 0.1, usb_tongue_d ]);
91 rectfromto([ -board_w/2 - side_wall_th, 0 ],
94 rectfromto(chip_cutout[0], chip_cutout[1]);
97 module TopMainWallsPlan() {
99 rectfromto([ -board_w/2 - side_wall_th, 0 ],
100 [ -board_w/2, wall_y_min ]);
102 FrontWallsPlan(usb_tongue_w_slop);
103 rectfromto([ -board_w/2 - side_wall_th + 0, - board_l ],
104 [ +board_w/2 + side_wall_th, total_y_min ]);
107 module Top(){ ////toplevel
110 linextr(0, usb_wall_h)
112 linextr(usb_wall_h - usb_ceil_th, usb_wall_h)
114 linextr(-board_th, usb_wall_h)
118 for (y_c = [strain_0_y_c, strain_1_y_c]) {
119 for (x_c = [-1,+1] * strain_pitch_across/2) {
120 translate([x_c, y_c, 0])
122 square([ strain_t, strain_w ], center=true);
125 linextr_y_xz(total_y_min-1, main_y_min)
126 translate([0, top_base_z])
127 scale([1, strain_groove_d/strain_groove_w])
128 circle(strain_groove_w/2, $fn = 8);
132 module BottomMainElevation(){ ////toplevel
137 module Bottom(){ ////toplevel