-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathstorage.scad
132 lines (104 loc) · 3.58 KB
/
storage.scad
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
/*
Variables to modify to mess with the basics:
mdf_shelf_thickness is the thickness of the shelf material.
shelf_count is the number of shelves you want.
shelf_spacing is how much of a gap you want between each shelf.
The other variables are fairly standard, play around!
*/
// Part Definitions
mdf_shelf_thickness = 12;
mdf_shelf_width = 484;
mdf_shelf_depth = 731;
mdf_color = "red";
cls_thickness = 28;
cls_height = 38;
cls_color = "green";
studding_diameter = 10;
// Drill holes for studding
hole_fudge = 2;
hole_offset = 14;
hole_diameter = studding_diameter + hole_fudge;
// Material specs
mdf_shelves_per_mdf_sheet = 8;
full_cls_length = 2400;
shelf_spacing = 0;
shelf_count = 32;
// CLS Long lengths
cls_long_length_count = shelf_count + 1;
cls_long_length_per_cls =
floor(full_cls_length / mdf_shelf_depth);
cls_long_length_cls_count =
ceil(cls_long_length_count / cls_long_length_per_cls);
// CLS Short lengths
cls_short_length_count = (shelf_count * 2) + 2;
cls_short_length_per_cls =
floor(full_cls_length / mdf_shelf_width);
cls_short_length_cls_count =
ceil(cls_short_length_count / cls_short_length_per_cls);
// Totals
total_height = (mdf_shelf_thickness + cls_thickness)*shelf_count + (shelf_spacing * (shelf_count - 1)) + cls_thickness;
total_width = mdf_shelf_width;
total_depth = mdf_shelf_depth;
// Material Counting
total_mdf_sheets = ceil(shelf_count / mdf_shelves_per_mdf_sheet);
total_cls_lengths = ceil((cls_long_length_cls_count + cls_short_length_cls_count)/2);
// Printing Data
echo(str("Total Height: ", total_height, "mm"));
echo(str("Total Width: ", total_width, "mm"));
echo(str("Total Depth: ", total_depth, "mm"));
echo(str("MDF Shelf Count: ", shelf_count));
echo(str("CLS short length Count: ", cls_short_length_count));
echo(str("CLS long length Count: ", cls_long_length_count));
echo(str("Total MDF Sheets: ", total_mdf_sheets));
echo(str("Total CLS Lengths: ", total_cls_lengths));
// Design Layout
bottom_shelf();
for(z = [1 : shelf_count-1])
translate([
0,
0,
(mdf_shelf_thickness + cls_height + shelf_spacing) * z
])
shelf_construct();
// Modules
module bottom_shelf() {
shelf_construct();
for(y = [0,mdf_shelf_depth-cls_thickness])
translate([0,y,-cls_height])
rotate([90,0,90])
cls_bar(mdf_shelf_width);
for(x = [0,mdf_shelf_width-cls_thickness])
translate([x + cls_thickness, cls_thickness, -cls_height])
rotate([90,0,180])
cls_bar(mdf_shelf_depth - (cls_thickness * 2), "yellow");
for(x = [hole_offset, mdf_shelf_width - hole_offset])
for(y = [hole_offset, mdf_shelf_depth - hole_offset])
translate([x,y,-1])
cylinder(d=studding_diameter,h=(mdf_shelf_thickness + cls_height+ shelf_spacing)*shelf_count - shelf_spacing);
}
module shelf_construct() {
difference() {
union() {
mdf_shelf();
for(y = [0,mdf_shelf_depth-cls_thickness])
translate([0,y,mdf_shelf_thickness])
rotate([90,0,90])
cls_bar(mdf_shelf_width);
translate([cls_thickness, cls_thickness, mdf_shelf_thickness])
rotate([90,0,180])
cls_bar(mdf_shelf_depth - (cls_thickness * 2), "yellow");
}
for(x = [hole_offset, mdf_shelf_width - hole_offset])
for(y = [hole_offset, mdf_shelf_depth - hole_offset])
translate([x,y,-1])
cylinder(d=hole_diameter,h=mdf_shelf_thickness + cls_height + 2);
}
}
module mdf_shelf(my_color = mdf_color) {
color(my_color)
cube([mdf_shelf_width,mdf_shelf_depth,mdf_shelf_thickness]);
}
module cls_bar(length = 100, my_color = cls_color) {
color(my_color)
cube([cls_thickness,cls_height,length]);
}