%
% source file of the Feta (not the Font-En-Tja) music font
%
-% (c) 1997--2002 Han-Wen Nienhuys <hanwen@cs.uu.nl>,
+% (c) 1997--2004 Han-Wen Nienhuys <hanwen@cs.uu.nl>,
% Jan Nieuwenhuizen <janneke@gnu.org>,
% Juergen Reuter <reuter@ipd.uka.de>
fet_begingroup("clefs");
-
-%
-% [Ross] says that clefs take 1 staff_space space on the left and right
-%
-% this is now handled in the lilypond spacing engine.
-%
-
-def set_horizontal_spacing =
- save left_space ,right_space;
- left_space# = 0;
- right_space# = 0;
-enddef;
+test_staff = 0;
% [Wanske] says the bulbs should be positioned about 1/4 right of the
% "arrow"
+
+%
+% TODO: the hair-curve at z6r looks a little awkward.
def draw_c_clef (expr reduction) =
save hair, norm, reduced_ss, right_edge;
reduced_ss#=staff_space#*reduction;
norm#:=2/3reduced_ss#;
- hair#:=1/6norm#;
+ hair#:=0.06 reduced_ss# + 0.5 linethickness# ;
- set_horizontal_spacing;
right_edge# = 15/4norm#+2hair#;
- set_char_box (left_space#, right_edge# + right_space#,
+ set_char_box (0, right_edge# + 0,
2 reduced_ss#, 2 reduced_ss#);
define_pixels (hair,norm,reduced_ss, right_edge);
draw_block ((0,-d), (3/4norm+1/2hair,h));
draw_block ((3/4norm+2hair,-d),
(3/4norm+7/2hair,h));
+
save xoff;
xoff=3/4norm+7/2hair;
+ z5l = (xoff - 3/4 hair, 0);
+ z5r = (x4, 0);
+
penpos1(hair,-90);
z1l=(xoff+norm+hair,h);
penpos2(norm-3/2hair,180);
z3=(((right_edge -xoff)/2)+xoff,2hair);
penpos4(hair,0);
- z4=(xoff+1/2norm+1/2hair,reduced_ss-hair);
-
- penpos5(4hair,0);
- z5=(xoff+5/4hair,0);
+ z4=(xoff+1/2norm+1/2hair, reduced_ss - linethickness - .2 hair);
penpos6(norm-hair,90);
z6=(xoff+3/4norm,0);
enddef;
fet_beginchar ("C clef", "C", "altoclef")
- if test = 1:
+ if test_staff = 1:
draw_staff (-2,2, 0.0);
fi;
draw_c_clef (1.0);
fet_endchar;
fet_beginchar ("C clef", "C_change", "caltoclef")
- if test = 1:
+ if test_staff = 1:
draw_staff (-2,2, 0.0);
fi;
draw_c_clef (.8);
%
def new_bulb (expr outer_tangent_point,
- big_radius, bulb_radius, flare, direction) =
- begingroup;
+ big_radius, bulb_radius, flare, direction, turning_dir) =
+
+begingroup;
save p, oldpen;
path p;
pen oldpen;
pair center;
clearxy;
- center = outer_tangent_point +big_radius* dir(0) + big_radius* dir(-90)
- - bulb_radius * dir (-90);
+ center = outer_tangent_point +big_radius* dir(0) + big_radius* dir(-turning_dir * 90)
+ - bulb_radius * dir (- turning_dir * 90);
- z1 = center + bulb_radius * dir 180;
- z2 = center + bulb_radius * dir 270;
+ z1 = center + bulb_radius * dir (turning_dir * 180);
+ z2 = center + bulb_radius * dir (turning_dir * 270);
z9 = center + bulb_radius * dir (0);
- z10 = center + bulb_radius * dir (90);
+ z10 = center + bulb_radius * dir (turning_dir *90);
z3 = outer_tangent_point + flare * dir (0);
labels(1,2,3,9,10);
% tension is needed to open up the space between return path and the
% ball.
fill
+% draw
z9 .. z10 .. tension 1.1 .. z1 .. z2 .. cycle;
- p:= outer_tangent_point{down}
+ p:= outer_tangent_point{dir (-turning_dir* 90)}
.. tension 0.97
- .. {up}z9 -- z3
+ .. {dir (turning_dir * 90)}z9 -- z3
;
if direction = 1:
p
save dot_diam;
reduced_ss# = staff_space# * reduction;
-
2.2 dot_diam = round reduction* (staff_space - stafflinethickness);
- right_thickness = 0.48;
- left_thick = .25;
+ right_thickness = 0.37 staff_space + 1.2 linethickness ;
swoosh_width# = 2.1 reduced_ss#;
-% tip_protude := (-stafflinethickness, -.2 staff_space);
+% tip_protude := (-linethickness, -.2 staff_space);
tip_protude := (0, 0);
- set_horizontal_spacing;
bulb_y_offset := 0.15 staff_space;
overshoot_top := 0.0;
%%
- set_char_box(left_space# +
+ set_char_box(0 +
- xpart exact_center,
- right_space# +
+ 0 +
xpart exact_center + swoosh_width# + 7/12 reduced_ss#,
- ypart exact_center + 2.5 reduced_ss#,
ypart exact_center +reduced_ss#);
x2 = .5 [x1,x3];
x2l = x2r = x2;
- y2l := vround_pixels (reduced_ss# + 0.5 stafflinethickness#);
- y2l - y2r = (1.0 + overshoot_top) * stafflinethickness;
- y2 = .5 [y2l, y2r];
+ y2l := vround_pixels (reduced_ss# + 0.5 linethickness#);
+ y2l - y2r = (1.0 + overshoot_top) * linethickness;
x3l - x1 = swoosh_width;
- x3l - x3r = right_thickness * reduced_ss;
+ x3l - x3r = right_thickness;
% try to correct: the top dot seems farther away if y3l = 0.
y3l = 0.05 staff_space;
z5 = (x3l + 1/3 reduced_ss, .5 reduced_ss);
penpos3(whatever, 185);
- penpos4(stafflinethickness, 135);
+ penpos4(linethickness, 135);
pickup pencircle scaled 1;
% draw
fill
- new_bulb (z1, 0.4 reduced_ss, 0.35 reduced_ss, 2 stafflinethickness, 1)
+ new_bulb (z1, 0.45 reduced_ss, 0.4 reduced_ss, 2.5 linethickness, 1, 1)
{dir (90)}
.. z2r{right} .. tension 1.0 .. z3r{down} .. {curl 0}
fet_beginchar("F clef ", "F", "bassclef")
- if test = 1:
+ if test_staff = 1:
draw_staff(-3,1, 0.0);
fi;
draw_bass_clef((0, 0), 1.0);
%
% Inspired by Baerenreiter
%
-% FIXME bulb should curve (see bass clef)
-% FIXME start (inside) should be little thinner
-% FIXME parametrise.
-%
% Beste lezers, kijk,
%
%
% -- vrij naar Van Kooten & De Bie
%
-
-def draw_gclef (expr exact_center, reduction)=
- save reduced_ss, downstroke_dir, downstroke_angle, hair, center;
+def debugfill = fill enddef;
+def draw_gclef (expr reduction)=
+ save reduced_ss, downstroke_dir, downstroke_angle, center;
save breapth_factor, inner_thick_end, thinness, thickness, thinnib;
- save inner_start_angle, thinness, thinpen;
+ save inner_start_angle, thinness;
reduced_ss# = staff_space# * reduction;
define_pixels(reduced_ss);
pair downstroke_dir, center;
- center := (hround_pixels(xpart exact_center),
- vround_pixels(ypart exact_center));
+ thinness = 0.08 staff_space + 0.7 linethickness;
+ downstroke_dir = unitvector (14, -75);
+ downstroke_angle = angle downstroke_dir;
+
- hair = .3 stafflinethickness;
-% hair = blot_diameter;
- thinness = 1.3 stafflinethickness;
- downstroke_dir = (14, -75);
- breapth_factor = 11/7;
+ breapth_factor = 21.0 /14;
inner_thick_end = 45;
inner_start_angle = downstroke_angle - 43;
- thickness = .4 reduced_ss - hair;
+ thickness = .32 reduced_ss + 1.1 linethickness;
+
+ thinnib = thinness;
- thinnib = thinness - hair;
- thinpen = thinness;
- set_horizontal_spacing;
-
- set_char_box(
- left_space# +
- -xpart exact_center + 1.0 * breapth_factor* reduced_ss#,
- right_space# +
- xpart exact_center + .66 breapth_factor* reduced_ss#,
- -ypart exact_center + 3 * reduced_ss#,
- ypart exact_center + 5 * reduced_ss#);
- pickup pencircle scaled hair;
- downstroke_angle = angle downstroke_dir;
+ set_char_box(0,
+ 1.71 * breapth_factor* reduced_ss#,
+ 2.6 * reduced_ss#,
+ 5 * reduced_ss#);
+ center := (1.0 * breapth_factor* reduced_ss, 0);
+
+ save upward_swoosh_angle;
+ upward_swoosh_angle = 132;
+ penpos7(thickness, upward_swoosh_angle);
+ penpos5(thickness, upward_swoosh_angle);
+
+
z1 = center + whatever * dir (inner_start_angle);
x1 = xpart center -.28 reduced_ss;
bot y4r = -(reduced_ss + .5 stafflinethickness);
z3 = (z4 - center) rotated inner_thick_end + center;
-
- z5r = (- breapth_factor, .37)* reduced_ss + center;
- penpos5(thickness, 135);
+ x5r = - breapth_factor* reduced_ss + xpart center;
+ y5r = .37 reduced_ss + ypart center;
z6 = center + whatever * downstroke_dir;
y6 = ypart center + 2 reduced_ss;
- z7l - z6 = whatever *(z5- z6) ;
+ z7l - z6 = whatever * (z5 - z6) ;
y7l = 3.5 reduced_ss;
- z8r = .4 [z9r, z7r] + 1.5 stafflinethickness * dir 52;
x9 = .7 [x10, x7r];
top y9l = 5 reduced_ss;
- y10 = 3. reduced_ss;
- y11 = -11/7 reduced_ss;
+ y11 = ypart center - 47/28 reduced_ss;
+ y12 = ypart center - 71/28 reduced_ss;
+ y13 = .48 [y12,y4r];
+ x11 - x13r = 1.5 reduced_ss + 0.5 thinnib;
+ x12r = xpart (.45 [z13r , z11] + .75 reduced_ss * downstroke_dir) ;
- y12 = ypart center - 18.5/7 reduced_ss;
- x12 = x11 - 5 /7 reduced_ss;
+% z10= center + whatever * dir (downstroke_angle - 1.5 );
+ x10 = x6 - 2 thinnib;
+ y10 = ypart center + 3.5 reduced_ss;
+ y10l - y10r = 1.2 thickness;
+ z10r - z10l =
+ .7 thinnib* dir (downstroke_angle + 90) + whatever * downstroke_dir;
- z13 = z12 + .6 reduced_ss*(-1,1);
+ z10 = .5 [z10l, z10r];
- (z10r - z10l) dotprod (unitvector downstroke_dir rotated 90) =
- thinnib;
+ z11 = center + whatever * downstroke_dir + ( .00 reduced_ss, 0);
- center - z10= whatever * downstroke_dir;
- center - z11 = whatever * downstroke_dir;
- center - z14 = .8 (center - z11);
penpos1(thinnib, inner_start_angle);
penpos2(thickness, 90);
penpos3(thinnib, -90 + inner_thick_end);
penpos4(thinnib, -90);
- penpos7(thickness, 135);
- penpos8(1.5 thinnib, - 70 + angle downstroke_dir);
- penpos9(1.4 thickness, -80); % ugh
- penpos10(whatever, downstroke_angle + 10);
- penpos11(thinnib, downstroke_angle + 90);
- penpos14(thinnib, downstroke_angle + 90);
- penpos12(thinnib, -90);
- penpos13(3 thinnib, 180);
+ penpos9(1.45 thickness, -70);
+ save lipje;
+ pair lipje;
+ lipje= .5 [z9l, z9r] + .25 ((z9r- z9l) rotated -90);
+ penpos13(thinnib + 0.14 staff_space, 180);
+
+ pickup pencircle scaled 1;
- filldraw z2l{right} .. z3l.. z4l{left} .. z5l{up} .. z7l{up}
- %.. z8l
+ debugfill
+ z2l{right}
+ .. z3l
+ .. z4l{left}
+ .. z5l{up}
+ .. z7l{up}
.. tension 1.2
- .. z9l & z9l ..
- {downstroke_dir}z10l --- z11l -- z11r --- z10r{- downstroke_dir}
- .. tension .8
- .. z9r & z9r{dir (downstroke_angle+ 40)} % ugh
- %.. z8r
+ .. z9l -- lipje
+ --z9r % {dir (downstroke_angle+ 0)}
+ .. tension 0.8
.. z7r{down} .. z5r{down} .. z4r{right}
.. z3r .. z2r{left} ..
tension .95 ..
- z1r -- z1l
+ z1r -- simple_serif(z1r, z1l, 80) -- z1l
.. tension 0.85 ..cycle;
- filldraw simple_serif(z1r, z1l, 80) -- cycle;
+ save p, staffline_time, staff_line_path, down_staff_line_intersection;
+ path p, staff_line_path;
+ pair down_staff_line_intersection;
+ p := z4{left} .. z5{up} .. z7{up} ;
+
+ staff_line_path := (-reduced_ss, 2 reduced_ss) .. (2 reduced_ss,2 reduced_ss);
+
+ draw p;
+
+
+ % we don't do this with a path: variations in thickness
+ % are very easily made and look very ugh.
+ pickup pencircle scaled thinnib;
+
+
+ save bot_angle;
+
+ bot_angle = -180; % downstroke_angle- 87;
+
+ penpos12(thinnib, bot_angle + 90);
+
+ p := z9 .. z10{down}
+ .. z6
+ .. z11{dir (-95) }
+ .. z12{dir(bot_angle)}
+ .. z13{up}
+ ;
+ save down_intersection_t;
+ down_intersection_t := xpart (p intersectiontimes staff_line_path) ;
+ down_staff_line_intersection = point down_intersection_t of p;
+ z14 = down_staff_line_intersection;
+ penpos14(thinnib, angle (direction down_intersection_t of p) + 90);
+
+ save start_angle;
+ start_angle=angle (direction xpart (p intersectiontimes z11) of p);
+ penpos11 (thinnib, start_angle+ 90);
- filldraw z12r{left} .. z13r{up} -- z13l{down} .. z12l{right} .. cycle;
+ save loop_end_dir;
+ pair loop_end_dir;
+ loop_end_dir = direction (xpart (p intersectiontimes staff_line_path)) of p;
+ draw p;
- draw_bulb(-1, z13l, lft z13r, 6/14 reduced_ss, 1.0);
+ penpos6(thinnib, angle (loop_end_dir) + 90);
+ pickup pencircle scaled 1;
+ debugfill
+ z9l
+ .. {down}z10l
+ .. z14l{loop_end_dir} -- z14r{-loop_end_dir}
+ .. z10r{up}
+ .. tension .98
+ .. z9r
+ -- cycle;
- pickup pencircle scaled (thinpen);
- draw z10 --- z14 .. z11 .. tension 0.85 .. z12{left};
+ pickup pencircle scaled 1;
- penlabels(range 1 thru 15);
+ debugfill
+ z11r{dir(start_angle)}
+ .. z12r{dir(bot_angle)}
+
+ ..new_bulb (z13r, 0.45 reduced_ss, 0.38 reduced_ss, thinnib
+ + .15 staff_space
+ , 1, -1) {down}
+
+% .. tension 0.98
+ .. z12l{-dir (bot_angle)}
+
+ .. z11l{-dir(start_angle)}
+ .. cycle;
+
+
+
+ penlabels(range 1 thru 16);
enddef;
fet_beginchar("G clef", "G", "trebleclef")
- if test = 1:
+ if test_staff = 1:
draw_staff(-1,3, 0.0);
fi;
- draw_gclef((1.7 staff_space#,0), 1.0);
+ draw_gclef(1.0);
fet_endchar;
fet_beginchar("G clef", "G_change", "ctrebleclef")
- draw_gclef((1.3 staff_space#,0), .8);
+ draw_gclef(0.8);
fet_endchar;
%%%%
%
+
+%%
+%
+% The perc clef extent is not coincident with its bbox, since
+% the perc clef needs more space in front than a normal clef.
+%
+
def draw_percussion_clef(expr reduction) =
- save reduced_ss;
+ save reduced_ss, razt;
+
reduced_ss# = staff_space# * reduction;
define_pixels(reduced_ss);
set_char_box(-.67reduced_ss#,2.0reduced_ss#,reduced_ss#,reduced_ss#);