diff --git a/mod/case_rack.scad b/mod/case_rack.scad index b39f8f3..aab3551 100644 --- a/mod/case_rack.scad +++ b/mod/case_rack.scad @@ -1,6 +1,6 @@ /* This file is part of SBC Case Builder https://github.com/hominoids/SBC_Case_Builder - Copyright 2022,2023,2024 Edward A. Kisiel hominoid@cablemi.com + Copyright 2025 Edward A. Kisiel hominoid@cablemi.com This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -19,7 +19,7 @@ NAME: case_rack - DESCRIPTION: creates a 1u-2u rack case + DESCRIPTION: creates 1u-2u rack cases TODO: none USAGE: case_rack(case_design,side) @@ -99,39 +99,6 @@ if(case_design == "rack" && side == "bottom") { panel_clamp("bottom", "m2", "sloped", 6, 18, 5, [false,10,2,"default"]); } - // case lower assembly blocks - // rear left - left side - translate([150-gap-wallthick-rack_asm_size,-gap-adj,floorthick-adj]) - cube([rack_asm_size,rack_asm_size,rack_asm_size]); - // rear left - right side - translate([150-gap-wallthick+rack_asm_gap,-gap-adj,floorthick-adj]) - cube([rack_asm_size,rack_asm_size,rack_asm_size]); - if(rack_width == 19) { - // rear right - right - translate([300-gap-wallthick+rack_asm_gap,-gap-adj,floorthick-adj]) - cube([rack_asm_size,rack_asm_size,rack_asm_size]); - // rear right - left side - translate([300-gap-wallthick-rack_asm_size,-gap-adj,floorthick-adj]) - cube([rack_asm_size,rack_asm_size,rack_asm_size]); - } - - // front left - left - translate([150-gap-wallthick-rack_asm_size,depth-gap-(2*wallthick)-rack_asm_size+adj, - floorthick-adj]) cube([rack_asm_size,rack_asm_size,rack_asm_size]); - // front left - right - translate([150-gap-wallthick+rack_asm_gap, - depth-gap-(2*wallthick)-rack_asm_size+adj,floorthick-adj]) - cube([rack_asm_size,rack_asm_size,rack_asm_size]); - if(rack_width == 19) { - // front right - right - translate([300-gap-wallthick+rack_asm_gap, - depth-gap-(2*wallthick)-rack_asm_size+adj,floorthick-adj]) - cube([rack_asm_size,rack_asm_size,rack_asm_size]); - // front right - left - translate([300-gap-wallthick-rack_asm_size,depth-gap-(2*wallthick)-rack_asm_size+adj, - floorthick-adj]) cube([rack_asm_size,rack_asm_size,rack_asm_size]); - } - // additive accessories if(accessory_name != "none") { for (i=[1:11:len(accessory_data[a[0]])-1]) { @@ -154,56 +121,6 @@ if(case_design == "rack" && side == "bottom") { } } } - // case lower block assembly holes - // rear left - translate([150-gap-wallthick-rack_asm_size-adj,-gap-adj+(rack_asm_size/2), - floorthick-adj+(rack_asm_size/2)]) rotate([0,90,0]) - cylinder(d=rack_asm_hole, h=rack_asm_gap+(2*rack_asm_size)+(2*adj)); - // rear left nut - translate([150-gap-wallthick-rack_asm_size-adj,-gap-adj+(rack_asm_size/2), - floorthick-adj+(rack_asm_size/2)]) rotate([0,90,0]) - cylinder(d=4*2/sqrt(3), h=2, $fn=6); - // rear left recess - translate([150-gap-wallthick+rack_asm_size+adj+rack_asm_gap-2,-gap-adj+(rack_asm_size/2), - floorthick-adj+(rack_asm_size/2)]) rotate([0,90,0]) - cylinder(d=4*2/sqrt(3), h=2); - // rear right - translate([300-gap-wallthick-rack_asm_size-adj,-gap-adj+(rack_asm_size/2), - floorthick-adj+(rack_asm_size/2)]) rotate([0,90,0]) - cylinder(d=rack_asm_hole, h=rack_asm_gap+(2*rack_asm_size)+(2*adj)); - // rear right nut - translate([300-gap-wallthick-rack_asm_size-adj,-gap-adj+(rack_asm_size/2), - floorthick-adj+(rack_asm_size/2)]) rotate([0,90,0]) - cylinder(d=4*2/sqrt(3), h=2, $fn=6); - // rear right recess - translate([300-gap-wallthick+rack_asm_size+adj+rack_asm_gap-2,-gap-adj+(rack_asm_size/2), - floorthick-adj+(rack_asm_size/2)]) rotate([0,90,0]) - cylinder(d=4*2/sqrt(3), h=2); - // front left - translate([150-gap-wallthick-rack_asm_size-adj,depth-gap-(2*wallthick)-(rack_asm_size/2)+adj, - floorthick-adj+(rack_asm_size/2)]) rotate([0,90,0]) - cylinder(d=rack_asm_hole, h=rack_asm_gap+(2*rack_asm_size)+(2*adj)); - // front left nut - translate([150-gap-wallthick-rack_asm_size-adj,depth-gap-(2*wallthick)-(rack_asm_size/2)+adj, - floorthick-adj+(rack_asm_size/2)]) rotate([0,90,0]) - cylinder(d=4*2/sqrt(3), h=2, $fn=6); - // front left recess - translate([150-gap-wallthick+rack_asm_size+adj+rack_asm_gap-2,depth-gap-(2*wallthick)-(rack_asm_size/2)+adj, - floorthick-adj+(rack_asm_size/2)]) rotate([0,90,0]) - cylinder(d=4*2/sqrt(3), h=2); - // front right - translate([300-gap-wallthick-rack_asm_size-adj,depth-gap-(2*wallthick)+adj-(rack_asm_size/2), - floorthick-adj+(rack_asm_size/2)]) rotate([0,90,0]) - cylinder(d=rack_asm_hole, h=rack_asm_gap+(2*rack_asm_size)+(2*adj)); - // front right nut - translate([300-gap-wallthick-rack_asm_size-adj,depth-gap-(2*wallthick)-(rack_asm_size/2)+adj, - floorthick-adj+(rack_asm_size/2)]) rotate([0,90,0]) - cylinder(d=4*2/sqrt(3), h=2, $fn=6); - // front right recess - translate([300-gap-wallthick+rack_asm_size+adj+rack_asm_gap-2,depth-gap-(2*wallthick)-(rack_asm_size/2)+adj, - floorthick-adj+(rack_asm_size/2)]) rotate([0,90,0]) - cylinder(d=4*2/sqrt(3), h=2); - // pcb and multi-pcb standoff holes for(r = [0:len(rack_bay_sbc)-1]) { if(rack_bay_sbc[r] != "empty" && rack_bay_face[r] != "removable") { @@ -725,10 +642,20 @@ if(case_design == "rack" && side == "bottom") { } // rear grommet openings grommet_offset = -75+11; - if(rack_bay_rear_conduit[r] == true) { + if(rack_bay_rear_conduit[r] == "grommet" || rack_bay_rear_conduit[r] == "grommets-vertical") { translate([-gap-wallthick-1+rack_asm_gap/2+75*(r+1)+grommet_offset+4,depth-wallthick-gap,13]) grommet("front", "sleeve", 10, 4, wallthick, true, [true,10,0,"default"]); } + if(rack_bay_rear_conduit[r] == "grommets-vertical") { + translate([-gap-wallthick-1+rack_asm_gap/2+75*(r+1)+grommet_offset+4,depth-wallthick-gap,30]) + grommet("front", "sleeve", 10, 4, wallthick, true, [true,10,0,"default"]); + } + if(rack_bay_rear_conduit[r] == "conduit") { + translate([-gap-wallthick-1+rack_asm_gap/2+75*(r+1)+grommet_offset+1.5,depth-gap-wallthick+adj,5]) + rotate([90,0,0]) slab([5,30,wallthick+2*adj],2.5); + translate([-gap-wallthick-1+rack_asm_gap/2+75*(r+1)+grommet_offset+4,depth-gap-wallthick+adj,30]) + rotate([90,0,0]) cylinder(d=15, h=2*(wallthick+adj)); + } // front vent if(rack_bay_face[r] == "vent") { translate([-gap-wallthick-1+rack_asm_gap/2+75*(r+1)-75+14,-gap-adj,case_z-16]) @@ -801,7 +728,6 @@ if(case_design == "rack" && side == "bottom") { } } } - } // ui access panel if(bottom_access_panel_enable == true) { @@ -854,34 +780,6 @@ if(case_design == "rack" && side == "bottom") { translate([pcb_loc_x ,pcb_loc_y,bottom_height-pcb_z+pcb_loc_z-adj]) rotate([0,0,rack_bay_rotation[r]]) sbc(rack_bay_sbc[r], cooling, fan_size, gpio_opening, uart_opening, true); } - // indents - if(indents == true) { - for (i=[1:11:len(sbc_data[s[0]])-2]) { - class = sbc_data[s[0]][i+1]; - type = sbc_data[s[0]][i+2]; - pcbid = sbc_data[s[0]][i+3]; - pcbloc_x = sbc_data[s[0]][i+4]; - pcbloc_y = sbc_data[s[0]][i+5]; - pcbloc_z = sbc_data[s[0]][i+6]; - if(class == "pcb") { - for (i=[1:11:len(sbc_data[s[0]])-2]) { - class = sbc_data[s[0]][i+1]; - type = sbc_data[s[0]][i+2]; - id = sbc_data[s[0]][i+3]; - loc_x = sbc_data[s[0]][i+4]+pcb_loc_x+pcbloc_x; - loc_y = sbc_data[s[0]][i+5]+pcb_loc_y+pcbloc_y; - loc_z = sbc_data[s[0]][i+6]+pcb_loc_z+pcbloc_z; - side = sbc_data[s[0]][i+7]; - rotation = sbc_data[s[0]][i+8]; - if(id == pcbid) { - indent(loc_x, loc_y, bottom_height+loc_z-adj, rotation[2], side, class, - type, wallthick, gap, floorthick, pcb_z); - } - } - } - } - } - // case divide translate([150-gap-wallthick,-gap-wallthick-1,-adj]) cube([rack_asm_gap,depth+2,case_z+2*adj]); translate([300-gap-wallthick,-gap-wallthick-1,-adj]) cube([rack_asm_gap,depth+2,case_z+2*adj]); @@ -939,6 +837,90 @@ if(case_design == "rack" && side == "bottom") { floorthick], access_panel_orientation, [false,10,2,"default"]); } } + // case lower assembly blocks + difference() { + union() { + // rear left - left side + translate([150-gap-wallthick-rack_asm_size,-gap-adj,floorthick-adj]) + cube([rack_asm_size,rack_asm_size,rack_asm_size]); + // rear left - right side + translate([150-gap-wallthick+rack_asm_gap,-gap-adj,floorthick-adj]) + cube([rack_asm_size,rack_asm_size,rack_asm_size]); + if(rack_width == 19) { + // rear right - right + translate([300-gap-wallthick+rack_asm_gap,-gap-adj,floorthick-adj]) + cube([rack_asm_size,rack_asm_size,rack_asm_size]); + // rear right - left side + translate([300-gap-wallthick-rack_asm_size,-gap-adj,floorthick-adj]) + cube([rack_asm_size,rack_asm_size,rack_asm_size]); + } + // front left - left + translate([150-gap-wallthick-rack_asm_size,depth-gap-(2*wallthick)-rack_asm_size+adj, + floorthick-adj]) cube([rack_asm_size,rack_asm_size,rack_asm_size]); + // front left - right + translate([150-gap-wallthick+rack_asm_gap, + depth-gap-(2*wallthick)-rack_asm_size+adj,floorthick-adj]) + cube([rack_asm_size,rack_asm_size,rack_asm_size]); + if(rack_width == 19) { + // front right - right + translate([300-gap-wallthick+rack_asm_gap, + depth-gap-(2*wallthick)-rack_asm_size+adj,floorthick-adj]) + cube([rack_asm_size,rack_asm_size,rack_asm_size]); + // front right - left + translate([300-gap-wallthick-rack_asm_size,depth-gap-(2*wallthick)-rack_asm_size+adj, + floorthick-adj]) cube([rack_asm_size,rack_asm_size,rack_asm_size]); + } + } + // case lower block assembly holes + // rear left + translate([150-gap-wallthick-rack_asm_size-adj,-gap-adj+(rack_asm_size/2), + floorthick-adj+(rack_asm_size/2)]) rotate([0,90,0]) + cylinder(d=rack_asm_hole, h=rack_asm_gap+(2*rack_asm_size)+(2*adj)); + // rear left nut + translate([150-gap-wallthick-rack_asm_size-adj,-gap-adj+(rack_asm_size/2), + floorthick-adj+(rack_asm_size/2)]) rotate([0,90,0]) + cylinder(d=4*2/sqrt(3), h=2, $fn=6); + // rear left recess + translate([150-gap-wallthick+rack_asm_size+adj+rack_asm_gap-2,-gap-adj+(rack_asm_size/2), + floorthick-adj+(rack_asm_size/2)]) rotate([0,90,0]) + cylinder(d=4*2/sqrt(3), h=2); + // rear right + translate([300-gap-wallthick-rack_asm_size-adj,-gap-adj+(rack_asm_size/2), + floorthick-adj+(rack_asm_size/2)]) rotate([0,90,0]) + cylinder(d=rack_asm_hole, h=rack_asm_gap+(2*rack_asm_size)+(2*adj)); + // rear right nut + translate([300-gap-wallthick-rack_asm_size-adj,-gap-adj+(rack_asm_size/2), + floorthick-adj+(rack_asm_size/2)]) rotate([0,90,0]) + cylinder(d=4*2/sqrt(3), h=2, $fn=6); + // rear right recess + translate([300-gap-wallthick+rack_asm_size+adj+rack_asm_gap-2,-gap-adj+(rack_asm_size/2), + floorthick-adj+(rack_asm_size/2)]) rotate([0,90,0]) + cylinder(d=4*2/sqrt(3), h=2); + // front left + translate([150-gap-wallthick-rack_asm_size-adj,depth-gap-(2*wallthick)-(rack_asm_size/2)+adj, + floorthick-adj+(rack_asm_size/2)]) rotate([0,90,0]) + cylinder(d=rack_asm_hole, h=rack_asm_gap+(2*rack_asm_size)+(2*adj)); + // front left nut + translate([150-gap-wallthick-rack_asm_size-adj,depth-gap-(2*wallthick)-(rack_asm_size/2)+adj, + floorthick-adj+(rack_asm_size/2)]) rotate([0,90,0]) + cylinder(d=4*2/sqrt(3), h=2, $fn=6); + // front left recess + translate([150-gap-wallthick+rack_asm_size+adj+rack_asm_gap-2,depth-gap-(2*wallthick)-(rack_asm_size/2)+adj, + floorthick-adj+(rack_asm_size/2)]) rotate([0,90,0]) + cylinder(d=4*2/sqrt(3), h=2); + // front right + translate([300-gap-wallthick-rack_asm_size-adj,depth-gap-(2*wallthick)+adj-(rack_asm_size/2), + floorthick-adj+(rack_asm_size/2)]) rotate([0,90,0]) + cylinder(d=rack_asm_hole, h=rack_asm_gap+(2*rack_asm_size)+(2*adj)); + // front right nut + translate([300-gap-wallthick-rack_asm_size-adj,depth-gap-(2*wallthick)-(rack_asm_size/2)+adj, + floorthick-adj+(rack_asm_size/2)]) rotate([0,90,0]) + cylinder(d=4*2/sqrt(3), h=2, $fn=6); + // front right recess + translate([300-gap-wallthick+rack_asm_size+adj+rack_asm_gap-2,depth-gap-(2*wallthick)-(rack_asm_size/2)+adj, + floorthick-adj+(rack_asm_size/2)]) rotate([0,90,0]) + cylinder(d=4*2/sqrt(3), h=2); + } } } @@ -968,12 +950,27 @@ module bay_tray(depth, bay) { translate([reminsert-4,(depth/2)-gap-wallthick+3.75,-adj]) cylinder(d=20, h=7); } - // left assembly block opening + // rear assembly block opening + // rear left translate([2-2*rack_asm_size,depth-wallthick-1.25,-adj]) cube([.125+(2*rack_asm_size),rack_asm_size,rack_asm_size]); - // right assembly block opening + // rear middle translate([2+baysize-2*rack_asm_size,depth-wallthick-1.25,-adj]) cube([.125+(2*rack_asm_size),rack_asm_size,rack_asm_size]); + // rear right + translate([2+2*baysize-2*rack_asm_size+1.25-.25,depth-wallthick-1.25,-adj]) + cube([.125+(2*rack_asm_size),rack_asm_size,rack_asm_size]); + // front assembly block opening + // front left + translate([2-2*rack_asm_size,-gap,-adj]) + cube([.125+(2*rack_asm_size),rack_asm_size,rack_asm_size]); + // front middle + if((bay == 1 || bay) == 3 && reminsert/9 > 10) + translate([2+baysize-2*rack_asm_size,-gap,-adj]) + cube([.125+(2*rack_asm_size),rack_asm_size,rack_asm_size]); + // front right + translate([2+2*baysize-2*rack_asm_size+1.25-.25,-gap,-adj]) + cube([.125+(2*rack_asm_size),rack_asm_size,rack_asm_size]); // front vent if(rack_bay_face[bay] == "removable") { diff --git a/sbc_case_builder.json b/sbc_case_builder.json index 95f44f4..3666af1 100644 --- a/sbc_case_builder.json +++ b/sbc_case_builder.json @@ -11048,19 +11048,19 @@ "pcb_loc_y": "0", "pcb_loc_z": "0", "rack_bay1_face": "vent", - "rack_bay1_rear_conduit": "true", + "rack_bay1_rear_conduit": "grommet", "rack_bay1_rear_fan": "true", "rack_bay1_rotation": "270", "rack_bay1_wall": "false", "rack_bay1_xyz_loc": "[11, 0, 0]", "rack_bay2_face": "vent", - "rack_bay2_rear_conduit": "true", + "rack_bay2_rear_conduit": "grommet", "rack_bay2_rear_fan": "true", "rack_bay2_rotation": "270", "rack_bay2_wall": "false", "rack_bay2_xyz_loc": "[84, 0, 0]", "rack_bay3_face": "vent", - "rack_bay3_rear_conduit": "true", + "rack_bay3_rear_conduit": "grommet", "rack_bay3_rear_fan": "true", "rack_bay3_rotation": "270", "rack_bay3_wall": "false", @@ -11138,7 +11138,7 @@ "Rack_Bay1": "c4", "Rack_Bay2": "c4", "Rack_Bay3": "c4", - "Rack_Bay4": "empty", + "Rack_Bay4": "c4", "Rack_Bay5": "c4", "Rack_Bay6": "c4", "access_panel_location": "[10, 15]", @@ -11308,41 +11308,41 @@ "pcb_loc_x": "0", "pcb_loc_y": "0", "pcb_loc_z": "0", - "rack_bay1_face": "removable", - "rack_bay1_rear_conduit": "true", + "rack_bay1_face": "vent", + "rack_bay1_rear_conduit": "grommet", "rack_bay1_rear_fan": "true", "rack_bay1_rotation": "270", "rack_bay1_wall": "true", - "rack_bay1_xyz_loc": "[10, 0, 0]", + "rack_bay1_xyz_loc": "[13.5, 0, 0]", "rack_bay2_face": "vent", - "rack_bay2_rear_conduit": "true", + "rack_bay2_rear_conduit": "grommet", "rack_bay2_rear_fan": "true", "rack_bay2_rotation": "270", "rack_bay2_wall": "true", - "rack_bay2_xyz_loc": "[87, 0, 0]", - "rack_bay3_face": "removable", - "rack_bay3_rear_conduit": "true", + "rack_bay2_xyz_loc": "[88, 0, 0]", + "rack_bay3_face": "vent", + "rack_bay3_rear_conduit": "grommet", "rack_bay3_rear_fan": "true", "rack_bay3_rotation": "270", - "rack_bay3_wall": "false", - "rack_bay3_xyz_loc": "[10, 0, 0]", - "rack_bay4_face": "removable", - "rack_bay4_rear_conduit": "true", + "rack_bay3_wall": "true", + "rack_bay3_xyz_loc": "[163.5, 0, 0]", + "rack_bay4_face": "vent", + "rack_bay4_rear_conduit": "grommet", "rack_bay4_rear_fan": "true", "rack_bay4_rotation": "270", "rack_bay4_wall": "true", - "rack_bay4_xyz_loc": "[10, 0, 0]", - "rack_bay5_face": "open", - "rack_bay5_rear_conduit": "true", + "rack_bay4_xyz_loc": "[238, 0, 0]", + "rack_bay5_face": "vent", + "rack_bay5_rear_conduit": "grommet", "rack_bay5_rear_fan": "true", "rack_bay5_rotation": "270", "rack_bay5_wall": "true", - "rack_bay5_xyz_loc": "[313, 0, 0]", - "rack_bay6_face": "fixed", - "rack_bay6_rear_conduit": "true", + "rack_bay5_xyz_loc": "[313.5, 0, 0]", + "rack_bay6_face": "vent", + "rack_bay6_rear_conduit": "grommet", "rack_bay6_rear_fan": "true", "rack_bay6_rotation": "270", - "rack_bay6_xyz_loc": "[386, 0, 0]", + "rack_bay6_xyz_loc": "[386.5, 0, 0]", "rack_size": "1u", "rack_width": "19", "raise_top": "0", diff --git a/sbc_case_builder.scad b/sbc_case_builder.scad index 54536a2..5ee4fd5 100644 --- a/sbc_case_builder.scad +++ b/sbc_case_builder.scad @@ -85,7 +85,7 @@ rack_bay1_rotation = 0; // [0:90:270] rack_bay1_face = "vent"; //["open","fixed","removable","vent"] rack_bay1_wall = false; // [true,false] rack_bay1_rear_fan = false; //[true,false] -rack_bay1_rear_conduit = false; //[true,false] +rack_bay1_rear_conduit = "grommet"; //["none","conduit","grommet","grommets-vertical"] Rack_Bay2 = "empty"; // ["empty", "c1+", "c2", "c4", "hc4", "xu4", "xu4q", "mc1", "hc1", "n1", "n2", "n2+", "n2l", "n2lq", "m1", "m1s", "m2", "h2", "h2+", "h3", "h3+", "h4", "h4+", "h4_ultra", "show2", "rpipico", "rpipicow", "rpicm4+ioboard", "rpicm1", "rpicm3", "rpicm3l", "rpicm3+", "rpicm4s", "rpicm4", "rpicm4l", "rpizero", "rpizerow", "rpizero2w", "rpi1a+", "rpi1b+", "rpi2b", "rpi3a+", "rpi3b", "rpi3b+", "rpi4b", "rpi5", "a64", "a64lts", "rock64", "rockpro64", "quartz64a", "quartz64b", "h64b", "star64", "soedge_a-baseboard", "soedge_rk1808", "rock4a", "rock4b", "rock4a+", "rock4b+", "rock4c", "rock4c+", "rock5b-v1.3", "rock5b", "rock5bq", "rock5b+", "nio12l", "vim1", "vim2", "vim3", "vim3l", "vim4", "tinkerboard", "tinkerboard-s", "tinkerboard-2", "tinkerboard-2s", "tinkerboard-r2", "tinkerboard-r2s", "opizero", "opizero2", "opir1plus_lts", "opir1", "opi5", "opi5max", "jetsonnano", "lepotato", "sweetpotato", "tritium-h2+", "tritium-h3", "tritium-h5", "solitude", "alta", "atomicpi", "visionfive2", "visionfive2q", "bpif3", "milk-v_duos", "licheerv+dock", "rak19007", "cnano-avr128da48", "nodemcu-32s", "cs-solarmeter", "feather-m0_express", "feather-m0_wifi", "feather-m4_express"] rack_bay2_xyz_loc = [0,0,0]; // [0:.5:450] @@ -93,7 +93,7 @@ rack_bay2_rotation = 0; // [0:90:270] rack_bay2_face = "vent"; //["open","fixed","removable","vent"] rack_bay2_wall = false; // [true,false] rack_bay2_rear_fan = false; //[true,false] -rack_bay2_rear_conduit = false; //[true,false] +rack_bay2_rear_conduit = "grommet"; //["none","conduit","grommet","grommets-vertical"] Rack_Bay3 = "empty"; // ["empty", "c1+", "c2", "c4", "hc4", "xu4", "xu4q", "mc1", "hc1", "n1", "n2", "n2+", "n2l", "n2lq", "m1", "m1s", "m2", "h2", "h2+", "h3", "h3+", "h4", "h4+", "h4_ultra", "show2", "rpipico", "rpipicow", "rpicm4+ioboard", "rpicm1", "rpicm3", "rpicm3l", "rpicm3+", "rpicm4s", "rpicm4", "rpicm4l", "rpizero", "rpizerow", "rpizero2w", "rpi1a+", "rpi1b+", "rpi2b", "rpi3a+", "rpi3b", "rpi3b+", "rpi4b", "rpi5", "a64", "a64lts", "rock64", "rockpro64", "quartz64a", "quartz64b", "h64b", "star64", "soedge_a-baseboard", "soedge_rk1808", "rock4a", "rock4b", "rock4a+", "rock4b+", "rock4c", "rock4c+", "rock5b-v1.3", "rock5b", "rock5bq", "rock5b+", "nio12l", "vim1", "vim2", "vim3", "vim3l", "vim4", "tinkerboard", "tinkerboard-s", "tinkerboard-2", "tinkerboard-2s", "tinkerboard-r2", "tinkerboard-r2s", "opizero", "opizero2", "opir1plus_lts", "opir1", "opi5", "opi5max", "jetsonnano", "lepotato", "sweetpotato", "tritium-h2+", "tritium-h3", "tritium-h5", "solitude", "alta", "atomicpi", "visionfive2", "visionfive2q", "bpif3", "milk-v_duos", "licheerv+dock", "rak19007", "cnano-avr128da48", "nodemcu-32s", "cs-solarmeter", "feather-m0_express", "feather-m0_wifi", "feather-m4_express"] rack_bay3_xyz_loc = [0,0,0]; // [0:.5:450] @@ -101,7 +101,7 @@ rack_bay3_rotation = 0; // [0:90:270] rack_bay3_face = "vent"; //["open","fixed","removable","vent"] rack_bay3_wall = false; // [true,false] rack_bay3_rear_fan = false; //[true,false] -rack_bay3_rear_conduit = false; //[true,false] +rack_bay3_rear_conduit = "grommet"; //["none","conduit","grommet","grommets-vertical"] Rack_Bay4 = "empty"; // ["empty", "c1+", "c2", "c4", "hc4", "xu4", "xu4q", "mc1", "hc1", "n1", "n2", "n2+", "n2l", "n2lq", "m1", "m1s", "m2", "h2", "h2+", "h3", "h3+", "h4", "h4+", "h4_ultra", "show2", "rpipico", "rpipicow", "rpicm4+ioboard", "rpicm1", "rpicm3", "rpicm3l", "rpicm3+", "rpicm4s", "rpicm4", "rpicm4l", "rpizero", "rpizerow", "rpizero2w", "rpi1a+", "rpi1b+", "rpi2b", "rpi3a+", "rpi3b", "rpi3b+", "rpi4b", "rpi5", "a64", "a64lts", "rock64", "rockpro64", "quartz64a", "quartz64b", "h64b", "star64", "soedge_a-baseboard", "soedge_rk1808", "rock4a", "rock4b", "rock4a+", "rock4b+", "rock4c", "rock4c+", "rock5b-v1.3", "rock5b", "rock5bq", "rock5b+", "nio12l", "vim1", "vim2", "vim3", "vim3l", "vim4", "tinkerboard", "tinkerboard-s", "tinkerboard-2", "tinkerboard-2s", "tinkerboard-r2", "tinkerboard-r2s", "opizero", "opizero2", "opir1plus_lts", "opir1", "opi5", "opi5max", "jetsonnano", "lepotato", "sweetpotato", "tritium-h2+", "tritium-h3", "tritium-h5", "solitude", "alta", "atomicpi", "visionfive2", "visionfive2q", "bpif3", "milk-v_duos", "licheerv+dock", "rak19007", "cnano-avr128da48", "nodemcu-32s", "cs-solarmeter", "feather-m0_express", "feather-m0_wifi", "feather-m4_express"] rack_bay4_xyz_loc = [0,0,0]; // [0:.5:450] @@ -109,7 +109,7 @@ rack_bay4_rotation = 0; // [0:90:270] rack_bay4_face = "vent"; //["open","fixed","removable","vent"] rack_bay4_wall = false; // [true,false] rack_bay4_rear_fan = false; //[true,false] -rack_bay4_rear_conduit = false; //[true,false] +rack_bay4_rear_conduit = "grommet"; //["none","conduit","grommet","grommets-vertical"] Rack_Bay5 = "empty"; // ["empty", "c1+", "c2", "c4", "hc4", "xu4", "xu4q", "mc1", "hc1", "n1", "n2", "n2+", "n2l", "n2lq", "m1", "m1s", "m2", "h2", "h2+", "h3", "h3+", "h4", "h4+", "h4_ultra", "show2", "rpipico", "rpipicow", "rpicm4+ioboard", "rpicm1", "rpicm3", "rpicm3l", "rpicm3+", "rpicm4s", "rpicm4", "rpicm4l", "rpizero", "rpizerow", "rpizero2w", "rpi1a+", "rpi1b+", "rpi2b", "rpi3a+", "rpi3b", "rpi3b+", "rpi4b", "rpi5", "a64", "a64lts", "rock64", "rockpro64", "quartz64a", "quartz64b", "h64b", "star64", "soedge_a-baseboard", "soedge_rk1808", "rock4a", "rock4b", "rock4a+", "rock4b+", "rock4c", "rock4c+", "rock5b-v1.3", "rock5b", "rock5bq", "rock5b+", "nio12l", "vim1", "vim2", "vim3", "vim3l", "vim4", "tinkerboard", "tinkerboard-s", "tinkerboard-2", "tinkerboard-2s", "tinkerboard-r2", "tinkerboard-r2s", "opizero", "opizero2", "opir1plus_lts", "opir1", "opi5", "opi5max", "jetsonnano", "lepotato", "sweetpotato", "tritium-h2+", "tritium-h3", "tritium-h5", "solitude", "alta", "atomicpi", "visionfive2", "visionfive2q", "bpif3", "milk-v_duos", "licheerv+dock", "rak19007", "cnano-avr128da48", "nodemcu-32s", "cs-solarmeter", "feather-m0_express", "feather-m0_wifi", "feather-m4_express"] rack_bay5_xyz_loc = [0,0,0]; // [0:.5:450] @@ -117,14 +117,14 @@ rack_bay5_rotation = 0; // [0:90:270] rack_bay5_face = "vent"; //["open","fixed","removable","vent"] rack_bay5_wall = false; // [true,false] rack_bay5_rear_fan = false; //[true,false] -rack_bay5_rear_conduit = false; //[true,false] +rack_bay5_rear_conduit = "grommet"; //["none","conduit","grommet","grommets-vertical"] Rack_Bay6 = "empty"; // ["empty", "c1+", "c2", "c4", "hc4", "xu4", "xu4q", "mc1", "hc1", "n1", "n2", "n2+", "n2l", "n2lq", "m1", "m1s", "m2", "h2", "h2+", "h3", "h3+", "h4", "h4+", "h4_ultra", "show2", "rpipico", "rpipicow", "rpicm4+ioboard", "rpicm1", "rpicm3", "rpicm3l", "rpicm3+", "rpicm4s", "rpicm4", "rpicm4l", "rpizero", "rpizerow", "rpizero2w", "rpi1a+", "rpi1b+", "rpi2b", "rpi3a+", "rpi3b", "rpi3b+", "rpi4b", "rpi5", "a64", "a64lts", "rock64", "rockpro64", "quartz64a", "quartz64b", "h64b", "star64", "soedge_a-baseboard", "soedge_rk1808", "rock4a", "rock4b", "rock4a+", "rock4b+", "rock4c", "rock4c+", "rock5b-v1.3", "rock5b", "rock5bq", "rock5b+", "nio12l", "vim1", "vim2", "vim3", "vim3l", "vim4", "tinkerboard", "tinkerboard-s", "tinkerboard-2", "tinkerboard-2s", "tinkerboard-r2", "tinkerboard-r2s", "opizero", "opizero2", "opir1plus_lts", "opir1", "opi5", "opi5max", "jetsonnano", "lepotato", "sweetpotato", "tritium-h2+", "tritium-h3", "tritium-h5", "solitude", "alta", "atomicpi", "visionfive2", "visionfive2q", "bpif3", "milk-v_duos", "licheerv+dock", "rak19007", "cnano-avr128da48", "nodemcu-32s", "cs-solarmeter", "feather-m0_express", "feather-m0_wifi", "feather-m4_express"] rack_bay6_xyz_loc = [0,0,0]; // [0:.5:450] rack_bay6_rotation = 0; // [0:90:270] rack_bay6_face = "vent"; //["open","fixed","removable","vent"] rack_bay6_rear_fan = false; //[true,false] -rack_bay6_rear_conduit = false; //[true,false] +rack_bay6_rear_conduit = "grommet"; //["none","conduit","grommet","grommets-vertical"] /* [3D Case Adjustments] */ // sbc location x axis @@ -611,22 +611,33 @@ if (view == "platter") { if(case_design == "rack") { case_rack(case_design,"bottom"); // rear fan covers - for(r = [0:len(rack_bay_sbc)-1]) { + ucount = rack_width == 10 ? 3 : len(rack_bay_sbc)-1; + for(r = [0:ucount-1]) { fan_offset = -75+(75-rear_fan_size)/2; if(rack_bay_rear_fan[r] == true) { translate([-gap-wallthick-1+.125+75*(r+1)+fan_offset+8, - depth+10,(case_z-rear_fan_size)/2]) + -80,(case_z-rear_fan_size)/2]) fan_cover(rear_fan_size, wallthick, rear_cooling); } } - // rear grommets - for(r = [0:len(rack_bay_sbc)-1]) { - grommet_offset = -75+11; - if(rack_bay_rear_conduit[r] == true) { - translate([-gap-wallthick-1+.125+75*(r+1)+grommet_offset,depth+30,0]) - color("lightgrey") grommet("bottom", "sleeve", 10, r+2, wallthick, true, [false,10,0,"default"]); + // rear grommets + for(r = [0:len(rack_bay_sbc)-1]) { + grommet_offset = -75+11; + if(rack_bay_rear_conduit[r] == "grommet") { + translate([0,-50,0]) rotate([270,0,0]) difference() { + translate([-gap-wallthick-1+.125+75*(r+1)+grommet_offset,0,0]) + grommet("bottom", "sleeve", 10, r+2, wallthick, false, [false,10,0,"default"]); + translate([-gap-wallthick-1+.125+75*(r+1)+grommet_offset-10,-.125,-3]) cube([20,10,20]); + } + translate([0,-30,0]) rotate([270,0,0]) difference() { + translate([-gap-wallthick-1+.125+75*(r+1)+grommet_offset,0,0]) + grommet("bottom", "sleeve", 10, r+2, wallthick, false, [false,10,0,"default"]); + translate([-gap-wallthick-1+.125+75*(r+1)+grommet_offset-10,-.125,-3]) cube([20,10,20]); + } + translate([-gap-wallthick-1+.125+75*(r+1)+grommet_offset,-70,0]) + grommet_clip("sleeve", 10, r+2, wallthick); + } } - } } if(case_design == "adapter_mini-stx_thin" || case_design == "adapter_mini-stx" || case_design == "adapter_mini-itx_thin" || case_design == "adapter_mini-itx" || case_design == "adapter_flex-atx" || case_design == "adapter_mini-dtx" || case_design == "adapter_dtx" || case_design == "adapter_micro-atx" || case_design == "adapter_atx" || case_design == "adapter_ssi-ceb" || case_design == "adapter_ssi-eeb") { color("dimgrey",1) case_adapter(case_design); @@ -1140,83 +1151,80 @@ if (view == "model") { cube([gap+wallthick+1,depth+2,case_z+2]); } } - } + } + ucount = rack_width == 10 ? 3 : len(rack_bay_sbc)-1; // rear fan covers - for(r = [0:len(rack_bay_sbc)-1]) { + for(r = [0:ucount-1]) { fan_offset = -75+(75-rear_fan_size)/2; if(rack_bay_rear_fan[r] == true) { translate([-gap-wallthick-1+.125+75*(r+1)+fan_offset+8, depth-gap,(case_z-rear_fan_size)/2]) rotate([90,0,0]) fan_cover(rear_fan_size, wallthick, rear_cooling); } - } // rear grommets - for(r = [0:len(rack_bay_sbc)-1]) { - grommet_offset = -75+11; - if(rack_bay_rear_conduit[r] == true) { - translate([-gap-wallthick-1+.125+75*(r+1)+grommet_offset+4,depth-wallthick-gap,13]) - color("lightgrey") grommet("front", "sleeve", 10, 4, wallthick, true, [false,10,0,"default"]); - } + grommet_offset = -75+11; + if(rack_bay_rear_conduit[r] == "grommet" || rack_bay_rear_conduit[r] == "grommets-vertical") { + translate([-gap-wallthick-1+.125+75*(r+1)+grommet_offset+4,depth-wallthick-gap,13]) + color("lightgrey") grommet("front", "sleeve", 10, 4, wallthick, true, [false,10,0,"default"]); } - // bay inserts - for(r = [0:len(rack_bay_sbc)-1]) { - bayadj = r == 0 ? -74 : -75.5; - if(rack_bay_face[r] == "removable" && r ==0 && rack_bay_sbc[r] != "empty") { - color("gray") translate([bayadj+75*(r+1),0,floorthick]) - bay_tray(depth-2*wallthick-gap-.5-tol,r); - } -// if(rack_bay_face[r] == "removable" && r !=0 && rack_bay_face[r-1] == "removable") { -// color("gray") translate([bayadj+75*(r+1),0,floorthick]) -// bay_tray(depth-2*wallthick-gap-.5-tol,r); -// } - if(rack_bay_face[r] == "removable" && r !=0 && rack_bay_sbc[r] != "empty") { - color("gray") translate([bayadj+75*(r+1),0,floorthick]) - bay_tray(depth-2*wallthick-gap-.5-tol,r); - } + if(rack_bay_rear_conduit[r] == "grommets-vertical") { + translate([-gap-wallthick-1+.125+75*(r+1)+grommet_offset+4,depth-wallthick-gap,30]) + color("lightgrey") grommet("front", "sleeve", 10, 4, wallthick, true, [false,10,0,"default"]); } - if(sbc_off == false) { - for(i = [0:len(rack_bay_sbc)-1]) { - if(rack_bay_sbc[i] != "empty" && rack_bay_face[i] != "removable") { - s = search([rack_bay_sbc[i]],sbc_data); - pcb_loc_z = rack_bay_xyz_loc[i][2]; - pcb_id = sbc_data[s[0]][4]; - pcb_width = sbc_data[s[0]][10][0]; - pcb_depth = sbc_data[s[0]][10][1]; - pcb_z_orig = sbc_data[s[0]][10][2]; - pcb_tmaxz = sbc_data[s[0]][11][5]; - pcb_bmaxz = sbc_data[s[0]][11][6]; - pcb_color = sbc_data[s[0]][11][1]; - pcb_radius = sbc_data[s[0]][11][0]; + // bay inserts + bayadj = r == 0 ? -74 : -75.5; + if(rack_bay_face[r] == "removable" && r ==0 && rack_bay_sbc[r] != "empty") { + color("gray") translate([bayadj+75*(r+1),0,floorthick]) + bay_tray(depth-2*wallthick-gap-.5-tol,r); + } + if(rack_bay_face[r] == "removable" && r !=0 && rack_bay_sbc[r] != "empty") { + color("gray") translate([bayadj+75*(r+1),0,floorthick]) + bay_tray(depth-2*wallthick-gap-.5-tol,r); + } + } + if(sbc_off == false) { + for(i = [0:len(rack_bay_sbc)-1]) { + if(rack_bay_sbc[i] != "empty" && rack_bay_face[i] != "removable") { + s = search([rack_bay_sbc[i]],sbc_data); + pcb_loc_z = rack_bay_xyz_loc[i][2]; + pcb_id = sbc_data[s[0]][4]; + pcb_width = sbc_data[s[0]][10][0]; + pcb_depth = sbc_data[s[0]][10][1]; + pcb_z_orig = sbc_data[s[0]][10][2]; + pcb_tmaxz = sbc_data[s[0]][11][5]; + pcb_bmaxz = sbc_data[s[0]][11][6]; + pcb_color = sbc_data[s[0]][11][1]; + pcb_radius = sbc_data[s[0]][11][0]; - pcb_loc_x = rack_bay_rotation[i] == 90 ? rack_bay_xyz_loc[i][0] + pcb_width : rack_bay_rotation[i] == 180 ? rack_bay_xyz_loc[i][0] + pcb_width : rack_bay_xyz_loc[i][0]; - pcb_loc_y = rack_bay_rotation[i] == 270 ? rack_bay_xyz_loc[i][1]+pcb_width : rack_bay_rotation[i] == 180 ? rack_bay_xyz_loc[i][1]+pcb_depth : rack_bay_xyz_loc[i][1]; - translate([pcb_loc_x ,pcb_loc_y,bottom_height-pcb_z+pcb_loc_z-adj]) - rotate([0,0,rack_bay_rotation[i]]) - sbc(rack_bay_sbc[i], cooling, fan_size, gpio_opening, uart_opening, false); - } - if(rack_bay_sbc[i] != "empty" && rack_bay_face[i] == "removable") { - bayadj = i == 0 ? -74 : -75.5; - s = search([rack_bay_sbc[i]],sbc_data); - pcb_loc_z = rack_bay_xyz_loc[i][2]; - pcb_id = sbc_data[s[0]][4]; - pcb_width = sbc_data[s[0]][10][0]; - pcb_depth = sbc_data[s[0]][10][1]; - pcb_z_orig = sbc_data[s[0]][10][2]; - pcb_tmaxz = sbc_data[s[0]][11][5]; - pcb_bmaxz = sbc_data[s[0]][11][6]; - pcb_color = sbc_data[s[0]][11][1]; - pcb_radius = sbc_data[s[0]][11][0]; + pcb_loc_x = rack_bay_rotation[i] == 90 ? rack_bay_xyz_loc[i][0] + pcb_width : rack_bay_rotation[i] == 180 ? rack_bay_xyz_loc[i][0] + pcb_width : rack_bay_xyz_loc[i][0]; + pcb_loc_y = rack_bay_rotation[i] == 270 ? rack_bay_xyz_loc[i][1]+pcb_width : rack_bay_rotation[i] == 180 ? rack_bay_xyz_loc[i][1]+pcb_depth : rack_bay_xyz_loc[i][1]; + translate([pcb_loc_x ,pcb_loc_y,bottom_height-pcb_z+pcb_loc_z-adj]) + rotate([0,0,rack_bay_rotation[i]]) + sbc(rack_bay_sbc[i], cooling, fan_size, gpio_opening, uart_opening, false); + } + if(rack_bay_sbc[i] != "empty" && rack_bay_face[i] == "removable") { + bayadj = i == 0 ? -74 : -75.5; + s = search([rack_bay_sbc[i]],sbc_data); + pcb_loc_z = rack_bay_xyz_loc[i][2]; + pcb_id = sbc_data[s[0]][4]; + pcb_width = sbc_data[s[0]][10][0]; + pcb_depth = sbc_data[s[0]][10][1]; + pcb_z_orig = sbc_data[s[0]][10][2]; + pcb_tmaxz = sbc_data[s[0]][11][5]; + pcb_bmaxz = sbc_data[s[0]][11][6]; + pcb_color = sbc_data[s[0]][11][1]; + pcb_radius = sbc_data[s[0]][11][0]; - pcb_loc_x = rack_bay_rotation[i] == 90 ? rack_bay_xyz_loc[i][0] + pcb_width : - rack_bay_rotation[i] == 180 ? rack_bay_xyz_loc[i][0] + pcb_width : - rack_bay_xyz_loc[i][0]; - pcb_loc_y = rack_bay_rotation[i] == 270 ? rack_bay_xyz_loc[i][1]+pcb_width : - rack_bay_rotation[i] == 180 ? rack_bay_xyz_loc[i][1]+pcb_depth : - rack_bay_xyz_loc[i][1]; + pcb_loc_x = rack_bay_rotation[i] == 90 ? rack_bay_xyz_loc[i][0] + pcb_width : + rack_bay_rotation[i] == 180 ? rack_bay_xyz_loc[i][0] + pcb_width : + rack_bay_xyz_loc[i][0]; + pcb_loc_y = rack_bay_rotation[i] == 270 ? rack_bay_xyz_loc[i][1]+pcb_width : + rack_bay_rotation[i] == 180 ? rack_bay_xyz_loc[i][1]+pcb_depth : + rack_bay_xyz_loc[i][1]; - translate([pcb_loc_x+bayadj+75*(i+1) ,pcb_loc_y+wallthick+gap, - bottom_height-pcb_z+pcb_loc_z-adj+floorthick]) rotate([0,0,rack_bay_rotation[i]]) - sbc(rack_bay_sbc[i], cooling, fan_size, gpio_opening, uart_opening, false); + translate([pcb_loc_x+bayadj+75*(i+1) ,pcb_loc_y+wallthick+gap, + bottom_height-pcb_z+pcb_loc_z-adj+floorthick]) rotate([0,0,rack_bay_rotation[i]]) + sbc(rack_bay_sbc[i], cooling, fan_size, gpio_opening, uart_opening, false); } } } @@ -1435,7 +1443,8 @@ if (view == "part") { } if(case_design == "rack") { // rear fan covers - for(r = [0:len(rack_bay_sbc)-1]) { + ucount = rack_width == 10 ? 3 : len(rack_bay_sbc)-1; + for(r = [0:ucount-1]) { fan_offset = -75+(75-rear_fan_size)/2; if(rack_bay_rear_fan[r] == true) { translate([-gap-wallthick-1+.125+75*(r+1)+fan_offset+8,0,0]) @@ -1445,7 +1454,7 @@ if (view == "part") { // rear grommets for(r = [0:len(rack_bay_sbc)-1]) { grommet_offset = -75+11; - if(rack_bay_rear_conduit[r] == true) { + if(rack_bay_rear_conduit[r] == "grommet") { translate([0,0,0]) rotate([270,0,0]) difference() { translate([-gap-wallthick-1+.125+75*(r+1)+grommet_offset,0,0]) grommet("bottom", "sleeve", 10, r+2, wallthick, false, [false,10,0,"default"]);