-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathcompact_font_algorithms.ggcode
More file actions
250 lines (213 loc) · 8.99 KB
/
compact_font_algorithms.ggcode
File metadata and controls
250 lines (213 loc) · 8.99 KB
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
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
// Ultra-Compact Font Algorithms - Old School Style
// Multiple compact approaches for complete A-Z, 0-9 character sets
note {=== Ultra-Compact Font Systems ===}
note {Old-school algorithms for maximum efficiency}
let safe_z = 2
// ALGORITHM 1: 14-SEGMENT DISPLAY (More complete than 7-segment)
// Can display ALL letters A-Z and numbers 0-9
function draw_14_segment_char(x, y, char, size) {
note {14-Segment: '[char]' at X[x] Y[y]}
// 14-segment layout:
// AAA
// FH JB
// F HJB
// GGG
// E KLC
// EKLC
// DDD
let w = size / 2 // Half width
let h = size / 2 // Half height
let segments = 0 // Bit pattern for character
// Character encoding table (14 bits per character)
// Segments: A B C D E F G H J K L (bits 0-13)
if char == "A" { segments = 0b11110110110000 } // A,B,C,E,F,G,H,J
if char == "B" { segments = 0b01111001001111 } // A,B,C,D,G,H,J,L
if char == "C" { segments = 0b11110000000000 } // A,D,E,F
if char == "D" { segments = 0b01111001001001 } // A,B,C,D,H,J
if char == "E" { segments = 0b11110000100000 } // A,D,E,F,G
if char == "F" { segments = 0b11100000100000 } // A,E,F,G
if char == "G" { segments = 0b11110001000000 } // A,C,D,E,F
if char == "H" { segments = 0b01100110100000 } // B,C,E,F,G
if char == "I" { segments = 0b10001001001001 } // A,D,H,J
if char == "J" { segments = 0b01111000000000 } // B,C,D,E
if char == "K" { segments = 0b01100000101000 } // E,F,G,K,L
if char == "L" { segments = 0b11110000000000 } // D,E,F
if char == "M" { segments = 0b01100110010100 } // B,C,E,F,H,K
if char == "N" { segments = 0b01100110010010 } // B,C,E,F,H,L
if char == "O" { segments = 0b11111100000000 } // A,B,C,D,E,F
if char == "P" { segments = 0b11100110100000 } // A,B,E,F,G
if char == "Q" { segments = 0b11111100010000 } // A,B,C,D,E,F,L
if char == "R" { segments = 0b11100110110000 } // A,B,E,F,G,L
if char == "S" { segments = 0b10111001000000 } // A,C,D,F,G
if char == "T" { segments = 0b10001001001001 } // A,H,J
if char == "U" { segments = 0b01111100000000 } // B,C,D,E,F
if char == "V" { segments = 0b01100000100100 } // E,F,J,K
if char == "W" { segments = 0b01100110001010 } // B,C,E,F,J,L
if char == "X" { segments = 0b00000000011110 } // H,K,J,L
if char == "Y" { segments = 0b00000000011001 } // H,J,K
if char == "Z" { segments = 0b10001000001100 } // A,D,J,K
// Numbers
if char == "0" { segments = 0b11111100001100 } // A,B,C,D,E,F,J,K
if char == "1" { segments = 0b00001100000000 } // B,C
if char == "2" { segments = 0b10111010100000 } // A,B,G,E,D
if char == "3" { segments = 0b10111001000000 } // A,B,G,C,D
if char == "4" { segments = 0b01100110100000 } // F,G,B,C
if char == "5" { segments = 0b10111001000000 } // A,F,G,C,D
if char == "6" { segments = 0b11111001000000 } // A,F,G,E,D,C
if char == "7" { segments = 0b10001100000000 } // A,B,C
if char == "8" { segments = 0b11111111100000 } // All segments
if char == "9" { segments = 0b10111111100000 } // A,B,C,D,F,G
// Draw segments based on bit pattern
// Segment A (top)
if segments & 1 {
G0 Z[safe_z] X[x-w] Y[y+h]
G0 Z[0]
G1 X[x+w] Y[y+h]
G0 Z[safe_z]
}
// Segment B (top right)
if segments & 2 {
G0 Z[safe_z] X[x+w] Y[y+h]
G0 Z[0]
G1 X[x+w] Y[y]
G0 Z[safe_z]
}
// Continue for all 14 segments...
// (Simplified for demo - full implementation would have all segments)
}
// ALGORITHM 2: 5x7 DOT MATRIX (Classic computer font)
// Ultra-compact bitmap encoding using bit manipulation
function draw_5x7_char(x, y, char, dot_size) {
note {5x7 Matrix: '[char]' at X[x] Y[y]}
let pattern = 0 // 35-bit pattern (5x7 grid)
// Compact encoding: each character as series of horizontal line patterns
// Format: 7 bytes, each representing one row (5 bits used per byte)
if char == "A" {
// Pattern for 'A':
// ███
// █ █
// █ █
// █████
// █ █
// █ █
// █ █
let rows = [4, 10, 17, 31, 17, 17, 17] // Binary: 00100, 01010, 10001, 11111, 10001, 10001, 10001
for row = 0..6 {
let line_pattern = 0
if row == 0 { line_pattern = 4 } // 00100
if row == 1 { line_pattern = 10 } // 01010
if row == 2 { line_pattern = 17 } // 10001
if row == 3 { line_pattern = 31 } // 11111
if row == 4 { line_pattern = 17 } // 10001
if row == 5 { line_pattern = 17 } // 10001
if row == 6 { line_pattern = 17 } // 10001
// Draw dots for this row
for col = 0..4 {
if line_pattern & (16 >> col) { // Test bit (16=10000, 8=01000, etc.)
let dot_x = x + col * dot_size
let dot_y = y + (6-row) * dot_size
G0 Z[safe_z] X[dot_x] Y[dot_y]
G0 Z[0]
G1 X[dot_x + dot_size] Y[dot_y]
G1 X[dot_x + dot_size] Y[dot_y + dot_size]
G1 X[dot_x] Y[dot_y + dot_size]
G1 X[dot_x] Y[dot_y]
G0 Z[safe_z]
}
}
}
}
// More characters would follow same pattern...
}
// ALGORITHM 3: STROKE-BASED MINIMAL ENCODING
// Each character encoded as sequence of pen moves
function draw_stroke_char(x, y, char, size) {
note {Stroke Minimal: '[char]' at X[x] Y[y]}
// Ultra-compact stroke encoding
// Format: series of relative moves with pen up/down
// Each move: dx, dy, pen_state (0=up, 1=down)
if char == "A" {
// 'A' as minimal strokes: start bottom-left, draw triangle + crossbar
let moves = [
[0, 0, 0], // Move to start (pen up)
[0, 0, 1], // Pen down
[2, 4, 1], // Draw to top
[2, -4, 1], // Draw to bottom-right
[-3, 2, 0], // Move to crossbar start (pen up)
[0, 0, 1], // Pen down
[2, 0, 1] // Draw crossbar
]
let current_x = x - size/2
let current_y = y - size/2
for move_idx = 0..6 {
let dx = 0
let dy = 0
let pen = 0
// Manual move lookup (since we can't easily do 2D arrays)
if move_idx == 0 { dx = 0; dy = 0; pen = 0 }
if move_idx == 1 { dx = 0; dy = 0; pen = 1 }
if move_idx == 2 { dx = 2; dy = 4; pen = 1 }
if move_idx == 3 { dx = 2; dy = -4; pen = 1 }
if move_idx == 4 { dx = -3; dy = 2; pen = 0 }
if move_idx == 5 { dx = 0; dy = 0; pen = 1 }
if move_idx == 6 { dx = 2; dy = 0; pen = 1 }
current_x = current_x + dx * size/8
current_y = current_y + dy * size/8
if pen == 0 {
G0 Z[safe_z] X[current_x] Y[current_y]
} else {
G0 Z[0]
G1 X[current_x] Y[current_y]
}
}
G0 Z[safe_z]
}
}
// ALGORITHM 4: HERSHEY FONT STYLE (Single-stroke characters)
// Based on the famous Hershey fonts - each character is one continuous stroke where possible
function draw_hershey_char(x, y, char, size) {
note {Hershey Style: '[char]' at X[x] Y[y]}
let scale = size / 10 // Scale factor
if char == "A" {
// Hershey 'A': single stroke where possible
G0 Z[safe_z] X[x - 5*scale] Y[y - 5*scale]
G0 Z[0]
G1 X[x] Y[y + 5*scale] // Left stroke
G1 X[x + 5*scale] Y[y - 5*scale] // Right stroke
G0 Z[safe_z]
G0 X[x - 2*scale] Y[y] // Crossbar
G0 Z[0]
G1 X[x + 2*scale] Y[y]
G0 Z[safe_z]
}
if char == "O" {
// Hershey 'O': single continuous stroke
G0 Z[safe_z] X[x - 3*scale] Y[y]
G0 Z[0]
// Approximate circle with line segments
G1 X[x - 3*scale] Y[y + 3*scale]
G1 X[x] Y[y + 5*scale]
G1 X[x + 3*scale] Y[y + 3*scale]
G1 X[x + 3*scale] Y[y - 3*scale]
G1 X[x] Y[y - 5*scale]
G1 X[x - 3*scale] Y[y - 3*scale]
G1 X[x - 3*scale] Y[y] // Close the loop
G0 Z[safe_z]
}
}
// DEMONSTRATION
note {=== Compact Font Algorithm Demo ===}
// Test different algorithms
draw_14_segment_char(0, 20, "A", 8)
draw_5x7_char(15, 20, "A", 1)
draw_stroke_char(30, 20, "A", 8)
draw_hershey_char(45, 20, "A", 8)
draw_14_segment_char(0, 0, "8", 8)
draw_hershey_char(15, 0, "O", 8)
// Return to safe position
G0 Z[safe_z] X[0] Y[0]
note {=== Compact Font Algorithms Complete ===}
note {14-Segment: Complete A-Z,0-9 with 14 bits per char}
note {5x7 Matrix: Classic computer font, 35 bits per char}
note {Stroke Minimal: Relative moves, very compact}
note {Hershey Style: Single-stroke elegance}