//打开设备
//typedef struct {
//DWORD dwCallback;        //指定一个窗口句柄
//MCIDEVICEID wDeviceID;   //为成功打开的文件返回 设备标识符. 
//LPCSTR lpstrDeviceType;  //设备类型的名字或常量标识. (设备名可以从注册表或者 SYSTEM.INI 文件中获得) 
//LPCSTR lpstrElementName; //设备元素 (通常是打开的文件全路径). 
//LPCSTR lpstrAlias//可选别名
//DWORD dwBufferSeconds;
//} MCI_WAVE_OPEN_PARMS;

//播放文件
//typedef struct {
//DWORD dwCallback;//指定一个窗口句柄
//DWORD dwFrom;//设置播放起始点
//DWORD dwTo;//设置播放结束点
//} MCI_PLAY_PARMS;

//查询信息
//typedef struct {
//DWORD dwCallback;
//DWORD dwReturn;//返回的信息内容
//DWORD dwItem;//请求查询的内容
//DWORD dwTrack;//轨道的长度或数目
//} MCI_STATUS_PARMS;

/*
 * 函数名称:MCI_Open
 * 函数介绍:用mci命令打开文件
 * 输入参数:CString strPath, 文件的路径
 * 输出参数:无
 * 返回值 :mci命令的错误信息
 */

  1. DWORD dlg_login::MCIOpen(const CString &strPath)
  2. {
  3. //打开MCI设备
  4. MCI_OPEN_PARMS mciOP;
  5. DWORD opReturn;
  6. MCIDEVICEID wIDDevioce;  //保存设备ID
  7. mciOP.lpstrDeviceType = NULL;
  8. mciOP.lpstrElementName = strPath;  //设置打开的文件的名称
  9. opReturn = mciSendCommand(NULL, MCI_OPEN, MCI_OPEN_ELEMENT, (DWORD)(LPVOID)&mciOP);
  10. if (opReturn == 0)
  11. {
  12. wIDDevioce = mciOP.wDeviceID;//播放设备Id
  13. wDevioceId = mciOP.wDeviceID;
  14. //设置设备信息
  15. MCI_SET_PARMS mciSet;
  16. mciSet.dwTimeFormat = MCI_FORMAT_MILLISECONDS; //设置时间单位为毫秒
  17. mciSendCommand(wDevioceId, MCI_SET, MCI_SET_TIME_FORMAT, (DWORD)(LPVOID)&mciSet);
  18. //设置当前播放位置跳转60秒
  19. MCISeek(100);
  20. //音频播放
  21. MCIPlay();
  22. MCI_STATUS_PARMS mciStatus;
  23. mciStatus.dwItem = MCI_STATUS_TIME_FORMAT;
  24. DWORD sta2Return = mciSendCommand(wIDDevioce, MCI_STATUS, MCI_STATUS_ITEM, (DWORD)(LPVOID)&mciStatus);
  25. DWORD music_timestyle = mciStatus.dwReturn; //获得当前的时间格式
  26. mciStatus.dwItem = MCI_STATUS_MODE;
  27. DWORD sta3Return = mciSendCommand(wIDDevioce, MCI_STATUS, MCI_STATUS_ITEM, (DWORD)(LPVOID)&mciStatus);
  28. DWORD music_playstyle = mciStatus.dwReturn; //获得当前播放工作模式 播放 526  暂停525
  29. }
  30. else
  31. wIDDevioce = NULL;
  32. return opReturn;
  33. }
DWORD dlg_login::MCIOpen(const CString &strPath)
{
//打开MCI设备
MCI_OPEN_PARMS mciOP;
DWORD opReturn;
MCIDEVICEID wIDDevioce; //保存设备ID
mciOP.lpstrDeviceType = NULL;
mciOP.lpstrElementName = strPath; //设置打开的文件的名称
opReturn = mciSendCommand(NULL, MCI_OPEN, MCI_OPEN_ELEMENT, (DWORD)(LPVOID)&mciOP);
if (opReturn == 0)
{
wIDDevioce = mciOP.wDeviceID;//播放设备Id
wDevioceId = mciOP.wDeviceID; //设置设备信息
MCI_SET_PARMS mciSet;
mciSet.dwTimeFormat = MCI_FORMAT_MILLISECONDS; //设置时间单位为毫秒
mciSendCommand(wDevioceId, MCI_SET, MCI_SET_TIME_FORMAT, (DWORD)(LPVOID)&mciSet); //设置当前播放位置跳转60秒
MCISeek(100);
//音频播放
MCIPlay(); MCI_STATUS_PARMS mciStatus;
mciStatus.dwItem = MCI_STATUS_TIME_FORMAT;
DWORD sta2Return = mciSendCommand(wIDDevioce, MCI_STATUS, MCI_STATUS_ITEM, (DWORD)(LPVOID)&mciStatus);
DWORD music_timestyle = mciStatus.dwReturn; //获得当前的时间格式 mciStatus.dwItem = MCI_STATUS_MODE;
DWORD sta3Return = mciSendCommand(wIDDevioce, MCI_STATUS, MCI_STATUS_ITEM, (DWORD)(LPVOID)&mciStatus);
DWORD music_playstyle = mciStatus.dwReturn; //获得当前播放工作模式 播放 526 暂停525
}
else
wIDDevioce = NULL;
return opReturn;
}
  1. DWORD dlg_login::MCIPlay()
  2. {
  3. MCI_PLAY_PARMS mciPP;
  4. DWORD opReturn;
  5. opReturn = mciSendCommand(wDevioceId, MCI_PLAY, MCI_NOTIFY, (DWORD)&mciPP);
  6. return opReturn;
  7. }
DWORD dlg_login::MCIPlay()
{
MCI_PLAY_PARMS mciPP;
DWORD opReturn;
opReturn = mciSendCommand(wDevioceId, MCI_PLAY, MCI_NOTIFY, (DWORD)&mciPP);
return opReturn;
}
  1. DWORD dlg_login::MCIStatus_music_length()
  2. {
  3. MCI_STATUS_PARMS mciStatus;
  4. mciStatus.dwItem = MCI_STATUS_LENGTH;
  5. DWORD staReturn = mciSendCommand(wDevioceId, MCI_STATUS, MCI_STATUS_ITEM, (DWORD)(LPVOID)&mciStatus);
  6. DWORD music_alltime = mciStatus.dwReturn / 1000; //音乐总时间
  7. return music_alltime;
  8. }
DWORD dlg_login::MCIStatus_music_length()
{
MCI_STATUS_PARMS mciStatus;
mciStatus.dwItem = MCI_STATUS_LENGTH;
DWORD staReturn = mciSendCommand(wDevioceId, MCI_STATUS, MCI_STATUS_ITEM, (DWORD)(LPVOID)&mciStatus);
DWORD music_alltime = mciStatus.dwReturn / 1000; //音乐总时间
return music_alltime;
}
  1. DWORD dlg_login::MCIStatus_music_pos()
  2. {
  3. MCI_STATUS_PARMS mciStatus;
  4. mciStatus.dwItem = MCI_STATUS_POSITION;
  5. DWORD sta1Return = mciSendCommand(wDevioceId, MCI_STATUS, MCI_STATUS_ITEM, (DWORD)(LPVOID)&mciStatus);
  6. DWORD music_timeing = mciStatus.dwReturn / 1000; //音乐当前播放时间
  7. return music_timeing;
  8. }
DWORD dlg_login::MCIStatus_music_pos()
{
MCI_STATUS_PARMS mciStatus;
mciStatus.dwItem = MCI_STATUS_POSITION;
DWORD sta1Return = mciSendCommand(wDevioceId, MCI_STATUS, MCI_STATUS_ITEM, (DWORD)(LPVOID)&mciStatus);
DWORD music_timeing = mciStatus.dwReturn / 1000; //音乐当前播放时间
return music_timeing;
}
  1. //从制定位置开始播放
  2. void send_music_from_pos()
  3. {
  4. MCI_STATUS_PARMS mciStatus;
  5. mciStatus.dwItem = MCI_STATUS_POSITION;
  6. DWORD sta1Return = mciSendCommand(wDevioceId, MCI_STATUS, MCI_STATUS_ITEM, (DWORD)(LPVOID)&mciStatus);
  7. DWORD music_timeing = mciStatus.dwReturn / 1000; //音乐当前播放时间
  8. MCI_PLAY_PARMS PlayParms;
  9. PlayParms.dwFrom = music_timeing; // 指定从什么地方(时间)播放
  10. DWORD ret1 = mciSendCommand(wDevioceId, MCI_PLAY, MCI_NOTIFY, (DWORD)(LPVOID)&PlayParms);
  11. }
//从制定位置开始播放
void send_music_from_pos()
{
MCI_STATUS_PARMS mciStatus;
mciStatus.dwItem = MCI_STATUS_POSITION;
DWORD sta1Return = mciSendCommand(wDevioceId, MCI_STATUS, MCI_STATUS_ITEM, (DWORD)(LPVOID)&mciStatus);
DWORD music_timeing = mciStatus.dwReturn / 1000; //音乐当前播放时间
MCI_PLAY_PARMS PlayParms;
PlayParms.dwFrom = music_timeing; // 指定从什么地方(时间)播放
DWORD ret1 = mciSendCommand(wDevioceId, MCI_PLAY, MCI_NOTIFY, (DWORD)(LPVOID)&PlayParms);
}

//关闭指定设备

  1. void close_mci()
  2. {
  3. DWORD retclose=mciSendCommand(wDevioceId, MCI_CLOSE, NULL, NULL);
  4. }
void close_mci()
{
DWORD retclose=mciSendCommand(wDevioceId, MCI_CLOSE, NULL, NULL);
}
  1. //调节音量
  2. DWORD dlg_login::MCISetVolume(DWORD dwVol)
  3. {
  4. MCI_DGV_SETAUDIO_PARMS  mciSetAudioPara;
  5. mciSetAudioPara.dwCallback  = NULL;
  6. mciSetAudioPara.dwItem   = MCI_DGV_SETAUDIO_VOLUME;
  7. mciSetAudioPara.dwValue  = dwVol; //此处就是音量大小 (0--1000)
  8. DWORD dwReturn = mciSendCommand(wDevioceId, MCI_SETAUDIO, MCI_DGV_SETAUDIO_VALUE |  MCI_DGV_SETAUDIO_ITEM, (DWORD)(LPVOID)&mciSetAudioPara);
  9. return dwReturn;
  10. }
//调节音量
DWORD dlg_login::MCISetVolume(DWORD dwVol)
{
MCI_DGV_SETAUDIO_PARMS mciSetAudioPara;
mciSetAudioPara.dwCallback = NULL;
mciSetAudioPara.dwItem = MCI_DGV_SETAUDIO_VOLUME;
mciSetAudioPara.dwValue = dwVol; //此处就是音量大小 (0--1000)
DWORD dwReturn = mciSendCommand(wDevioceId, MCI_SETAUDIO, MCI_DGV_SETAUDIO_VALUE | MCI_DGV_SETAUDIO_ITEM, (DWORD)(LPVOID)&mciSetAudioPara);
return dwReturn;
}

jpg改rar 

mciSendCommand 音频视频播放命令函数的更多相关文章

  1. CS中调用微软自带com组件实现音频视频播放(wf/wpf)

    1.mp3播放器:工具箱中右键,在弹出的菜单中选择“选择项”,添加“com组件”,选择名称“windows Media Player",点击确定就会在工具箱新增一个“windows Medi ...

  2. shell中的内建命令, 函数和外部命令

    转自shell中的内建命令, 函数和外部命令 Shell识别三种基本命令:内建命令.Shell函数以及外部命令: (1)内建命令就是由Shell本身所执行的命令.    有些命令是由于其必要性才内建的 ...

  3. HTML5学习总结-04 音频&视频播放

    一 音频播放 1 Audio(音频) HTML5提供了播放音频文件的标准 2 control(控制器) control属性攻添加播放,暂停和音量空间. 3 标签定义声音 <audio> 例 ...

  4. php 执行linux 命令函数

    php的内置函数exec,system都可以调用系统命令(shell命令),当然还有passthru,escapeshellcmd等函数. 在很多时候利用php的exec,system等函数调用系统命 ...

  5. 关于exec命令函数

    exec执行某命令在命令行下没有问题,但是在php中就出错.这个问题99.99%与权限有关,但是exec执行的命令不会返回错误.一个技巧就是使用管道命令,假设你的exec调用如下: exec('con ...

  6. PHP执行系统外部命令函数:exec()、passthru()、system()、shell_exec()

    php提供4种方法执行系统外部命令:exec().passthru().system(). shell_exec().在开始介绍前,先检查下php配置文件php.ini中是有禁止这是个函数.找到 di ...

  7. PHP在Linux下Apache环境中执行exec,system,passthru等服务器命令函数

    更多内容推荐微信公众号,欢迎关注: 若在服务器中使用php test.php运行exec,system,passthru等命令相关的脚本能成功运行,在web页面却没反应, [可能是服务器端,PHP脚本 ...

  8. 【转】shell中的内建命令, 函数和外部命令

    原文:http://www.cnblogs.com/xkfz007/archive/2011/10/13/2209571.html linux命令有内部命令和外部命令之分.内部命令实际上是shell程 ...

  9. FFMPEG 音频转换命令

    音频转换: .转换amr到mp3: ffmpeg -i shenhuxi.amr amr2mp3.mp3 .转换amr到wav: ffmpeg -acodec libamr_nb -i shenhux ...

随机推荐

  1. 连载:面向对象葵花宝典:思想、技巧与实践(35) - NOP原则

    NOP.No Overdesign Priciple.不要过度设计原则. 这应该是你第一次看到这个原则.而且你也不用上网查了,由于这个不是大师们创造的,而是我创造的:) 之所以提出这个原则,是我自己吃 ...

  2. 使用maven开发OSGI样例

    一:创建maven项目,在pom.xml里面增加例如以下依赖 <dependency> <groupId>org.osgi</groupId> <artifa ...

  3. stm32 堆和栈(stm32 Heap & Stack)

    关于堆和栈已经是程序员的一个月经话题,大部分有是基于os层来聊的. 那么,在赤裸裸的单片机下的堆和栈是什么样的分布呢?以下是网摘: 刚接手STM32时,你只编写一个 int main() { whil ...

  4. Go语言核心之美 4.3-多返回值

    在Go语言中.函数能够有多个返回值,这个特性我们已经在之前的样例见过非常多,非常多标准库函数都会返回两个值,一个是期望得到的函数执行结果,另外一个是函数出错时的错误值. 以下的程序是findlinks ...

  5. [elk]Mutate filter plugin增删改查字段

    Mutate filter plugin参考: https://www.elastic.co/guide/en/logstash/current/plugins-filters-mutate.html ...

  6. Ubuntu/Debian下编译PC版的ffmpeg

    1.安装git: 在命令行下执行 sudo apt-get install git-core 2.下载最新版本的ffmpeg: git clone git://source.ffmpeg.org/ff ...

  7. char数组与string转换

    1.char数组转string 有很多种方法: 假设c字符串定义为char ch[]="hello world!"; 1.向构造函数传入c字符串创建string对象: string ...

  8. Scanner.findInLine()与while的使用莫名其妙的导致NoSuchElementException: No line found

    public static boolean parseHTML(Scanner sc, List<String> errorInfo) { String[] tags = new Stri ...

  9. scala中计算的的一个小问题,超出Int.maxValue时不会报错

    如果小于Int.max时他不会报错 def sumcount(str:String): Int ={ val ints = for(c <- str)yield { println(c.asIn ...

  10. [Linux内核]软中断、tasklet、工作队列

    转自:http://www.cnblogs.com/li-hao/archive/2012/01/12/2321084.html 软中断.tasklet和工作队列并不是Linux内核中一直存在的机制, ...