2 % part of LilyPond's pretty-but-neat music font
4 fet_begingroup("nummer")
7 define_pixels(height,thick,thick,thin,hair);
9 foot_width#:=9/4thick#;
10 define_pixels(foot_top,foot_width);
11 define_pixels(kuulleke);
13 def calc_kuulleke(expr w,alpha) =
15 save beta; beta=(alpha-90)/2;
16 save gamma; gamma=(90+alpha)/2;
18 penpos1(w/cosd(alpha),alpha);
19 penpos2(hair,90+beta);
20 z2=z1l+(1/2hair/tand((alpha+90)/2))*dir(beta);
22 penpos3(hair,gamma-90);
23 z3=z1r-(1/2hair/tand((90-alpha)/2))*dir(gamma);
24 z4=z1+kuulleke*dir(alpha-90);
28 % should make generic macro?
30 def draw_foot(expr xpos) =
35 penpos2(foot_width,0);
42 fill z1..{right}z1r{down}..{right}z3l..z3r{left}..z5
43 ..{left}z4l..z4r{right}..{up}z1l{right}..z1..cycle;
48 set_char_box(0, 2/3height#*widen, 0, height#);
49 message "w:"&decimal w;
50 message "h:"&decimal h;
53 z1=(thick,h/2+thin-hair/2);
57 % yup, should use the path fract [] "everywhere"
61 penpos5(7/8thick,180);
64 z6r=(w-9/8thick*flaren,h);
65 penpos7(7/8thick,180);
67 penpos10(7/8thick,180);
69 penlabels(1,2,3,4,5,6,7,8,9,10,11);
71 fill z5{right}..z2r{right}..tension t..z3r{down}
72 ..tension t..z4r{left}
73 ..tension t..z7r{up}..tension t..z6r{right}
74 ..z6l{left}..tension t..z7l{down}..z10l{up}..cycle;
75 draw_flare(z6r,0,-90,hair,thick*flaren);
76 unfill z2l{right}..tension t..z3l{down}..tension t
77 ..z4l{left}..tension t..z10l{up}..tension t..cycle;
80 fet_beginchar("Numeral 0", "0", "zero")
81 % set_char_box(0, 4/5height#*widen, 0, height#);
82 set_char_box(0, 11/15height#*widen, 0, height#);
83 message "w:"&decimal w;
84 message "h:"&decimal h;
93 fill z1r..z2r..z3r..z4r..cycle;
95 unfill z1l..tension t..z2l..tension t..z3l
96 ..tension t..z4l..tension t..cycle;
99 fet_beginchar("Numeral 1", "1", "one")
100 % set_char_box(0, 19/30height#*widen, 0, height#);
101 set_char_box(0, 1/2foot_width#+3/2thick#+1/2hair#, 0, height#);
102 message "w:"&decimal w;
103 message "h:"&decimal h;
106 calc_kuulleke(thick,alpha);
107 z1=(3/2thick,height);
113 save beta; beta=angle(z1l-z6);
114 penpos7(thin,beta-90);
116 penpos8(thin/cosd(beta),-90);
118 penpos9(thin,beta-90);
119 z9r=z8r+(thin/cosd(beta))*(0,-1);
120 penlabels(1,2,3,4,5,6,7,8,9);
121 save gamma; gamma=angle(length(z1r-z1),+2kuulleke);
122 fill z2r{dir(alpha-gamma)}..z4..{dir(alpha+gamma)}z3l..z3r{down}
123 ..{down}z5r{left}..z5..{left}z5l{up}..{up}z2l..cycle;
124 fill z7l{dir(beta)}..{dir(beta)}z1l..z2r..z9r{up}
125 ..z9l{dir(180+beta)}..{dir(180+beta)}z7r..cycle;
131 fet_beginchar("Numeral 2", "2", "two")
132 set_char_box(0, 11/15height#*widen, 0, height#);
133 message "w:"&decimal w;
134 message "h:"&decimal h;
136 save alpha; alpha=-50;
138 penpos1(thin,90+beta);
139 z1=(0,0)+(1/2sqrt(2)*thin)*dir(45);
140 penpos3(hair,90+beta);
141 z3=(w,thick)+(1/2sqrt(2)*hair)*dir(-135);
142 penpos2(thick-hair,90+alpha);
143 x2-x1=x3-x2; y2=5/8thick/fatten;
145 fill z1r{dir(beta)}..{dir(alpha)}z2r..{dir(beta)}z3r
146 ..z3l{dir(180+beta)}..{dir(180+alpha)}z2l
147 ..{dir(180+beta)}z1l..cycle;
154 z6r=(1/2hair+thick,h);
156 fill z1l{dir(beta)}..z4l{dir(15)}..z5r{up}..
159 ..z6l{right}..z5l{down}..z4r{dir(180+15)}
160 ..{dir(180+beta)}z1r..cycle;
161 % nice without flaren correction...
162 draw_flare(z6r,180,90,thin,thick);
165 fet_beginchar("Numeral 3", "3", "three")
166 set_char_box(0, 2/3height#*widen, 0, height#);
167 message "w:"&decimal w;
168 message "h:"&decimal h;
171 penpos2(thick-hair,180);
172 z2l=(w-thick/8,3/4h+thick/16);
174 z3=(w/2,h/2+1/8thick);
176 z4=(1/2thick+hair,y3);
178 z5r=(w,1/4h+thick/16);
181 penpos7(thin+hair,90);
183 penlabels(1,2,3,4,5,6,7);
184 save alpha; alpha=25;
186 fill z1l{right}..tension t..z2l{down}..z7r{dir(180+alpha)}
187 ..z7l{dir(-alpha)}..z5r{down}..tension t..z6r{left}
188 ..z6l{right}..tension t..z5l{up}
189 ..tension t..z3l{left}..z4l{left}
190 ..z4r{right}..z3r{right}..tension t..z2r{up}
191 ..tension t..z1r{left}..cycle;
192 draw_flare(z1l,180,90,hair,thick*flaren);
193 draw_flare(z6r,180,-90,hair,9/8thick*flaren);
196 fet_beginchar("Numeral 4", "4", "four")
197 set_char_box(0, 4/5height#*widen, 0, height#);
198 message "w:"&decimal w;
199 message "h:"&decimal h;
202 calc_kuulleke(3/2thick,alpha);
203 z1r=(w-3thin,height);
205 z5=(thin,1/4height+thin);
206 save beta; beta=angle(z3r-z5);
211 penpos8(thin,-alpha);
213 penlabels(1,2,3,4,5,6,7);
214 save gamma; gamma=angle(length(z1r-z1),+2kuulleke);
215 fill z2r{dir(alpha-gamma)}..z4..{dir(alpha+gamma)}z3l
216 ..z3r{dir(180+beta)}..{dir(180+beta)}z8r{right}
217 ..{right}z7l..z7r{left}..{left}z6r..z8l{dir(beta)}
222 save alpha; alpha=beta;
223 calc_kuulleke(thick,alpha);
224 % z1r=(w-3thin,height-(thin+hair)/cosd(alpha));
225 z1r=(w-3thin,height-(thin+1/2hair)/cosd(alpha));
230 save gamma; gamma=angle(length(z1r-z1),+2kuulleke);
231 fill z2r{dir(alpha-gamma)}..z4..{dir(alpha+gamma)}z3l
232 ..z3r{down}..{down}z5r{left}..z5..{left}z5l{up}
234 penlabels(1,2,3,4,5);
239 fet_beginchar("Numeral 5", "5", "five")
240 set_char_box(0, 7/10height#*widen, 0, height#);
241 message "w:"&decimal w;
242 message "h:"&decimal h;
243 calc_kuulleke(w-thin,0);
247 z5l=(x1l,h-15/16thick);
249 z6=z5r+1/2hair*dir(-45);
251 z7l=(x1l,h/2+thin-hair);
252 penlabels(1,2,3,4,5,6,7);
253 save gamma; gamma=angle(length(z1r-z1),+2kuulleke);
254 fill z2r{dir(alpha-gamma)}..z4..{dir(alpha+gamma)}z3l
255 ..z3r{dir(-135)}..{left}z6r..z6l{down}..z7r{down}
256 ..z7l{up}..{up}z2l..cycle;
262 z10r=(w,1/2[y9r,y11r]);
265 penlabels(8,9,10,11);
268 fill z8r{dir(beta)}..z9r{right}..tension t..z10r{down}
269 ..tension t..z11r{left}
270 ..z11l{right}..tension t..z10l{up}..tension t
271 ..z9l{left}..z8l{dir(180+beta)}..cycle;
272 draw_flare(z11r,180,-90,hair,9/8thick*flaren);
275 fet_beginchar("Numeral 6", "6", "six")
279 fet_beginchar("Numeral 7", "7", "seven")
280 set_char_box(0, 11/15height#*widen, 0, height#);
281 message "w:"&decimal w;
282 message "h:"&decimal h;
284 save alpha; alpha=-180;
286 penpos1(3/2thick,180+alpha);
287 penpos2(hair,180+alpha-45);
288 z2=z1l+(1/4sqrt(2)*hair)*dir(alpha-135);
289 penpos3(hair,180+alpha+45);
290 z3=z1r+(1/4sqrt(2)*hair)*dir(alpha-45);
291 z4=z1+kuulleke*dir(alpha-90);
293 % shit, does not work
294 calc_kuulleke(3/2thick,-alpha);
299 penpos5(thin,90+beta);
300 z5=(w,h)+(1/2sqrt(2)*thin)*dir(-135);
302 save gamma; gamma=angle(length(z1r-z1),+2kuulleke);
303 save delta; delta=12;
305 fill z3l{dir(alpha-gamma)}..z4..{dir(alpha+gamma)}z2r..
306 z2l{dir(beta+delta)}..{dir(beta)}z5r
307 ..z5l{dir(180+beta)}..{dir(delta-90)}z3r..cycle;
308 penlabels(1,2,3,4,5);
311 save alpha; alpha=-50;
313 z1=(3/2thin,h-(thick+thin)/2);
314 penpos3(thin,90+beta);
315 z3=(w,h)+(1/2sqrt(2)*thin)*dir(-135);
316 penpos2(thick-hair,90+alpha);
317 x2-x1=x3-x2; y2=h-5/8thick/fatten;
325 z6r=(thin,y1r+thin/2);
327 fill z1r{dir(beta)}..{dir(alpha)}z2r..{dir(beta)}z3r
328 ..z3l{dir(180+beta)}..{dir(180+alpha)}z2l
329 ..{dir(180+beta)}z1l..z6l{down}..{down}z5r
330 ..z5l{up}..{up}z4l..z4r{down}..{down}z6r..{right}cycle;
331 penlabels(1,2,3,4,5,6);
334 fet_beginchar("Numeral 8", "8", "eight")
335 set_char_box(0, 11/15height#*widen, 0, height#);
336 message "w:"&decimal w;
337 message "h:"&decimal h;
338 save alpha; alpha=60;
339 save beta; beta=alpha-15;
340 z1=(w/2,h/2+thick/8);
341 penpos2(hair,90+180+beta);
347 penpos5(thick,90+90+alpha);
348 z5=z1+w/4*dir(alpha-90);
349 penpos6(thick,90+90+alpha);
350 z6=z1+(w/4-thin/2)*dir(90+alpha);
354 z8r=(w-thin/2,3/4h+thin/2);
355 penpos9(hair,90+180+beta);
357 penlabels(1,2,3,4,5,6,7,8,9);
359 fill z2r{dir(180+beta)}..z3r{down}..z4r{right}
360 ..z5r{dir(90+alpha)}..z6r{dir(90+alpha)}
361 ..tension t..z7r{right}..z8r{down}..z9r{dir(180+beta)}
362 ..z9l{dir(beta)}..z8l{up}..z7l{left}..z6l{dir(alpha-90)}
363 ..z5l{dir(alpha-90)}..tension t..z4l{left}..z3l{up}
364 ..z2l{dir(beta)}..cycle;
367 fet_beginchar("Numeral 9", "9", "nine")
370 currentpicture := currentpicture scaled -1;
371 currentpicture := currentpicture shifted (w,h);
374 fet_endgroup("nummer")