-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathdefinitions.scad
167 lines (141 loc) · 5.35 KB
/
definitions.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
use <scad-utils/linalg.scad>
use <scad-utils/transformations.scad>
include <switch-and-keycap-specs.scad>
X = [1, 0, 0];
Y = [0, 1, 0];
Z = [0, 0, 1];
switch_type = "choc";
keycap_type = "choc";
keyhole_length = choc_keyhole_length;
keycap_width = choc_keycap_width;
keycap_depth = choc_keycap_depth;
keycap_height = choc_keycap_height;
cap_top_height = choc_keycap_top_height;
plate_thickness = 2.7;
plate_padding = [2.5, 2.5]; // horizontal and vertical padding around switches.
plate_dimensions = [
keyhole_length + plate_padding.x,
keyhole_length + plate_padding.y,
plate_thickness
];
// overall space allotted for each keycap
mount_width = keycap_width + 1;
mount_depth = keycap_depth + 1;
// angle from key-to-key in a column (alpha) and column-to-column (beta)
alpha = 180/12;
beta = 180/36;
finger_row_radius = mount_depth / 2 / sin(alpha/2) + cap_top_height;
finger_column_radius = mount_width / 2 / sin(beta/2) + cap_top_height;
thumb_row_radius = mount_depth / 2 / sin(alpha/2) + cap_top_height;
thumb_column_radius = mount_width / 2 / sin(beta/2) + cap_top_height;
// Per-column offsets for finger keys.
finger_column_offset_index = [0, 0, 0];
finger_column_offset_index_stretch = [0, 0, 0];
finger_column_offset_middle = [0, 2.82, -3.0]; // was moved -4.5
finger_column_offset_ring = [0, 0, 0];
finger_column_offset_pinky = [0, -8, 5.64];
finger_column_offset_pinky_stretch = [0, -8, 5.64];
finger_column_offsets = [
finger_column_offset_index_stretch,
finger_column_offset_index,
finger_column_offset_middle,
finger_column_offset_ring,
finger_column_offset_pinky,
finger_column_offset_pinky_stretch
];
// Per-column selection of keys an their row positions.
// Values here don't need to be integers but they probably should be.
finger_columns = [
[1, 2, 3],
[1, 2, 3, 4],
[1, 2, 3, 4],
[1, 2, 3, 4],
[1, 2, 3],
[1, 2, 3]
];
finger_overrides = [
// [5, 0, 1.5, 1, 0, 0.25, 0],
// [5, 1, 1.5, 1, 0, 0.25, 0],
// [5, 2, 1.5, 1, 0, 0.25, 0]
];
// Per-column selection of thumb keys and their row positions.
// In this case because of the 2u keys there's need to use fractional values.
thumb_columns = [
[-.5],
[-.5, 1],
[-1, 0, 1]
];
// Thumb overrides specify on a per-colum-index-and-row-index basis:
// * size multiplier (u and h)
// * rotation (in degrees)
// Note: this is only used for thumb keys and doesn't support the ergodox-style
// 1.25u outer pinky-column keys.
thumb_overrides = [
[0, 0, 1, 2, 90],
[1, 0, 1, 2, 90]
];
// Between the finger and thumb clusters is a column of LEDs positioned using
// finger key positioning and some additional offset and pivot.
led_transform = rotation([0, -60, 0]) * translation([-6, 0, 0]);
// LED size is used for $u and $h to scale the plate edge/corner pieces for
// easier and positioning.
led_size = 0.52;
// LED positioning is given with [col, row] pairs.
leds = [
[-0.75, 0.82],
[-0.75, 1.2],
[-0.75, 1.58],
[-0.75, 1.96]
];
// how thick to make the arm/clamp.
// I haven't tried other values as I didn't want to print one that's too weak
// and keep iterating. Wouldn't be a bad idea to render one and throw it into
// Fusion360 or something for finite element analysis, but I'm not an engineer.
desk_arm_thickness = 25;
desk_arm_trunc = 0.8;
desk_arm_radius = (desk_arm_thickness / 2) / desk_arm_trunc;
// These measurements are specific to the ball mount I bought.
ball_mount_diameter = 28.44;
ball_mount_height = 23.98;
// How thick to make the walls of the cylinder that the ball mount slides into.
// The desk arm actually screws into the ball mount base so this probably isn't
// adding to print strength at all.
ball_mount_socket_thickness = 3;
// What orientation should the ball mount have in the desk arm's socket.
// Tilting this gives you more clearance from the desk arm, but pay attention to
// your print orientation to ensure torque applied to the ball mount doesn't act
// on layer weakness.
ball_mount_base_orientation = identity4()
* rotation([0, 0, 90])
* rotation([50, 0, 0])
* rotation([0, 0, 180]);
// What orientation to apply to things attached to the ball mount head.
// This doesn't affect printed parts directly but is useful for visualization.
ball_mount_pivot_orientation = identity4()
* rotation([0, 30, 0]);
// The precise thickness isn't important if you want to secure the arm with a
// clamp (1/4" bolt). In fact, my preference is to leave a few millimetres of
// clearance so that you can augment your printed parts with grippier material:
// silicone/rubber sheet or even kitchen drawer liners can be used as a softer
// layer to avoid damaging the desk surface.
_DESK_THICKNESS_TURNSTONE_BIVI = 14.99; // my work desk
_DESK_THICKNESS_IKEA_SKARSTA = 22.28; // my home desk
desk_thickness = _DESK_THICKNESS_IKEA_SKARSTA;
desk_available_depth = 68.98;
// Desired offset from ball mount base to the top (ignoring thickness) of desk.
desk_top_offset = [0, 50, 40];
// Desired offset from keyboard "origin" to bottom mount component.
keyboard_offset = rotation([0, -20, 0]) * translation([30, 5, -6]);
function slice(vec, start, end) = (
let(e=is_undef(end) ? len(vec) - 1 : end)
[ for(i=[start:e]) vec[i] ]
);
// Look up thumb overrides for given column and row index
function get_overrides (source, colIndex, rowIndex) = (
let(matches = [
for(vec=source)
if (vec[0] == colIndex && vec[1] == rowIndex)
slice(vec, 2)
])
len(matches) > 0 ? matches[0] : [1, 1, 0]
);