1 % feta-nummer.mf -- implement bold Orator numerals
3 % part of LilyPond's pretty-but-neat music font
5 % source file of the Feta (not the Font-En-Tja) music font
7 % (c) 1997--2004 Jan Nieuwenhuizen <janneke@gnu.org>
10 % These numbers were taken from a part that that the EJE violas played
11 % 1997 -- Probably Mendelssohn's ouverture Heimkehr aus der Fremde.
15 % TODO all the invocation of flare_path are weird --
16 % the horizontal tangents should be more at the center of the
20 define_pixels(height,thick,thick,thin,hair,flare);
21 define_pixels(foot_top,foot_width);
22 define_pixels(kuulleke);
25 % Yet Another Bulb Routine with smooth inside curve.
27 % alpha = start direction.
28 % beta = which side to turn to.
29 % flare = diameter of the bulb
30 % line = diameter of line attachment
31 % direction = is ink on left or right side (1 or -1)
35 % move_away_to = amount left (for 2)
36 % turn_to = amount down (for 2 )
38 def number_flare_path(expr pos,alpha,beta,line,flare,
41 turn_to, taille, taille_ratio,
46 % z5 = z2 + 0.43* flare *dir (alpha - 1.5 beta);
48 z4 = (0.75 - taille) [z2r, z2l] + whatever* dir (alpha - beta) ;
49 z4 = (taille_ratio * taille) [z3l, z3r] + whatever* dir(alpha);
50 penpos1(line,180+beta+alpha);
53 z2r = z1r + move_away_to *dir (alpha) + (line + turn_to) * dir(alpha+beta);
54 z3r = 0.5 [z2l,z2r] + 0.5 *flare *dir(alpha + beta);
56 penpos2(flare, alpha );
57 penpos3(flare, alpha + beta);
58 penlabels(1, 2, 3, 4, 5);
64 .. z2r{dir(180+alpha-beta)}
65 .. z3r{dir(alpha+180)}
66 .. z2l{dir(alpha-beta)}
69 %%% Two versions of the curve: one with z4, the other with z5.
70 % .. z5{dir(alpha- beta/2 )}
71 ..z4{dir(180+alpha+beta)}
72 ..z1l{dir(alpha+180)};
84 def calc_kuulleke(expr w,alpha) =
86 save beta; beta=(alpha-90)/2;
87 save gamma; gamma=(90+alpha)/2;
89 penpos1(w/cosd(alpha),alpha);
90 penpos2(hair,90+beta);
91 z2=z1l+(1/2hair/tand((alpha+90)/2))*dir(beta);
93 penpos3(hair,gamma-90);
94 z3=z1r-(1/2hair/tand((90-alpha)/2))*dir(gamma);
95 z4=z1+kuulleke*dir(alpha-90);
99 % should make generic macro?
101 def draw_foot(expr xpos) =
106 penpos2(foot_width,0);
114 fill z1..{right}z1r{down}..{right}z3l..z3r{left}..z5
115 ..{left}z4l..z4r{right}..{up}z1l{right}..z1..cycle;
120 set_char_box(0, .68 height#*widen, 0, height#);
121 message "w:"&decimal w;
122 message "h:"&decimal h;
125 z1=(thick,h/2+thin-hair/2);
130 penpos3 (15/16 thick,0);
131 % yup, should use the path fract [] "everywhere"
146 penlabels(1,2,3,4,5,6,7,8,9,10,11);
149 save outer_t; outer_t= 0.88;
153 z7{right}..z2r{right}
160 % .. flare_path (z6r,0,-90,hair,flare, 1)
161 .. number_flare_path (z6r, 0,-90,hair,flare,
162 w - x6r -hair/2, .16 h, 0.05, 2.5, 1)
166 .. {down}z10l -- cycle;
168 unfill z2l{right}..tension t..z3l{down}..tension t
169 ..z4l{left}..tension t..z10l{up}..tension t..cycle;
173 dot_diam# = 7/8flare#;
174 define_pixels(dot_diam);
177 fet_beginchar("Space", "space", "space")
178 set_char_box(0, space#, 0,height#);
184 fet_beginchar("Numeral comma", "comma", "comma")
185 set_char_box(0, dot_diam#, 3/2dot_diam#, dot_diam#);
186 pickup pencircle scaled dot_diam;
187 draw (dot_diam/2,dot_diam/2);
190 penpos1(thin,alpha+90);
191 z1l=(w/2,-1.5h+hair);
194 filldraw z1l{dir(alpha)}..{up}z2..{z0-z2}z0{right}..{dir(180+alpha)}z1r..cycle;
199 fet_beginchar("Numeral dash", "hyphen", "hyphen")
200 set_char_box(0, height#/3, 0, height#);
201 pickup pencircle scaled thin;
208 fet_beginchar("Numeral dot", "period", "period")
209 set_char_box(0, dot_diam#, 0, dot_diam#);
210 pickup pencircle scaled dot_diam;
211 draw (dot_diam/2,dot_diam/2);
219 fet_beginchar("Numeral 0", "zero", "zero")
220 set_char_box(0, 11/15height# * widen, 0, height#);
221 message "w:"&decimal w;
222 message "h:"&decimal h;
231 fill z1r..z2r..z3r..z4r..cycle;
234 unfill z1l..tension t..z2l..tension t..z3l
235 ..tension t..z4l..tension t..cycle;
238 fet_beginchar("Numeral 1", "one", "one")
239 % set_char_box(0, 19/30height#*widen, 0, height#);
240 set_char_box(0, 1/2foot_width#+3/2thick#+1/2hair#, 0, height#);
241 message "w:"&decimal w;
242 message "h:"&decimal h;
245 calc_kuulleke(thick,alpha);
246 z1=(3/2thick,height);
252 save beta; beta=angle(z1l-z6);
253 penpos7(thin,beta-90);
255 penpos8(thin/cosd(beta),-90);
257 penpos9(thin,beta-90);
258 z9r=z8r+(thin/cosd(beta))*(0,-1);
259 penlabels(1,2,3,4,5,6,7,8,9);
260 save gamma; gamma=angle(length(z1r-z1),+2kuulleke);
261 fill z2r{dir(alpha-gamma)}..z4..{dir(alpha+gamma)}z3l..z3r{down}
262 ..{down}z5r{left}..z5..{left}z5l{up}..{up}z2l..cycle;
263 fill z7l{dir(beta)}..{dir(beta)}z1l..z2r..z9r{up}
264 ..z9l{dir(180+beta)}..{dir(180+beta)}z7r..cycle;
270 fet_beginchar("Numeral 2", "two", "two")
271 set_char_box(0, 22/30 height#*widen, 0, height#);
272 message "w:"&decimal w;
273 message "h:"&decimal h;
275 save alpha; alpha=-45*widen;
277 save gamma; gamma=beta-10;
278 save flare_start_distance;
281 save theta; theta=20/widen;
282 penpos1(hair,90+beta);
283 z1=(0,0)+(1/2sqrt(2)*hair)*dir(45);
284 penpos3(hair,90+gamma);
285 z3=(w,thick)+(1/2sqrt(2)*hair)*dir(-135);
286 penpos2(thick, 90+alpha -15);
288 y2=10/16 thick/widen;
289 fill z1r{dir(beta)}.. tension 0.9 .. {dir(alpha + 10)}z2r..{dir(gamma)}z3r
290 ..z3l{dir(180+gamma)}..{dir(180+alpha - 5)}z2l
291 ..{dir(180+beta)}z1l..cycle;
294 z4r=(w-thin/2, .71 h);
305 p := z1l{dir(beta)}..tension t..z4r{up}
306 .. number_flare_path(z5r,180,90,hair, 1.05 flare,
308 .21 h, 0.006, 0.4, 1)
309 .. z4l{down}..tension t
310 ..{dir(180+beta)}z1r..cycle;
312 pickup pencircle scaled 1;
320 % TODO: should widen a bit. The right edge of the 3 bumps into next glyph in
323 fet_beginchar("Numeral 3", "three", "three")
324 set_char_box(0, 2/3height#*widen, 0, height#);
325 message "w:"&decimal w;
326 message "h:"&decimal h;
329 % flare_start = 0.25 ;
333 % z1l=(17/16thick,h);
334 penpos2(7/8thick,180);
336 y2l = 3/4h + thick* 3/32;
338 z3=(w/2,h/2+1/8thick);
340 z4=(5/8thick+1/2thin,y3);
343 y5r = 17/64 h + thick/16;
352 penlabels(1,2,3,4,5,6,7);
353 save alpha; alpha=25;
355 save outer_t; outer_t := 0.93;
356 pickup pencircle scaled 1;
360 number_flare_path (z1l, 180, 90, hair, 7/8 flare, x1l - .5 hair,
361 .16 h, 0.06, 1.5, -1)
365 ..z7r{dir(180+alpha)}
370 .. number_flare_path (z6r, 180, -90, hair, flare, x6l,
388 fet_beginchar("Numeral 4", "four", "four")
389 set_char_box(0, 4/5height#*widen, 0, height#);
390 message "w:"&decimal w;
391 message "h:"&decimal h;
394 calc_kuulleke(3/2thick,alpha);
395 z1r=(w-3/4thick,height);
397 z5=(thin,1/4height+thin);
398 save beta; beta=angle(z3r-z5);
403 penpos8(thin,-alpha);
405 penlabels(1,2,3,4,5,6,7);
406 save gamma; gamma=angle(length(z1r-z1),+2kuulleke);
407 fill z2r{dir(alpha-gamma)}..z4..{dir(alpha+gamma)}z3l
408 ..z3r{dir(180+beta)}..{dir(180+beta)}z8r{right}
409 ..{right}z7l..z7r{left}..{left}z6r..z8l{dir(beta)}
414 save alpha; alpha=beta;
415 calc_kuulleke(thick,alpha);
416 z1r=(w-3/4thick,height-(3/2thin)/cosd(alpha));
421 save gamma; gamma=angle(length(z1r-z1),+2kuulleke);
422 fill z2r{dir(alpha-gamma)}..z4..{dir(alpha+gamma)}z3l
423 ..z3r{down}..{down}z5r{left}..z5..{left}z5l{up}
425 penlabels(1,2,3,4,5);
430 fet_beginchar("Numeral 5", "five", "five")
431 set_char_box(0, 27/40 height#*widen, 0, height#);
432 message "w:"&decimal w;
433 message "h:"&decimal h;
434 calc_kuulleke(w-thin,0);
439 z5l=(x1l,h-15/16thick);
441 z6=z5r+1/2hair*dir(-45);
443 z7l=(x1l,h/2+thin-hair);
444 penlabels(1,2,3,4,5,6,7);
445 save gamma; gamma=angle(length(z1r-z1),+2kuulleke);
446 fill z2r{dir(alpha-gamma)}..z4..{dir(alpha+gamma)}z3l
447 ..z3r{dir(-135)}..{left}z6r..z6l{down}..z7r{down}
448 ..z7l{up}..{up}z2l..cycle;
450 z8l=(x7r,y7r-1/16thick);
455 x9 = .36 [x8r, x10r] ;
459 y10r = 1/2[y9r,y11r];
464 penlabels(8,9,10,11, 12);
467 save inner_t, outer_t;
470 fill z8r{dir(beta)}..z9r{right}
473 .. number_flare_path (z11r, 180, -90, hair, flare, x11l,
479 ..z9l{left}..z8l{dir(180+beta+10)}..cycle;
483 fet_beginchar("Numeral 6", "six", "six")
487 fet_beginchar("Numeral 7", "seven", "seven")
488 set_char_box(0, 11/15height#*widen, 0, height#);
489 message "w:"&decimal w;
490 message "h:"&decimal h;
492 save alpha; alpha=-180;
494 penpos1(3/2thick,180+alpha);
495 penpos2(hair,180+alpha-45);
496 z2=z1l+(1/4sqrt(2)*hair)*dir(alpha-135);
497 penpos3(hair,180+alpha+45);
498 z3=z1r+(1/4sqrt(2)*hair)*dir(alpha-45);
499 z4=z1+kuulleke*dir(alpha-90);
501 % shit, does not work
502 calc_kuulleke(3/2thick,-alpha);
507 penpos5(thin,90+beta);
508 z5=(w,h)+(1/2sqrt(2)*thin)*dir(-135);
510 save gamma; gamma=angle(length(z1r-z1),+2kuulleke);
511 save delta; delta=12;
513 fill z3l{dir(alpha-gamma)}..z4..{dir(alpha+gamma)}z2r..
514 z2l{dir(beta+delta)}..{dir(beta)}z5r
515 ..z5l{dir(180+beta)}..{dir(delta-90)}z3r..cycle;
516 penlabels(1,2,3,4,5);
519 save alpha; alpha=-45*widen;
520 penpos1(1/2thick,90);
521 z1=(3/2thin,h-(thick+thin)/2);
522 penpos3(thin,90+beta);
523 z3=(w,h)+(1/2sqrt(2)*thin)*dir(-135);
524 penpos2(thick,90+alpha);
525 x2=1/2[x1,x3]-1/4thick; y2=h-15/16thick+thin*widen;
532 penpos6(9/8thick,90);
533 z6r=(thin,y1r+2/16thick);
535 fill z1r{dir(beta)}..{dir(alpha)}z2r..{dir(beta)}z3r
536 ..z3l{dir(180+beta)}..{dir(180+alpha)}z2l
537 ..{dir(180+beta)}z1l..z6l{down}..{down}z5r
538 ..z5l{up}..{up}z4l..z4r{down}..{down}z6r..{right}cycle;
539 penlabels(1,2,3,4,5,6);
542 fet_beginchar("Numeral 8", "eight", "eight")
543 set_char_box(0, 11/15height#*widen, 0, height#);
544 message "w:"&decimal w;
545 message "h:"&decimal h;
546 save alpha; alpha=60;
547 save beta; beta=alpha-15;
548 z1=(w/2,h/2+thick/8);
549 penpos2(14/8 thin,0);
556 penpos5(thick,90+90+alpha);
557 z5=z1+w/4*dir(alpha-90);
558 penpos6(thick,90+90+alpha);
559 z6=z1+(w/4-thin/2)*dir(90+alpha);
561 z7r= (x1 + .02 w ,h);
563 z8r=(w-thin/2,3/4h+thin/2);
564 penpos9( 13/8 thin,0);
566 penlabels(1,2,3,4,5,6,7,8,9);
568 fill z2r{dir(180+beta)}..z3r{down}..z4r{right}
569 ..z5r{dir(90+alpha)}..z6r{dir(90+alpha)}
570 ..tension t..z7r{right}..z8r{down}..z9r{dir(180+beta)}
571 ..z9l{dir(beta)}..z8l{up}..z7l{left}..z6l{dir(alpha-90)}
572 ..z5l{dir(alpha-90)}..tension t..z4l{left}..z3l{up}
573 ..z2l{dir(beta)}..cycle;
576 fet_beginchar("Numeral 9", "nine", "nine")
579 currentpicture := currentpicture scaled -1;
580 currentpicture := currentpicture shifted (w,h);
583 ligtable "3" : "3" kern 0.1 space#, "0" kern 0.1 space#;
584 ligtable "2" : "7" kern 0.15 space#;