导入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());
内容来源于网络如有侵权请私信删除

文章来源: 博客园

原文链接: https://www.cnblogs.com/optimo/p/13716322.html

你还没有登录,请先登录注册
  • 还没有人评论,欢迎说说您的想法!