-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathBMLib.py
77 lines (54 loc) · 2.06 KB
/
BMLib.py
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
from itertools import chain
#: Multiple of notch height
IDEAL_NOTCH_WIDTH = 4
def genFrontPoints(w, h, d, t):
return chain(
genHorizontalLinePoints(0, 0, w, t, 0),
genVerticalLinePoints(w, 0, h, -t, 0),
genHorizontalLinePoints(w, h - t, -w, t, 0),
genVerticalLinePoints(0, h, -h, t, -t),
)
def genBackPoints(w, h, d, t):
return genFrontPoints(w, h, d, t)
def genLeftPoints(w, h, d, t):
return chain(
genHorizontalLinePoints(0, 0, -d, t, -t),
genVerticalLinePoints(-d + t, 0, h, -t, 0),
genHorizontalLinePoints(-d, h - t, d, t, t),
genVerticalLinePoints(-t, h, -h, t, -t),
)
def genRightPoints(w, h, d, t):
return genLeftPoints(w, h, d, t)
def genBottomPoints(w, h, d, t):
return chain(
genHorizontalLinePoints(0, -t, w, t, t),
genVerticalLinePoints(w - t, 0, -d, t, -t),
genHorizontalLinePoints(w, -d + t, -w, -t, -t),
genVerticalLinePoints(t, -d, d, -t, t),
)
def genTopPoints(w, h, d, t):
return chain(
genHorizontalLinePoints(0, 0, w, -t, 0),
genVerticalLinePoints(w, 0, -d, -t, 0),
genHorizontalLinePoints(w, -d, -w, t, 0),
genVerticalLinePoints(0, -d, d, t, 0),
)
def genHorizontalLinePoints(x, y, length, notchHeight, offset):
idealNotch = abs(notchHeight) * IDEAL_NOTCH_WIDTH
notchCount = int(abs(length) / idealNotch)
if notchCount % 2 == 0:
notchCount += 1
notchWidth = length / notchCount
# First point
yield (x + offset, y)
# Two points for every side of a notch
for i in range(1, notchCount):
x = x + notchWidth
yield (x, y if ((i % 2) == 1) else y + notchHeight)
yield (x, y if ((i % 2) == 0) else y + notchHeight)
# Last point is omitted (because it will be the first point of the next side)
def genVerticalLinePoints(x, y, length, notchHeight, offset):
# Symmetrical with the horizontal version, but with x & y swapped
points = genHorizontalLinePoints(y, x, length, notchHeight, offset)
for y, x in points:
yield (x, y)