MIDI转音频
fluidsynth d:\sf2\TYRolandSFX.sf2 c:\windows\media\onestop.mid -afile -Eauto -Fonestop.wav -g0.25 -in -Ofloat -r44100 -Twav
案例解析
- 首先,我们提供了 SF2 音色文件 d:\sf2\TYRolandSFX.sf2 和 MIDI 文件 c:\windows\media\onestop.mid。
- 然后,我们指定音频驱动为“file”,这使得 FluidSynth 能将音频流输出到文件。
- 我们设置音频文件的字节序为"auto"(系统推荐的字节序)。
- 接着我们指定要输出的音频文件名叫做“onestop.wav”。(这是相对于工作目录的路径。若要输出到其他文件夹,请指定绝对路径)
- 我们调节了音量增益为 0.25 dB。
- 我们使用了
-i参数禁用内置命令行,以及-n参数禁用 MIDI 输入设备。这里使用了多个参数合并的写法。在 FluidSynth 的源代码中默认使用了 getopt 函数用以实现参数的解析,它支持多参合并。但这取决于你的编译环境是否支持这个函数。若不支持 getopt 函数,则请勿采用上面的多参合并写法。
需要注意的是:
1. 可能会与长参数名冲突。
长参数的开头可以只有一个“-”。但若已经定义--bar长参数,且还是想同时传入-b-a-r短参数时,则需要颠倒它们的顺序以保证不冲突,可以写成:-arb,或者直接分开单独写。
2. 要求传入值的短参数名不可采用此写法。
例如上文的-a-E等参数要求我们传值。所以必须将它单独作为一个字段写出来。
- 我们指定了采样位深度为 32 位浮点,采样频率为 44100Hz,文件格式为 WAV。
运行结果
若一切正常,在工作目录下将会生成一个 onestop.wav 音频文件。