draw_brevis(brevis_wid#);
fet_endchar;
-def draw_mensural_black_head (expr wid) =
+def draw_neo_mensural_black_head (expr wid) =
save head_width;
head_width# = wid;
set_char_box (0, head_width#, noteheight#/2, noteheight#/2);
filldraw z1 -- z2 -- z3 -- z4 -- cycle;
enddef;
-def draw_mensural_open_head (expr wid)=
- draw_mensural_black_head (wid);
+def draw_neo_mensural_open_head (expr wid)=
+ draw_neo_mensural_black_head (wid);
save diamNW, diamSW;
diamNW = length (z2 - z1) + blot_diameter;
diamSW = length (z4 - z1) + blot_diameter;
unfill z5 -- z6 -- z7 -- z8 --cycle;
enddef;
+fet_beginchar("Neo-mensural open head","0neo_mensural","neomensuralminimhead")
+ draw_neo_mensural_open_head (staff_space#);
+fet_endchar;
+
+fet_beginchar("Neo-mensural open head","1neo_mensural","neomensuralsemiminimhead")
+ draw_neo_mensural_open_head (staff_space#);
+fet_endchar;
+
+fet_beginchar("Neo-mensural black head","2neo_mensural","neofusahead")
+ draw_neo_mensural_black_head (staff_space#);
+fet_endchar;
+
+
+def draw_mensural_head (expr wid, open) =
+ save head_width;
+ head_width# = wid;
+ set_char_box (0, head_width#,
+ noteheight#/2, noteheight#/2);
+
+ define_pixels(head_width, noteheight);
+
+ x2 = head_width/2;
+ y2 = 1.1 noteheight/2;
+ y1 = 0;
+ (x2 - x1) / (y2 - y1) = tand(30);
+ z3 = (2x2 - x1, y1);
+ z4 = z3 + z1 - z2;
+
+ pickup pencircle
+ xscaled 0.18 head_width
+ yscaled 0.36 head_width
+ rotated -30;
+
+ if open:
+ draw z1 -- z2 -- z3 -- z4 -- cycle;
+ else:
+ filldraw z1 -- z2 -- z3 -- z4 -- cycle;
+ fi;
+enddef;
+
+
fet_beginchar("Mensural open head","0mensural","mensuralminimhead")
- draw_mensural_open_head (staff_space#);
+ draw_mensural_head (staff_space#, true);
fet_endchar;
fet_beginchar("Mensural open head","1mensural","mensuralsemiminimhead")
- draw_mensural_open_head (staff_space#);
+ draw_mensural_head (staff_space#, true);
fet_endchar;
fet_beginchar("Mensural black head","2mensural","fusahead")
- draw_mensural_black_head (staff_space#);
+ draw_mensural_head (staff_space#, false);
fet_endchar;
2beta# = ht# * b_h;
a# = beta# * a_b;
wd# = 2a# / a_w;
- set_char_box(0, wd#, 0.5 ht#, 0.5 ht#);
+ set_char_box(0.3wd#, 0.3wd#, 0.5 ht#, 0.5 ht#);
black_notehead_width# := wd#;
save za, alpha, size;
2beta# = ht# * b_h;
a# = beta# * a_b;
wd# = 2a# / a_w;
- set_char_box(0.0, 0.4wd#, 0.5ht#, 0.5ht#);
+ set_char_box(0.25wd#, 0.25wd#, 0.5ht#, 0.5ht#);
black_notehead_width# := wd#;
save convexity;
2beta#=ht#*b_h;
a# = beta#*a_b;
wd# = 2a# / a_w;
- set_char_box(0, wd#, 0.5 ht#, 0.5 ht#);
+ set_char_box(0.1wd#, 0.4wd#, 0.5 ht#, 0.5 ht#);
black_notehead_width# := wd#;
define_pixels(ht, wd);
2beta# = ht# * b_h;
a# = beta# * a_b;
wd# = 2a# / a_w;
- set_char_box(0, wd#, 0.5 ht#, 0.5 ht#);
+ set_char_box(wd#/2, wd#/2, 0.5 ht#, 0.5 ht#);
black_notehead_width# := wd#;
save za, alpha, size;
2beta# = ht# * b_h;
a# = beta# * a_b;
wd# = 2a# / a_w;
- set_char_box(wd#/2, wd#/2, 0.7 ht#, 0.7 ht#);
+ set_char_box(wd#, wd#, 0.7 ht#, 0.7 ht#);
black_notehead_width# := wd#;
- save za, zb, zc, alpha, size;
- pair za, zb, zc;
+ save za, alpha, size;
+ pair za;
define_pixels(ht, wd);
alpha = 35;
size = 0.7ht;