导入winmm.dll中的函数mciSendString

[DllImport("winmm.dll")]

static extern Int32 mciSendString(String command, StringBuilder buffer, Int32 bufferSize, IntPtr hwndCallback);

需要注意的是,所有命令需要在同一个线程中,才可以对同一个midi实例进行控制。该函数通过字符串向声卡发送指令,常见的用于播放midi文件的指令有以下:

1.打开文件

mciSendString($"open {file} type {device} alias {alias}", null, 0, new IntPtr());

{file}: 文件名,需要打开的midi文件路径;

{device}: 设备名称,一般填写”sequencer”,不过笔者发现填写”mpegvideo”会显著提高加载midi的速度;

{alias}: 别名,用于后续对该midi的控制。

2.播放文件

mciSendString($"play {alias} [repeat]", null, 0, new IntPtr());

{alias}: 前文提到的别名;

[repeat]: 可选指令,可以循环播放。

3.获取文件时长

mciSendString("set {alias} time format milliseconds", null, 0, new IntPtr());

mciSendString("status {alias} length", result, 100, new IntPtr());

首先将时间格式设置为毫秒,然后将时间读取到result变量中。

4.停止播放

mciSendString($"stop {alias}", null, 0, new IntPtr());

5.关闭文件

mciSendString($"close {alias}", null, 0, new IntPtr());

内容来源于网络如有侵权请私信删除

Logo

魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。

更多推荐