fet_begingroup("scripts")
def draw_fermata =
- save alpha, radius, crook_thinness, crook_fatness, dot_diam;
+ save alpha, radius, crook_thinness, crook_fatness, dot_radius;
% [Wanske] and some Baerenreiter editions
% suggest ca 80 degrees iso half-circle
set_char_box(w#, w#, crook_thinness#/2, h#);
define_pixels(radius, crook_thinness, crook_fatness);
- dot_diam = 4/3 crook_fatness;
+ dot_radius = round (4/6 crook_fatness);
penpos1(crook_thinness, 0);
addto currentpicture also
currentpicture xscaled -1;
- pickup pencircle scaled dot_diam;
+ pickup pencircle scaled 2dot_radius;
x4 =0;
bot y4 = - crook_thinness/2;
- draw z4;
+ drawdot z4;
enddef;
fet_beginchar("fermata up", "ufermata", "ufermata")
fet_beginchar("staccato dot", "staccato", "staccato")
save radius;
radius# = 1.4 stafflinethickness#;
- define_pixels(radius);
+ define_whole_pixels(radius);
pickup pencircle scaled 2 radius;
- draw (0,0);
+ drawdot (0,0);
set_char_box(radius#, radius#, radius#, radius#);
fet_endchar;
save radius, height;
height# = .8 staff_space#;
radius# = 2 stafflinethickness#;
- define_pixels(radius, height);
+ define_whole_pixels(radius);
+ define_pixels(height);
draw_brush((0,0), stafflinethickness, (0, height),2 radius);
set_char_box(radius#,radius#, blot_diameter#/2, height# + radius#);
fet_beginchar("portato/single tenuto", "tenuto", "tenuto")
save thick;
thick# = 1.4 stafflinethickness#;
- define_pixels(thick);
+ define_whole_pixels(thick);
set_char_box(.6 staff_space#, .6 staff_space#, thick#/2,thick#/2);
pickup pencircle scaled thick;
- lft x1 = -b;
- rt x2 = w;
- y1 = y2 = 0;
- draw z1 .. z2;
+ draw_rounded_block((-b,-thick/2),(w,thick/2),thick);
fet_endchar;
def draw_portato =
save thick, radius;
thick# = 1.4 stafflinethickness#;
- define_pixels(thick);
radius# = 1.4 stafflinethickness#;
- define_pixels(radius);
+ define_whole_pixels(thick,radius);
set_char_box(.6 staff_space#, .6 staff_space#, thick#/2,.5 staff_space#+ radius#);
- pickup pencircle scaled thick;
- lft x1 = -b;
- rt x2 = w;
- y1 = y2 = 0;
- draw z1 .. z2;
+ draw_rounded_block((-b,-thick/2),(w,thick/2),thick);
pickup pencircle scaled 2 radius;
- draw (0,h);
+ drawdot (0,h);
enddef;
size# = 1.1 staff_space#;
set_char_box(size#/2, size#/2, size#/2, size#/2);
- pickup pencircle scaled thick;
-
- rt x1 = w;
- y1 = 0;
- z2 = -z1;
-
- draw z1 .. z2;
- draw (z1 .. z2) rotated 90;
+ draw_rounded_block((-b,-thick/2),(w,thick/2),thick);
+ addto currentpicture also currentpicture rotated 90;
fet_endchar;
+
%
-% FIXME: blotting
+% A vee with tapered insides to prevent visual blotting
%
-fet_beginchar("Upbow", "upbow", "upbow")
- save ht, wd, thick;
- thick = 1.4 stafflinethickness;
- wd# = 1.3 staff_space#;
- ht# = 1.6 wd#;
+def draw_vee (expr width, height, thickness) =
+begingroup
+ save diminish;
-
- set_char_box(wd#/2, wd#/2, 0, ht#);
- pickup pencircle scaled thick;
+ diminish = 0.75;
+ pickup pencircle scaled thickness;
+
x1 = 0;
bot y1 = 0;
rt x2 = w;
top y2 = h;
+ z3 = 0.6 [z2, z1];
+ penpos3(thickness, 0);
+ penpos4(thickness * diminish, 0);
+ x4r = thickness/2;
+ y4 = thickness/2;
labels(1,2);
- draw z2 -- z1 -- (z2 xscaled -1);
+ penlabels(3,4);
+
+ draw z1;
+ draw z3 -- z2;
+ penstroke z3e .. z4e;
+ addto currentpicture also currentpicture xscaled -1;
+endgroup;
+enddef;
+
+fet_beginchar("Upbow", "upbow", "upbow")
+ save ht, wd, thick, diminish;
+
+ thick = 1.4 stafflinethickness;
+ wd# = 1.3 staff_space#;
+ ht# = 1.6 wd#;
+ set_char_box(wd#/2, wd#/2, 0, ht#);
+ draw_vee (wd, ht, thick);
fet_endchar;
fet_beginchar("Downbow", "downbow", "downbow")
save stemthick, beamheight;
- save wd;
+ save wd,round;
define_pixels(wd)
wd# = 1.5 staff_space#;
stemthick = 1.2 stafflinethickness;
-
set_char_box(wd#/2, wd#/2, 0, 4/3 staff_space#);
beamheight = 4/10 h;
-
- pickup pencircle scaled blot_diameter;
- top y2 - bot y1 = beamheight;
- top y2 = h;
- rt x1 = w;
- x1 = x2;
- y2 = y3;
- y1 = y4;
- x3 = 0;
- x4 = x3;
- save p;
- path p;
- filldraw z1 -- z2 -- z3 -- z4 --cycle;
-
- pickup pencircle scaled stemthick;
-
- bot y5 =0;
- rt x5 = rt x6 = w;
- y6 = h - beamheight;
- draw z6 -- z5;
- labels(1, 2,3,4,5,6);
+ draw_rounded_block((-b,h-beamheight),(w,h),blot_diameter);
+ draw_rounded_block((-b,-d),(-b+stemthick,h-stemthick),stemthick);
addto currentpicture also currentpicture xscaled -1;
fet_endchar;
ascender_extra# = 1/2 ex#;
ascender# = ascender_extra# + ex#;
- ex# = 1.5 staff_space#;
- kerning# = .75 ex#;
+ ex# = 1.4 staff_space#;
+ kerning# = .60 ex#;
start_nib_angle = 20;
- bulb_size = 0.47;
+ bulb_size = 0.70;
define_pixels(ex, ascender_extra, ascender, kerning);
t_overshoot = 0.03 ex;
fatness = 12/40 ex;
- t_fatness = 8/10 fatness;
- r_fatness = .75 fatness;
- uitschieter = 21/40 ex;
+ t_fatness = 0.78 fatness;
+ t_width = 1.9 t_fatness;
+ r_fatness = 0.78 fatness;
+ uitschieter = 0.48 ex;
hair_thick = blot_diameter;
-
+ r_flare = 0.45 r_fatness;
+ r_width = 2 r_fatness + 0.25 kerning;
slant = .2;
+% slant = .0;
+
local_copy(transform)(currenttransform);
currenttransform := currenttransform slanted slant shifted (- staff_space, 0) ;
z2 = (x1, 7/18 ex);
penpos2(start_nib_wid, start_nib_angle);
- z3l = (11/10 t_fatness, - t_overshoot);
+ z3l = (0.5 t_width, - t_overshoot);
+
+ z4l = (t_width, 0.23 ex);
+ penpos4(whatever, 200);
+ x4l - x4r = hair_thick;
- z4l = (13/6 t_fatness, 5/16 ex);
- penpos4(hair_thick, 180);
+ x3r = 0.5 [x4r, x2r];
+% 1.7 [x3l, x3r] = x4r;
+ y3r - y3l = 0.6 t_fatness;
- 1.9 [z3l, z3r] = z4r;
- z3 = .5 [z3l, z3r];
save t_p, krul_p;
path t_p, krul_p, r_p;
+ z5 = (t_fatness/2, 2/3 ex);
+% penpos5(hair_thick, );
- t_p := z1l -- z2l{down} .. tension (1 + .5 slant)
+ t_p := z1r{dir (angle(z1l-z1r) + 30)} .. z1l{-dir (angle(z1r-z1l) - 45)}
+ -- z2l {down}
+ .. tension (1 + .5 slant)
.. z3l{right}
.. z4l{up} -- z4r{down}
- .. z3r{left} .. z2r{up} .. z1r -- cycle;
+ .. z3r{left}
+ .. tension (1.5 + .7 slant)
+ .. z2r{up} .. z1r -- cycle;
fill t_p ;
krul_ang = 32;
pickup pencircle scaled hair_thick;
-
- z5 = (t_fatness/2, 2/3 ex);
lft x6 = - uitschieter;
- y6 = y5 - 1/20 ex;
+ y6 = y5 ; % - 1/20 ex;
z7 = z5 + whatever*dir krul_ang;
up_angle = krul_ang;
penpos7(hair_thick, up_angle + 90);
- x8l = .7 [x9r, x7r];
- y8l = y7l;
- penpos8(2 hair_thick, (up_angle +90)/2);
-
y9 = 3/4 ex;
x9 = x1 + kerning;
penpos9(r_fatness, 0);
x10 = x9;
- y10 = 0;
+ y10 = -0.3 stafflinethickness;
penpos10(r_fatness, 0);
- krul_p := z4{up} .. tension 1.1 .. z5
- .. tension 1 and .75 .. {down}z6
- .. tension .85 and 1.1 .. z5 --- z7;
+ krul_p := z4{up}
+ .. tension 0.98
+ .. z5
+ .. z6
+ .. z5 --- z7;
draw krul_p;
- r_p := z7l{z7-z5} .. z8l{right} .. z9l{down} --- z10l -- z10r
+ r_p := z7l{z7-z5} .. z9l{down} --- simple_serif (z10l, z10r, -30)
--- z9r{up}
- .. z8r{left} .. z7r{z5-z7} -- cycle;
+ .. z7r{z5-z7} -- cycle;
fill r_p;
- set_char_box(staff_space# , staff_space#, 0,ascender#);
+ set_char_box(.85 staff_space# , .85 staff_space#, 0,ascender#);
- penpos11(1/4 r_fatness, -20);
+
+ penpos11(1/4 r_fatness, -4);
z11r = z9r;
- z13 = (x9 + 2 r_fatness, y11 );
- penpos13(r_fatness, 180);
- fill z11r{dir 70} .. z13r{down} -- z13l{up} .. z11l{dir 250} -- cycle;
- penlabels(range 1 thru 15);
+ z13l = (x9l + r_width, y11 - stafflinethickness );
+ penpos13(r_flare, 180);
+
+ z15 = z13r - (bulb_size * r_fatness,0);
+ z14 = 0.5 [z13l, z15] - (0,bulb_size* r_fatness);
+ z16 = 0.5 [z13l, z15] + (0,bulb_size* r_fatness);
- draw_bulb(-1, z13r, z13l, bulb_size * r_fatness, 1.5);
+ fill z11r{up} .. tension 0.94 .. z13r{down} -- z15{down}
+ .. tension 1.0 .. z13l{up}
+ .. z11l{down} -- cycle;
+
+ fill z15{up} .. tension 1.06 .. z13l{down} .. z14 .. cycle;
+
+
+
+ penlabels(range 1 thru 15);
+
fet_endchar;
set_char_box(wd#, wd#, 0, ht#);
-
- pickup pencircle scaled thickness;
- lft x1 = -b;
- bot y1 = 0;
- x2 =0;
- top y2 = h;
- z3 = z1 xscaled -1;
-
-
- draw z1 -- z2 -- z3;
-
+ draw_vee (wd, ht, thickness);
enddef;
fet_beginchar("left toe", "upedaltoe", "upedaltoe")
fill halfcoda;
fill (halfcoda scaled -1);
- pickup pencircle scaled thin;
- draw (0,-h) -- (0,h);
- draw (-w,0) -- (w,0);
+ draw_gridline((0,-h),(0,h),thin);
+ draw_gridline((-w,0),(w,0),thin);
fet_endchar;