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;
46 bottom_floor_th = 1.5;
52 top_top_z = usb_wall_h;
53 top_base_z = -board_th;
54 bottom_base_z = top_base_z - cable_space_z - bottom_floor_th;;
56 front_y_max = front_wall_th;
58 strain_0_y_c = main_y_min - strain_w/2;
59 strain_1_y_c = strain_0_y_c - strain_pitch_along;
60 total_y_min = strain_1_y_c - strain_w/2 - side_wall_th;
62 bottom_wall_top_z = (top_top_z + top_base_z) * 0.5 - fit_gap_z/2;
63 cover_wall_top_z = (top_top_z + top_base_z) * 0.5 + fit_gap_z/2;
65 top_side_wall_x = +board_w/2 + side_wall_th;
74 module FrontWallsPlan(slop) {
76 rectfromto([ -board_w/2 - side_wall_th, 0 ],
77 [ -usb_w/2 - slop, front_wall_th ]);
80 module TopSmallWallsPlan() {
83 rectfromto([ -usb_w/2, -0.01 ],
84 [ -usb_w/2 + usb_wall_w, usb_tongue_d ]);
89 rectfromto(w[0], w[1]);
92 module TopCeilPlan() {
95 rectfromto([ -usb_w/2, -0.01 ],
96 [ 0.1, usb_tongue_d ]);
97 rectfromto([ -board_w/2 - side_wall_th, 0 ],
100 rectfromto(chip_cutout[0], chip_cutout[1]);
103 module TopMainWallsPlan() {
105 rectfromto([ -board_w/2 - side_wall_th, 0 ],
106 [ -board_w/2, wall_y_min ]);
108 FrontWallsPlan(usb_tongue_w_slop);
109 rectfromto([ -board_w/2 - side_wall_th + 0, - board_l ],
110 [ +board_w/2 + side_wall_th, total_y_min ]);
113 module Top(){ ////toplevel
116 linextr(0, usb_wall_h)
118 linextr(usb_wall_h - usb_ceil_th, usb_wall_h)
120 linextr(-board_th, usb_wall_h)
124 for (y_c = [strain_0_y_c, strain_1_y_c]) {
125 for (x_c = [-1,+1] * strain_pitch_across/2) {
126 translate([x_c, y_c, 0])
128 square([ strain_t, strain_w ], center=true);
131 linextr_y_xz(total_y_min-1, main_y_min)
132 translate([0, top_base_z])
133 scale([1, strain_groove_d/strain_groove_w])
134 circle(strain_groove_w/2, $fn = 8);
138 module BottomMainElevation(){ ////toplevel
140 rectfromto([ -top_side_wall_x, bottom_base_z ],
141 [ +top_side_wall_x, top_base_z ]);
144 module Bottom(){ ////toplevel
145 linextr_y_xz(total_y_min, front_y_max)
146 BottomMainElevation();
149 module BottomDemo(){ ////toplevel
151 translate([0, 0, 0.25]) %Top();