MCI Command String笔记

MCI Command String是多媒体设备的程序接口。通过它,我们可以打开一个多媒体文件,例如mp3,VCD,Mpeg4格式的文件等等,并对它进行播放,暂停,关闭 等操作。现在介绍一下MCI Command String的使用方法。

#include<mmsystem.h> //音乐播放的头文件

MCI Command String是通过mciExecute或mciSendString两个函数执行的。这两个函数的声明如下:
 
Private Declare Function mciExecute Lib "winmm.dll" Alias "mciExecute" (ByVal lpstrCommand As String) As Long
 
Private Declare Function mciSendString Lib "winmm.dll" Alias "mciSendStringA" (ByVal lpstrCommand As String, ByVal lpstrReturnString As String, ByVal uReturnLength As Long, ByVal hwndCallback As Long) As Long

函数如下:

mciSendString(LPCTSTR lpstrCommand,LPTSTR lpstrReturnString,UINT uReturnLength,HWND hwndCallback);

mciExecute(LPCSTR pszCommand);

 

这两个函数都有一个叫lpstrCommand的参数, 这个参数就是我们今天要介绍的MCI Command String。其中函数mciSendString还有三个参数,lpstrReturnString是一个字符串,它用来接收 mciSendString函数返回的信息(例如,我们在lpstrCommand中的命令是让函数返回打开的文件的设备类型,那么函数就把设备类型的信 息保存在lpstrReturnString参数中。);uReturnLength参数用来指定参数lpstrReturnString的长 度;hwndCallback是接收"wait"、"notify"消息的窗口句柄,在Visual Basic中调用时该参数设为0即可。

mciSendString(字符串,"",0,NULL);//一般常用形式

 

在熟悉了这两个函数后,我们就可以进入正题――MCI Command String了。
 
MCI Command String的命令格式是这样的:lpszCommand lpszDevice lpszCommandFlag lpazFlag
 
lpszCommand是mci命令,例如open,play,stop,close等等,用于操作文件的方式
 
lpszDevice是设备名(或文件名)。例如,我们用以下的程序打开了我的文档中的Music01.dat文件,并用"alias"参数将其别名设为 OpenFile:

dim lReturn as long (1)
 
lReturn=mciExecute("open C:/Mydocu~1/Music01.dat alias OpenFile type MPEGVideo") (2)
 
那么,在以后的MCI Command String中lpszDevice参数必须指定为OpenFile。例如,关闭该文件的代码如下:
 
lReturn=mciExecute("close OpenFile") (3)
 
如果我们没有为打开的文件设定别名,则以后调用的MCI Command String中lpszDevice参数为DOS路径名加文件名。例子如下:
 
dim lReturn as long (4)
 
lReturn=mciExecute("open C:/Mydocu~1/Music01.dat type MPEGVideo") (5)
 
lReturn=mciExecute("close C:/Mydocu~1/Music01.dat type MPEGVideo") (6)
 
从这里可以看出,设定别名的好处是减少了代码的输入。
 
LpszCommandFlag是mci命令的参数。如上代码(2),"alias OpenFile"以及"type MPEGVideo"就是命令"open"的参数。通常一个mci命令的参数少则几个多则几十个。
 
LpazFlag可以为指定为"wait"或"notity"。如果为"wait",那么mci命令执行完毕后会向父窗体发送MCI_WAIT消 息,"notity"则发送MCI_NOTIFY消息。此参数在Visual Basic中无甚用处。
 
 
在此先声明一下,微软提供的winmm.dll函数库支持的多媒体设备的类型共有 cdaudio,dat,digitalvideo,other,overlay,scanner,sequencer,vcr,videodisc,waveaudio 十种(注意:winmm.dll函数库不支持RealPlay格式的文件。您可以用以下代码获得已打开的文件的类 型:lReturn=mciSendString("capability lpszDevice device type",sReturn,32,0) )。至于哪一类设备支持哪些参数,您可以在MSDN中查找关键字"MCI Command Strings",选中所列出的命令,在其中的HTML帮助文档中通常会有一个表格告诉你哪些设备支持哪些参数或者在第一段中有信息告诉您哪些设备支持该 命令。
 
好了,现在让我们对又繁索,又该死,又强大的mci命令参数作一个系统的介绍。(限于篇幅,本文仅介绍大部份主要命令的参数。)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值