6 psu_sz = psu_sz_nom + [ 0.11, 0.44 ] + [ 0.25, 0.25 ];
8 psu_hole_pos = [ 2.05, // from back edge of psu_sz[0]
9 0.55 * 0.5 * 25.4, // from centreline
13 psu_th_for_clamp = 1.50;
15 psu_hole_dia = 2.5 - 0.5;
16 psu_connector_z = 2.9 + 0.1;
17 psu_connector_z_overlap = 0.15;
18 psu_connector_depth = 6.25;
19 psu_connector_w = 8.0 + 0.5;
22 psu_clamp_th = 4.0 + 0.75;
26 psu_board_clamp_ovlp = 4.5;
27 psu_board_nutbox = nutbox_data_M3;
30 psu_board_support_wall = 2;
31 psu_board_support_ovlp = 4.5;
32 psu_board_support_ovlp_ceil = 2;
33 psu_board_support_z = 2;
35 psu_baffle_gap = 1.0 + 0.5;
37 psu_y = +psu_sz[1]/2 + psu_usb_protr;
39 psu_usba_v_apart = 7.0;
40 psu_usba_v_from_edge = 4.86;
41 psu_usba_v_space_below = 1.5;
42 psu_usba_v_space_w = 1.7;
43 psu_usba_v_space_l = 3.0;
47 // ----- calculated -----
49 psu_z = NutBox_h_base(psu_board_nutbox);
50 psu_z_down = psu_z + 0.1;
51 psu_fix_sz = NutBox_outer_size(psu_board_nutbox);
52 psu_board_nutbox_y = psu_sz[1]/2 + psu_board_nutbox[0]/2;
54 psu_mount_outer_sz = psu_sz +
55 [ psu_board_support_wall * 2,
56 max(psu_board_support_wall,
57 psu_board_nutbox_y + psu_fix_sz/2) ];
59 module PsuBoardRepresentation(){
60 linear_extrude(height= psu_th)
61 square(center=true, [psu_sz[0],psu_sz[1]]);
64 module PsuRepresentation(){
65 PsuBoardRepresentation();
66 translate([0, -psu_sz[1]/2, -psu_connector_z])
67 linear_extrude(height= psu_connector_z + psu_connector_z_overlap)
68 rectfromto([ -psu_connector_w/2, -10 ],
69 [ +psu_connector_w/2, psu_connector_depth ]);
72 module AtPsuMountCorner(mx,my){
75 translate(-0.5 * [psu_sz[0], psu_sz[1], 0]
76 -1 * [0,0, psu_z_down])
80 module PsuMountCornerExtrude(mx,my, plus_z=psu_board_support_z){
81 AtPsuMountCorner(mx,my){
82 linear_extrude(height= psu_z_down + plus_z, convexity=10) {
88 module PsuUsbAVSpacePlan(){
89 for (x= [-1,+1] * psu_usba_v_apart/2) {
90 translate([x, -psu_usba_v_from_edge ]) {
92 for (y= [-1,+1] * 0.5 * (psu_usba_v_space_l - psu_usba_v_space_w)) {
94 circle(r= psu_usba_v_space_w);
101 module PsuMountPositiveMain(){
104 PsuMountCornerExtrude(mx,my){
105 rectfromto(-[1,1]*psu_board_support_wall,
106 +[1,1]*psu_board_support_ovlp);
109 // mount above at plug end
110 PsuMountCornerExtrude(mx,0, psu_th + psu_board_support_wall){
111 rectfromto(-[1,1]*psu_board_support_wall,
112 [psu_board_support_ovlp,
113 psu_board_support_ovlp_ceil]);
116 translate([0,0, -psu_z_down])
117 linear_extrude(psu_z_down - psu_baffle_gap, convexity=10)
121 module PsuMountNegative(){
122 axis = [0, -psu_sz[1]/2, psu_th];
125 rotate([atan(2 * psu_board_support_z / psu_sz[1]),
128 PsuBoardRepresentation();
131 module PsuMountPositive(){
134 PsuMountPositiveMain();
135 linextr_y_xz(-psu_y, psu_sz[1]*2) square(100, center=true);
140 PsuBoardRepresentation();
141 translate([0,0,5]) PsuBoardRepresentation();
143 translate([-20,0,-20]) cube(40);
147 PsuMountCornerExtrude(mx,1){
148 translate([psu_sz[0]/2 - psu_hole_pos[1],
150 + psu_board_gap * [1,1] )
151 circle(r= psu_hole_dia/2);
155 translate([0, psu_board_nutbox_y, 0])
157 NutBox(psu_board_nutbox, psu_z_down);
158 translate([0, psu_sz[1]/2, 0])
159 linextr(-psu_usba_v_space_below, +10)
164 module PsuClamp(){ ////toplevel
165 rotate([180,0,0]) difference(){
166 linear_extrude(height=psu_clamp_th + psu_th_for_clamp, convexity=5) {
169 circle(r = psu_fix_sz/2);
170 translate([ -psu_board_nutbox[0]/2, 0])
171 square(center=true, [ psu_board_clamp_ovlp*2, psu_clamp_w ]);
173 circle(r = psu_board_nutbox[0]/2);
176 translate([0,0,-1]) linear_extrude(height=psu_th_for_clamp+1) {
177 translate([ -psu_board_nutbox[0]/2 + psu_clamp_gap, 0 ])
179 translate([0,-20]) square(40);
183 translate([0, -psu_board_nutbox[0]/2])
189 module PsuLedWindowsPlan(){
191 PsuLedWindowsPlanCore();
196 module PsuMountDemo() { ////toplevel
197 ceil = psu_test_ceil;
199 translate([0, psu_y, psu_z]) {
207 color("yellow") translate([0,0, -psu_z - ceil])
208 linear_extrude(height=0.4, convexity=10)
211 color("blue") translate([0,0, -psu_z - ceil])
212 linear_extrude(height=0.4, convexity=10)
215 translate([0, psu_board_nutbox_y, 10])
222 module PsuMountTest() { ////toplevel
223 ceil = psu_test_ceil;
228 translate([0, psu_y, psu_z])
231 linextr_x_yz(-(psu_sz[0]/2 + 5),
234 rectfromto([0, -ceil], [psu_sz[1] + 10, psu_z + 10]);
235 rectfromto([ceil,0], 400*[1,1]);
238 translate([0, psu_y, psu_z]) {
243 translate([0, psu_y, psu_z]) {
250 psu_multicolour_gap = 0.075;
251 psu_initial_layer_thick = 0.400;
252 psu_initial_layer_width = 0.750;
253 psu_window_ledge = 0.50; // each side
255 module PsuMountTestFullLayerFrame(ix) {
256 sz = psu_sz*2 + [1,1]*psu_initial_layer_width*(3+ix);
257 translate([0, psu_y]) difference(){
258 square(center=true, sz + 2*[1,1]*psu_initial_layer_width);
259 square(center=true, sz);
264 module PsuMountTestFullMain() { ////toplevel
265 ceil = psu_test_ceil;
267 linextr(0, psu_initial_layer_thick)
268 PsuMountTestFullLayerFrame(2);
271 translate([0,0, ceil])
274 translate([0, psu_y, 0]) {
275 linextr(-1, psu_initial_layer_thick) {
276 offset(delta=psu_window_ledge + psu_multicolour_gap)
278 offset(delta=psu_multicolour_gap)
285 module PsuMountTestFullOneLayer(ix) {
286 linextr(0, psu_initial_layer_thick) {
287 PsuMountTestFullLayerFrame(ix);
288 translate([0, psu_y]) children();
292 module PsuMountTestFullText() { ////toplevel
293 PsuMountTestFullOneLayer(0)
296 module PsuMountTestFullWindows() { ////toplevel
297 PsuMountTestFullOneLayer(1)
298 offset(delta=psu_window_ledge)
302 module PsuMountTestFullDemo() { ////toplevel
303 color("blue") PsuMountTestFullMain();
304 color("yellow") PsuMountTestFullText();
305 %PsuMountTestFullWindows();