]> git.donarmstrong.com Git - lilypond.git/blobdiff - mf/feta-eindelijk.mf
''
[lilypond.git] / mf / feta-eindelijk.mf
index f81107f1c82efb6a90d8d39b094e2a728766f229..e2709e6d388d7cf32cae965f2a6d39edbf8832ed 100644 (file)
@@ -38,6 +38,10 @@ ball_crook_balldiam =flare;
 
 save block_rest_y, block_rest_x;
 
+save breve_rest_y, breve_rest_x;
+
+breve_rest_y# =  staff_space#;
+breve_rest_x# = 3/5 staff_space#;
 block_rest_y# = 5/8 staff_space#;
 block_rest_x# = 3/2 staff_space#;
 
@@ -88,38 +92,22 @@ fet_beginchar("half rest (outside staff)", "1o", "outsidehalfrest");
 fet_endchar;
 
 
-save breve_rest_y, breve_rest_x;
-
-breve_rest_y# =  staff_space#;
-breve_rest_x# = 3/5 staff_space#;
-multi_rest_x# = 4 staff_space#;
-multi_beam_height# = 1/3 staff_space#;
 
 define_pixels(breve_rest_y, breve_rest_x, multi_rest_x, multi_beam_height);
 
-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));
+       draw_block ((0,-floor (breve_rest_y)), (breve_rest_x, floor (breve_rest_y)));
 fet_endchar;
 
-tracingvariables := 1;
-
-fet_beginchar("multi rest", "-4", "multirest");
-       set_char_box(multi_rest_x#, multi_rest_x#,
-                    breve_rest_y#, breve_rest_y#);
-       draw_block ((- b, - multi_beam_height),
-                  (w, multi_beam_height));
-       draw_block ((- b,-breve_rest_y),
-                  (rthin - b, breve_rest_y));
-       draw_block ((w - rthin,-breve_rest_y),
-                  (w, breve_rest_y));
+fet_beginchar("breve rest", "-1", "breverest");
+       set_char_box(0, breve_rest_x#, 0, breve_rest_y#);
+       draw_block ((0,0), (breve_rest_x, floor (breve_rest_y)));
 fet_endchar;
 
+tracingvariables := 1;
+
 fet_beginchar("Quarter rest","2","quartrest");
 %      draw_staff (-2, 2, 0.0);        
        save alpha, yshift, height;
@@ -127,9 +115,10 @@ fet_beginchar("Quarter rest","2","quartrest");
        yshift# = -1.25 staff_space#;
        height# = 2.8125 staff_space#;
        define_pixels (yshift, height);
-
+       save xcenter;
+       xcenter = -0.1 staff_space;
        
-       set_char_box(0, 27/25staff_space#,
+       set_char_box(0, 0.95 staff_space#,
          -yshift#,
          yshift# + height#);
        
@@ -154,15 +143,15 @@ fet_beginchar("Quarter rest","2","quartrest");
        z13=z2r+1/2rthin*ne+1/2rthin*nw;
 
        y1r = h;
-       x1l=1/3staff_space;
+       x1l=xcenter +  1/3staff_space;
        z2r=z1+staff_space*se;
        z3=1/2[z2,z4];
-       x4=3/8staff_space;
+       x4= xcenter + 3/8staff_space;
        y4= 0;
        z5=z4l+1.3staff_space*se;
        x6l=x4l;
        y6l=y4r;
-       x7=2/5staff_space;
+       x7= xcenter + 2/5staff_space;
        y7= -d;
        
        fill z1l{se}..{se}z10..z3l..z11{se}..{se}z5l..z5r{nw}..{nw}z12..z3r..z13{nw}..{nw}z1r.. cycle;
@@ -179,38 +168,107 @@ def rest_crook(expr a, w) =
        balled_crook(a, w, ball_crook_balldiam, ball_crook_stem)
 enddef;
 
+%
+% Notes about 8th rest:  
+% 
+% * 8th rest should be no wider than the black note head
+%
+% * The inside corner of the horizontal portion is usually a little blotted.
+%
+% * The top of the crook chops off the vertical brush
+% 
+% * The crook widens a little
+%
+% * The bottom of the brush is slightly flat, as it has to align with
+% stafflines if it is inside the staff.
+%
+% * The top of the brush usually is a little lower than the top of bulb.
+%
+% * The bulb can vary. Sometimes it is open (like in the clefs). Sometimes 
+% it is closed, or even a flare.
+% 
+
+def normalize (expr p) =
+       (p / length (p))
+enddef ;
+
 def draw_eighth_rest =
-%      draw_staff (-2, 2, 0.0);
-       save yshift, ballcorrection;
-       ballcorrection = 0.005 staff_space;
+       save width, bulb_diam, thin, thick;
+       save ycenter, crook_thick, crook_thin;
+       save crook_dir, lower_brush;
+       pair crook_dir;
 
-       yshift# := -1.0 staff_space#;
-       define_pixels(yshift);
 
+       width# := 1.0 staff_space#;
+       bulb_diam# := 0.64 staff_space#;
+       thin# := 1.1 stafflinethickness#;
+       thick# :=  2.2 stafflinethickness#;
+       crook_thick# := 1.8 stafflinethickness#;
+       crook_thin := 1.3 stafflinethickness;
 
-       set_char_box(0, 4/3staff_space#, -yshift#, yshift# +
-                       5/3staff_space#+7/4stafflinethickness#);
+       lower_brush = 1.5 stafflinethickness;
+       ycenter := 0.5 staff_space;
 
-       %
-       % The curve is like a valley causing less space between
-       % the curve and the lower staff line. Correct for this.
-       % 
-       save x,y;
+       define_pixels (width, bulb_diam, thin, thick, crook_thick);
+       set_char_box (0, width#,
+               1.0 staff_space# + 0.5 stafflinethickness#, 0.5 staff_space# + bulb_diam#/2);
 
-       x1=w-stem/6;
+       penpos1 (thick, 0);
+       penpos2 (thin, 0);
+
+       y1 = ycenter + - 1.5 staff_space ;
+%      y9 = y5 -  lower_brush;
+       y2 = y5 -  lower_brush;
+       
+       x2r = width;
+
+       y3 - y2l = 0.25 staff_space;
+       x2r - x1 = 0.5 staff_space;
+
+       x3 = x1l ;
+
+
+       x4 = 1.02 bulb_diam ;
+       y4 := ceiling (ycenter - 2 stafflinethickness + crook_thin);
+
+       x5 = 0.5 bulb_diam - 0.25 stafflinethickness;
+       y5 = ycenter +bulb_diam/2;
+       
+       z9 = z2 + 0.46 stafflinethickness * dir (angle(z2 - z1)- 10);
+
+%      z7 = %(bulb_diam/2,ycenter) + 0.23 staff_space * dir ( 35);
+       z7 = 0.5 [z4, z5] + (0.45 stafflinethickness,0.4 stafflinethickness);
+       z8 = (0, ycenter + 0.5 stafflinethickness);
+
+       z6 = whatever [z1l, z2l];
+       z6 = whatever [z2l, z4] + crook_thick * (crook_dir rotated -90);
+       crook_dir = normalize(z2l - z4);
+
+       y3 := ycenter +floor (- bulb_diam/2);
+
+
+       penlabels (1, 2);
+       labels(3, 4, 5, 6, 7, 8, 9);
+
+       fill z2r -- z2l -- simple_serif (z1l, z1r, 40) -- cycle;
+       fill z2r{z2r-z1r} .. z9 .. z2l{dir(232)} .. tension 2
+               .. z4{left} .. tension 0.9 .. z7 %{dir(90 + 25)} 
+               .. z5{left} .. z8 .. z3{right}
+               .. {curl 0.2}z6 -- cycle;
 
-       y1 = yshift + 1.5 staff_space + flare/4 + ballcorrection; 
-       rest_crook (z1,w-stem/6);
-       z2-z1=whatever*dir70;
-       y2= yshift + stem/2;
-       brush(z1,2/3stem,z2,stem);      
-enddef;
+
+       enddef;
 
 fet_beginchar("8th rest","3","eighthrest");
        draw_eighth_rest;
+       fet_endchar;
 
+fet_beginchar("Classical quarter rest","2classical","clasquartrest");
+       draw_eighth_rest;
+       currentpicture := currentpicture xscaled -1 shifted (w,0);
        fet_endchar;
 
+
 fet_beginchar("16th rest","4","sixteenthrest");
 %      draw_staff (-2, 2, 0.0);
        save yshift, ballcorrection;
@@ -347,10 +405,6 @@ fet_beginchar("128th rest","7","hundredtwentyeighthrest");
        
        fet_endchar;
 
-fet_beginchar("Classical quarter rest","2classical","clasquartrest");
-       draw_eighth_rest;
-       currentpicture := currentpicture xscaled -1 shifted (w,0);
-       fet_endchar;
 
 endgroup;
 
@@ -377,6 +431,13 @@ def neomens_half_block_rest =
        draw_block ((0,0), (neomens_block_rest_x, neomens_half_block_rest_y));
        enddef;
 
+fet_beginchar("Neo-mensural maxima rest", "-3neo_mensural", "neomensmaximarest");
+       set_char_box(0, neomens_block_rest_x#,
+                   neomens_block_rest_y#, 2 neomens_block_rest_y#);
+       draw_block ((0,-neomens_block_rest_y),
+                  (neomens_block_rest_x, 2 neomens_block_rest_y));
+fet_endchar;
+
 fet_beginchar("Neo-mensural longa rest", "-2neo_mensural", "neomenslongarest");
        set_char_box(0, neomens_block_rest_x#,
                    neomens_block_rest_y#, neomens_block_rest_y#);
@@ -404,5 +465,57 @@ fet_beginchar("Neo-mensural half rest", "1neo_mensural", "neomensminimahalfrest"
        neomens_half_block_rest;
 fet_endchar;
 
+neomensrestsize# = .8staff_space#;
+
+fet_beginchar("Neo-mensural 4th rest","2neo_mensural","neomenssemiminimarest")
+       set_char_box(0,neomensrestsize#,0,neomensrestsize#);
+        pickup pencircle scaled 2 stafflinethickness;
+       lft x1 = 0;
+       bot y1 = 0;
+       lft x2 = 0;
+       top y2 = h;
+       rt x3 = w;
+       bot y3 = h/2;
+       draw z1 .. z2;
+       draw z2 .. z3;
+fet_endchar
+
+fet_beginchar("Neo-mensural 8th rest","3neo_mensural","neomensfusarest")
+       set_char_box(0,neomensrestsize#,0,neomensrestsize#);
+        pickup pencircle scaled 2 stafflinethickness;
+       rt x1 = w;
+       bot y1 = 0;
+       rt x2 = w;
+       top y2 = h;
+       lft x3 = 0;
+       bot y3 = h/2;
+       draw z1 .. z2;
+       draw z2 .. z3;
+fet_endchar
+
+fet_beginchar("Neo-mensural 16th rest","4neo_mensural","neomenssemifusarest")
+       set_char_box(0,neomensrestsize#,0,staff_space#);
+        pickup pencircle scaled 2 stafflinethickness;
+       rt x1 = w;
+       bot y1 = 0;
+       rt x2 = w;
+       top y2 = h;
+
+       draw z1 .. z2;
+
+        pickup pencircle scaled 2 stafflinethickness;
+       rt x3 = w;
+       top y3 = h;
+       lft x4 = 0;
+       bot y4 = h/2;
+       rt x5 = w;
+       top y5 = 5/8h;
+       lft x6 = 0;
+       bot y6 = h/8;
+
+       draw z3 .. z4;
+       draw z5 .. z6;
+fet_endchar
+
 
 fet_endgroup("rests")