使用Lilypond排版简谱
这两天我想做一个简谱,在网上搜索乐谱排版软件,发现了基于GPL协议的Lilypond软件。只不过Lilypond是用来做五线谱的。幸好,又找到剑桥大学 Silas S. Brown 编写的一个 jianpu-ly.py 脚本,通过调用Lilypond能够最终生成简谱。关于它的详细介绍请看这里。
该脚本支持的简谱语法规则如下:
- 音阶:1 2 3 4 5 6 7 1’
- 空拍:0
- 升、降音:#1 b2
- 低两个八度、低八度、中音、高八度、高两个八度:1,, 1, 1 1’ 1’’
- 六十四分、三十二分、十六分、八分、四分音符(一拍):h1 d1 s1 q1 1
- 符点音符:s1. q1. 1.
- 半音符(两拍):1 -
- 符点半音符(三拍):1 - -
- 全音符(四拍):1 - - -
- 拍子:4/4
- 大调:1=Bb
- 小调:6=F#
- 标题:title=采茶舞曲
- 三联音:3[ q1 q1 q1 ]
- 重复:R{ 1 1 1 } A{ 2 | 3 }
同时在原始脚本的基础之上我还作了一些修改,增加了乐曲速度(tempo)设定功能。
一个典型的简谱源文件如下:
%% tempo: 4=60
title=标题
1=C
2/4
1 2 3 4 5 6 7 1'
将该文件存为jianpu.txt
后,先调用jianpu-ly.py
生成Lilypond输入文件:
jianpu-ly.py < jianpu.txt > jianpu.ly
然后调用lilypond
程序,生成指定格式的乐谱文件。令人惊喜的是,不光可以排版出PDF、PS、PNG等格式的简谱,还可以生成midi文件,直接播放试听。可以用如下方式调用lilypond
:
# 生成PDF文件、midi文件
lilypond jianpu.ly
# 生成png文件、midi文件
lilypond --png jianpu.ly
# 生成ps文件、midi文件
lilypond --ps jianpu.ly
可以用timidity
直接播放生成的midi文件,或者将其转换为RIFF wav格式,再用普通的音频播放器来听。
timidity -Ow -o jianpu.wav jianpu.midi
为了方便使用,我编写了一个bash脚本make_jianpu.sh
,用于将上述几个命令的执行自动化。
此外,我在使用的过程中发现,若使用默认的Lilypond设置,虽然能够生成正确的midi文件,但却无法排版出升、降与还原号(accidentals)。经过一番试探,发现只要在/usr/share/lilypond/2.14.2/ly/engraver-init.ly
文件中第168行添加:
\consists "Accidental_engraver"
便可以解决该问题。这是因为,经jianpu-ly.py
脚本转换生成的Lilypond文件基于的是RhythmicStaff context。而engraver-init.ly
中的默认配置并未包括对accidentals的“雕刻”(engrave)。所以,需要手动加上。
至此,用于简谱排版的工具已经俱备。我试着编排了《博基上校进行曲》片段如下。大家可以体验一下Lilypond的效果。
源文件:
%% tempo: 4=120
title=博基上校进行曲
arranger=排版:皮波迪先生@豆瓣 2016-02-14
1=C
2/4
q1' q0 q7. s6 q5 q3 q1 q3 q5 s5 s6 q5 s5 s6 5 -
R{ q5 q3 0 q0 q3 q4 q5 3' 3' 1' - q5 q3 0 q0 q3 q4 q3 5 5 4 - q4 q2 0 }
A{ q0 q2 q3 q4 q5 q3 0 q0 q3 q4 q3 q2 5 q3 q#4 2 q6 5 ( - 5 ) - |
q0 q6 q7 q6 } q1' q5 0 q0 q5 q4 q3 q2 6 q2 q7, 5 q7, 1 ( - 1 ) q3 q3 1'. q7 s6 s#5 q6 q5 q4 3 ( - q3 ) q3 q4 q3 6 q#5. s6 1' q6. s1' #2' ( - #2' ) 6 3'. q2' s1' s7 q6 q#5. s6 2. q4 q6 q0 s1' s7 s1' s2' q3' q0 q7. s1' 6 ( - 6 ) q3 q3 1'. q7 s6 s#5 q6 q5 q4 3 ( - q3 ) q3 q4 q3 6 q#5. s6 1' q6. s1' #2' ( - #2' ) 6 3'. q2' s1' s7 q6 q#5. s6 2. q4 q6 q0 s1' s7 s1' s2' q3' q0 q7. s1' 6 ( - 6 ) 5 \ff
简谱:
jianpu-ly.py
与make_jianpu.sh
的源代码可以在这里下载。