使用WindowsAPI获取录音音频

严禁转载

介绍使用winmm.h进行音频流的获取

 

首先需要包含以下引用对象

#include <Windows.h>
#include "mmsystem.h"
#pragma comment(lib, "winmm.lib")

音频的获取需要调用7个函数

1. waveInGetNumDevs:返回系统中就绪的波形声音输入设备的数量

UINT waveInGetNumDevs(VOID);

2. waveInGetDevCaps:检查指定波形输入设备的特性

MMRESULT waveInGetDevCaps( 

  UINT_PTR     uDeviceID,  

  LPWAVEINCAPS pwic,       

  UINT         cbwic       

);

//uDeviceID 音频输入设备标识,也可以为一个打开的音频输入设备的句柄.

//    个人认为如果上一步获得了多个设备,可以用索引标识每一个设备.

//    

//pwic 对WAVEINCAPS结构体的一个指针,包含设备的音频特性.

//

//cbwic WAVEINCAPS结构体的大小,使用sizeof即可.

//

//MMRESULT 函数执行的结果

//    MMSYSERR_NOERROR 表示执行成功

//    MMSYSERR_BADDEVICEID 索引越界 

//    MMSYSERR_NODRIVER 没有就绪的设备 

//    MMSYSERR_NOMEM 不能分配或者锁定内存

 介绍WAVEINCAPS结构体的含义

typedef struct { 

    WORD      wMid;                //音频设备制造商定义的驱动程序标识

    WORD      wPid;                //音频输入设备的产品标识

    MMVERSION vDriverVersion;        //驱动程序版本号

    TCHAR     szPname[MAXPNAMELEN];//制造商名称

    DWORD     dwFormats;            //支持的格式,参见MSDN

    WORD      wChannels;            //支持的声道数

    WORD      wReserved1;            //保留参数

} WAVEINCAPS;

3. waveInOpen:打开指定的音频输入设备,进行录音

MMRESULT waveInOpen(

  LPHWAVEIN       phwi,                //接收打开的音频输入设备标识的HWAVEIN结构的指针

  UINT_PTR       uDeviceID,            //指定一个需要打开的设备标识.可以使用WAVE_MAPPER选择一个按指定录音格式录音的设备

  LPWAVEFORMATEX pwfx,                //一个所需的格式进行录音的WAVEFORMATEX结构的指针 

  DWORD_PTR      dwCallback,        //指向一个回调函数、事件句柄、窗口句柄、线程标识,对录音事件进行处理.

  DWORD_PTR      dwCallbackInstance, //传给回调机制的参数

  DWORD          fdwOpen            //打开设备的方法标识,指定回调的类型.参见CSDN

);

介绍WAVEFORMATEX结构体的含义

typedef struct { 

    WORD  wFormatTag;        //波形声音的格式,单声道双声道使用WAVE_FORMAT_PCM.当包含在WAVEFORMATEXTENSIBLE结构中时,使用WAVE_FORMAT_EXTENSIBLE.

    WORD  nChannels;        //声道数量

    DWORD nSamplesPerSec;    //采样率.wFormatTag为WAVE_FORMAT_PCM时,有8.0kHz,11.025kHz,22.05kHz,和44.1kHz.

    DWORD nAvgBytesPerSec;    //每秒的采样字节数.通过nSamplesPerSec * nChannels * wBitsPerSample / 8计算

    WORD  nBlockAlign;        //每次采样的字节数.通过nChannels * wBitsPerSample / 8计算

    WORD  wBitsPerSample;    //采样位数.wFormatTag为WAVE_FORMAT_PCM时,为8或者16

    WORD  cbSize;            //wFormatTag为WAVE_FORMAT_PCM时,忽略此参数

} WAVEFORMATEX;

介绍dwCallback回调函数格式

void CALLBACK waveInProc(

  HWAVEIN hwi,          //回调此函数的设备句柄

  UINT uMsg,            //波形声音输入信息,标识关闭(WIM_CLOSE)、缓冲区满(WIM_DATA)、打开(WIM_OPEN).

  DWORD_PTR dwInstance, //用户在waveInOpen指定的数据

  DWORD_PTR dwParam1,   //(LPWAVEHDR)dwParam1,用户指定的缓冲区

  DWORD_PTR dwParam2     

);

4. waveInPrepareHeader:为音频输入设备准备一个缓冲区

MMRESULT waveInPrepareHeader(

  HWAVEIN hwi,    //音频输入设备句柄

  LPWAVEHDR pwh,//指向WAVEHDR结构的指针,标识准备的缓冲区

  UINT cbwh        //WAVEHDR结构的大小,使用sizeof即可

);


介绍WAVEHDR结构

typedef struct wavehdr_tag { 

    LPSTR      lpData;          //指向波形格式的缓冲区

    DWORD      dwBufferLength;  //缓冲区的大小

    DWORD      dwBytesRecorded; //当前存储了多少数据

    DWORD_PTR  dwUser;          //用户数据

    DWORD      dwFlags;            //为缓冲区提供的信息,在waveInPrepareHeader函数中使用WHDR_PREPARED

    DWORD      dwLoops;         //输出时使用,标识播放次数

    struct wavehdr_tag * lpNext;//reserved

    DWORD_PTR reserved;         //reserved

} WAVEHDR, *LPWAVEHDR; 

5. waveInAddBuffer:将缓冲区发送给设备,若缓冲区填满,则不起作用。(参数同上)

MMRESULT waveInAddBuffer(

  HWAVEIN hwi, 

  LPWAVEHDR pwh, 

  UINT cbwh 

); 

6. waveInStart:开始进行录制

MMRESULT waveInStart(

  HWAVEIN hwi  //设备句柄

);

7. waveInClose:关闭设备

MRESULT waveInClose(

  HWAVEIN hwi  //设备句柄

);

 如下示例:

http://download.csdn.net/detail/long7782/7771019

 

你可能感兴趣的:(windows)