-% eindelijk.mf
-% LilyPond's own rest(s)
-
-% todo breve/longa rests
-
+% feta-eindelijk.mf -- implement rest symbols
+%
+% part of LilyPond's pretty-but-neat music font
+%
+% source file of the Feta (not the Font-En-Tja) music font
+%
+% (c) 1997, 1998 Jan Nieuwenhuizen <janneke@gnu.org>
fet_begingroup("rests");
%
save stem, ball_crook_stem, ball_crook_balldiam, flare;
-define_pixels(stem,flare);
% stem#:=1/8*interline#;
stem# = 1/5interline#;
+% flare# = 2/3interline#;
+flare# = 2/3interline# - 1/8stafflinethickness#;
+
+define_pixels(stem,flare);
+
ball_crook_stem = stem;
ball_crook_balldiam =flare;
-flare# = 2/3interline#;
+
save block_rest_y, block_rest_x;
define_pixels(block_rest_y, block_rest_x);
-def block_rest=
- pickup pencircle scaled blot_diameter;
-
- bot y1 = 0;
- top y2 = block_rest_y;
- y3 = y2;
- y4 = y1;
-
- rt x1 = block_rest_x;
- x2 = x1;
- lft x3 = 0;
- x4 = x3;
- save p;
- path p;
- p:=z1 -- z2 -- z3 -- z4 -- cycle;
- draw_rounded_path(p, blot_diameter);
-enddef;
+def block_rest =
+ draw_block ((0,0), (block_rest_x, block_rest_y));
+ enddef;
fet_beginchar( "whole rest", "0", "wholerest");
set_char_box(0, block_rest_x#,
draw z5 .. z6;
fet_endchar;
+
+save breve_rest_y, breve_rest_x;
+
+breve_rest_y# = interline#;
+breve_rest_x# = 3/5 interline#;
+
+define_pixels(breve_rest_y, breve_rest_x);
+
+fet_beginchar("breve rest", "-1", "breverest");
+ set_char_box(0, breve_rest_x#, 0, breve_rest_y#);
+ draw_block ((0,0), (breve_rest_x, breve_rest_y));
+fet_endchar;
+
+fet_beginchar("longa rest", "-2", "longarest");
+ set_char_box(0, breve_rest_x#, breve_rest_y#, breve_rest_y#);
+ draw_block ((0,-breve_rest_y), (breve_rest_x, breve_rest_y));
+fet_endchar;
+
+
fet_beginchar("Quarter rest","2","quartrest");
save alpha;
alpha:=-50;
enddef;
fet_beginchar("8th rest","3","eighthrest");
- set_char_box(0, 4/3interline#,-interline#, 8/3interline#+2stafflinethickness#);
+ set_char_box(0, 4/3interline#,-interline#, 8/3interline#+7/4stafflinethickness#);
save x,y, ht;
ht = h + d;
x1=w-stem/6; y1=ht-flare/4;
currentpicture:=currentpicture shifted (0,interline);
fet_endchar;
-def tand(expr alpha) =
- (sind alpha/cosd alpha);
- enddef;
-
fet_beginchar("16th rest","4","sixteenthrest");
save alpha,cw,h,w;
alpha=74;
cw#=7/6interline#;
- h#=5/3interline#+interline#+2stafflinethickness#;
+% h#=5/3interline#+interline#+2stafflinethickness#;
+ h#=5/3interline#+interline#+7/4stafflinethickness#;
w#=cw#+(h#-3/2interline#)/tand(alpha);
set_char_box(0,w#,0,h#);
define_pixels(cw);
save alpha,cw,h,w;
alpha=76;
cw#=7/6interline#;
- h#=5/3interline#+2interline#+2stafflinethickness#;
+ h#=5/3interline#+2interline#+7/4stafflinethickness#;
w#=cw#+(h#-3/2interline#)/tand(alpha);
set_char_box(0,w#,0,h#);
define_pixels(cw);
save alpha,cw,h,w;
alpha=78;
cw#=7/6interline#;
- h#=5/3interline#+3interline#+2stafflinethickness#;
+ h#=5/3interline#+3interline#+7/4stafflinethickness#;
w#=cw#+(h#-3/2interline#)/tand(alpha);
set_char_box(0,w#,0,h#);
define_pixels(cw);
z5-z1=whatever*dir alpha;
y5=y1-3interline;
rest_crook (z5,cw);
+ % ugh
+ currentpicture:=currentpicture shifted (0,-interline);
fet_endchar;
fet_beginchar("128th rest","7","hundredtwentyeighthrest");
save alpha,cw,h,w;
alpha=78;
cw#=7/6interline#;
- h#=5/3interline#+4interline#+2stafflinethickness#;
+ h#=5/3interline#+4interline#+7/4stafflinethickness#;
w#=cw#+(h#-3/2interline#)/tand(alpha);
set_char_box(0,w#,0,h#);
define_pixels(cw);
z6-z1=whatever*dir alpha;
y6=y1-4interline;
rest_crook (z6,cw);
+ % ugh
+ currentpicture:=currentpicture shifted (0,-interline);
fet_endchar;
endgroup;