usb_w = 12.01 + 0.19;
usb_wall_w = 0.51;
usb_tongue_d = 8.97 - 0.2;
+usb_tongue_w_slop = +0.5;
usb_wall_h = 4.54 - 2.04;
usb_ceil_th = 0.425;
front_wall_th = 0.75;
// egress_w = 8.0;
-wall_y_min = -board_l - side_wall_th;;
+wall_y_min = -board_l - side_wall_th; // XXXX remove
+main_y_min = -board_l - side_wall_th;
ceil_y_min = wall_y_min - 5;;
small_walls = [
// [ [3.0, -11.72], [sw_to_edge, -13.38] ],
[ [-sw_to_edge+3.85, -14.90], [sw_to_edge, -13.38] ],
];
-chip_cutout = [[ -sw_to_edge + 4.20, -4.50 ],
+chip_cutout = [[ -sw_to_edge + 4.20, -3.75 ],
[ -sw_to_edge + 11.95, -11.90 ]];
+strain_w = 2.0 + 0.5;
+strain_t = 1.0 + 0.5;
+strain_pitch_across = 5;
+strain_pitch_along = 10;
+strain_groove_d = 2;
+strain_groove_w = 3;
+
+fit_gap_z = 0.5;
+
+// calculated
+
+top_top_z = usb_wall_h;
+top_base_z = -board_th;
+
+strain_0_y_c = main_y_min - strain_w/2;
+strain_1_y_c = strain_0_y_c - strain_pitch_along;
+total_y_min = strain_1_y_c - strain_w/2 - side_wall_th;
+
+bottom_wall_top_z = (top_top_z + top_base_z) * 0.5 - fit_gap_z/2;
+cover_wall_top_z = (top_top_z + top_base_z) * 0.5 + fit_gap_z/2;
+
+bop_side_wall_x = +board_w/2 + side_wall_th;
+
module BothSides(){
for (m=[0,1]) {
mirror([m,0]) {
}
}
}
+module FrontWallsPlan(slop) {
+ BothSides(){
+ rectfromto([ -board_w/2 - side_wall_th, 0 ],
+ [ -usb_w/2 - slop, front_wall_th ]);
+ }
+}
module TopSmallWallsPlan() {
for (m=[0,1]) {
mirror([m,0]) {
[ -usb_w/2 + usb_wall_w, usb_tongue_d ]);
}
}
+ FrontWallsPlan(0);
for (w=small_walls) {
rectfromto(w[0], w[1]);
}
BothSides(){
rectfromto([ -board_w/2 - side_wall_th, 0 ],
[ -board_w/2, wall_y_min ]);
- rectfromto([ -board_w/2 - side_wall_th, 0 ],
- [ -usb_w/2, front_wall_th ]);
}
-// rectfromto([ -board_w/2 - side_wall_th + egress_w, -board_l ],
-// [ +board_w/2 + side_wall_th, wall_y_min ]);
+ FrontWallsPlan(usb_tongue_w_slop);
+ rectfromto([ -board_w/2 - side_wall_th + 0, - board_l ],
+ [ +board_w/2 + side_wall_th, total_y_min ]);
}
-module Top(){
- linextr(0, usb_wall_h)
- TopSmallWallsPlan();
- linextr(usb_wall_h - usb_ceil_th, usb_wall_h)
- TopCeilPlan();
- linextr(-board_th, usb_wall_h)
- TopMainWallsPlan();
+module Top(){ ////toplevel
+ difference(){
+ union(){
+ linextr(0, usb_wall_h)
+ TopSmallWallsPlan();
+ linextr(usb_wall_h - usb_ceil_th, usb_wall_h)
+ TopCeilPlan();
+ linextr(-board_th, usb_wall_h)
+ TopMainWallsPlan();
+ }
+
+ for (y_c = [strain_0_y_c, strain_1_y_c]) {
+ for (x_c = [-1,+1] * strain_pitch_across/2) {
+ translate([x_c, y_c, 0])
+ linextr(-20, 20)
+ square([ strain_t, strain_w ], center=true);
+ }
+ }
+ linextr_y_xz(total_y_min-1, main_y_min)
+ translate([0, top_base_z])
+ scale([1, strain_groove_d/strain_groove_w])
+ circle(strain_groove_w/2, $fn = 8);
+ }
}
-Top();
+module BottomMainElevation(){ ////toplevel
+ difference(){
+// rectfromto([
+ }
+}
+module Bottom(){ ////toplevel
+}