forked from jeremybennett/scad-examples
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathclip-frame-holder.scad
176 lines (131 loc) · 5.18 KB
/
clip-frame-holder.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
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
// A4 clip frame stand
// Copyright (C) 2015 Jeremy Bennett <[email protected]>
// Contributor: Jeremy Bennett <[email protected]>
// This file is licensed under the Creative Commons Attribution-ShareAlike 3.0
// Unported License. To view a copy of this license, visit
// http://creativecommons.org/licenses/by-sa/3.0/ or send a letter to Creative
// Commons, PO Box 1866, Mountain View, CA 94042, USA.
// 45678901234567890123456789012345678901234567890123456789012345678901234567890
// This is a tetrahedron, with the front face 5 degrees back from vertical and
// a slot in the base for the clip. We build it as a cube, tilt it, then
// slice bits off to make the tetrahedron.
// Base dimensions
WIDTH = 210.0; // Frame width
HEIGHT = 297.0; // Frame depth
DEPTH = 3.5; // Frame thickness
TILT = 10; // How much to tilt back
CLIP_W = 15; // Clip width
CLIP_H = 40; // Clip height
CLIP_D = 8; // Clip depth
// Derived dimensions
base_w = WIDTH / 3;
base_h = HEIGHT / 3;
base_d = base_w;
clear_d = DEPTH * 1.2; // Allow some play in frame thickness
// The basic cube with a ledge. Face is on X-Z plane, base is on X-Y plane,
// face centered on Y-Z plane, with ledge sticking forward
module base_holder () {
// Dimensions for the ledge
ledge_w = base_w;
ledge_h = clear_d * 2;
ledge_d = ledge_h;
// Dimensions for groove in the ledge
groove_w = ledge_w;
groove_h = clear_d;
groove_d = groove_h;
difference () {
union () {
// The base cube
translate (v = [-base_w / 2, 0, 0])
cube (size = [base_w, base_d, base_h], center = false);
// Ledge allow to extend below, to allow for tilt
translate (v = [-ledge_w / 2, -ledge_d, -ledge_h])
cube (size = [ledge_w, ledge_d, ledge_h * 2], center = false);
}
// Groove in the ledge
translate (v = [-groove_w / 2, -groove_d, ledge_h - groove_h])
cube (size = [groove_w, groove_d, groove_h], center = false);
// Slot for clip. Also extends below to allow for tilt
translate (v = [-CLIP_W / 2, -base_d + CLIP_D, groove_h])
cube (size = [CLIP_W, base_d, CLIP_H], center = false);
}
}
// A cube rotated around Y to slice off the side.
// @param direction Which direction to rotate.
module side_slice (direction) {
// Amount to tilt to ensure meeting at the top
angle = direction * atan ((base_w / 2) / base_h);
rotate (a = [0, angle, 0])
translate (v = [-direction * base_w / 2, 0, 0])
cube (size = [base_w, base_d * 4, base_h * 4], center = true);
}
// A cube rotated around X to slice off the back
module back_slice () {
// Amount to tilt to ensure meeting at the top
angle = atan (base_d / base_h) - TILT;
rotate (a = [angle, 0, 0])
translate (v = [0, base_d, 0])
cube (size = [base_w * 2, base_d * 2, base_h * 4], center = true);
}
// A triangular prism for slicing out of the middle
module triangular_prism () {
prism_w = base_w * 2;
prism_h = base_h / 2;
prism_d = base_w / 2;
sliced_height = prism_h * 0.8;
difference () {
rotate (a = [-TILT, 0, 0])
translate (v = [-prism_w / 2, 0, 0])
cube (size = [prism_w, prism_d, prism_h], center = false);
// Subtract cube for the base
translate (v = [-base_w, 0, -base_h])
cube (size = [base_w * 2, base_d * 2, base_h], center = false);
// Subtract cube for the back
translate (v = [0, prism_d, 0])
back_slice ();
// Cube to slice off to top
translate (v = [-prism_w / 2, 0, sliced_height])
cube (size = [prism_w, prism_d, prism_h], center = false);
}
}
// The full holder
// The base is tipped back, then triangles are cut away. And have a flat top,
// because printing a point is a bad idea.
// To save weight, we take a triangular prism out of the centre.
module full_holder () {
sliced_height = base_h * 0.8;
difference () {
rotate (a = [-TILT, 0, 0])
base_holder ();
// Cube to slice the base. Ensure wide enough
translate (v = [-base_w, -base_d * 2, -base_h])
cube (size = [base_w * 2, base_d * 4, base_h], center = false);
// Cubes to slice off the sides
translate (v = [base_w / 2, 0, 0])
side_slice (-1);
translate (v = [-base_w / 2, 0, 0])
side_slice (+1);
// Cube to slice off the back
translate (v = [0, base_d, 0])
back_slice ();
// Cube to slice off to top
translate (v = [-base_w / 2, 0, sliced_height])
cube (size = [base_w, base_d, base_h], center = false);
// Triangular prism to save weight
translate (v = [0, base_d / 4.5, base_h / 6])
triangular_prism ();
}
}
// Finally we add some curves to the corners
module holder () {
o = base_w / 2;
a = (base_d) / 2;
cyl_rad = sqrt (o * o + a * a) - clear_d;
intersection () {
full_holder ();
translate (v = [0, base_d / 2 - clear_d, 0])
cylinder (r = cyl_rad, h = base_h);
}
}
// Print out the base
holder ();