Windows波形音频MMEAPI简介

news/2024/9/22 17:53:04/

Windows波形音频MMEAPI简介

使用MMEAPI时需要导入头文件:#include<mmeapi.h>

mmeapi.h文件的主要内容

mmeapi.h 文件是 Windows 多媒体 API 的一部分,主要用于处理波形音频(Waveform Audio)的输入和输出。以下是该文件的主要内容和功能:

  1. 错误返回值
    定义了一些波形音频操作的错误返回值,例如:
  • WAVERR_BADFORMAT:不支持的波形格式。
  • WAVERR_STILLPLAYING:仍有音频在播放。
    • WAVERR_UNPREPARED:音频头未准备好。
    • WAVERR_SYNC:设备是同步的。
  1. 数据类型
    定义了一些与波形音频相关的数据类型,例如:
    • HWAVE、HWAVEIN、HWAVEOUT:波形音频设备的句柄。
    • WAVECALLBACK:波形音频回调函数类型。

  2. 回调消息
    定义了一些波形音频设备的回调消息,例如:
    • WOM_OPEN、WOM_CLOSE、WOM_DONE:波形输出设备的回调消息。
    • WIM_OPEN、WIM_CLOSE、WIM_DATA:波形输入设备的回调消息。

  3. 设备 ID
    定义了波形设备映射器的设备 ID:
    • WAVE_MAPPER:用于波形设备映射器的设备 ID。

  4. 标志
    定义了一些用于 waveOutOpen 和 waveInOpen 函数的标志,例如:
    • WAVE_FORMAT_QUERY:查询格式。
    • WAVE_ALLOWSYNC:允许同步。
    • WAVE_MAPPED、WAVE_FORMAT_DIRECT 等。

  5. 数据块头
    定义了波形数据块头的结构体 WAVEHDR,包括以下字段:
    • lpData:指向数据缓冲区的指针。
    • dwBufferLength:数据缓冲区的长度。
    • dwBytesRecorded:仅用于输入。
    • dwUser:供客户端使用。
    • dwFlags:各种标志。
    • dwLoops:循环控制计数器。
    • lpNext、reserved:保留给驱动程序使用。

  6. 设备能力结构
    定义了波形输出设备和输入设备的能力结构体,例如:
    • WAVEOUTCAPS、WAVEINCAPS:描述设备的能力,包括制造商 ID、产品 ID、驱动程序版本、支持的格式、通道数等。

  7. 标志字段
    定义了一些用于 WAVEHDR 和设备能力结构体的标志字段,例如:
    WHDR_DONEWHDR_PREPAREDWHDR_BEGINLOOPWHDR_ENDLOOPWHDR_INQUEUE:用于 WAVEHDR 的标志。
    WAVECAPS_PITCHWAVECAPS_PLAYBACKRATEWAVECAPS_VOLUMEWAVECAPS_LRVOLUMEWAVECAPS_SYNCWAVECAPS_SAMPLEACCURATE:用于设备能力结构体的标志。

使用 waveOutOpen 函数打开一个波形音频输出设备

以下是一个简单的示例,展示如何使用 waveOutOpen 函数打开一个波形音频输出设备:

#include <windows.h>
#include <mmeapi.h>void OpenWaveOutDevice() {HWAVEOUT hWaveOut;WAVEFORMATEX wfx;// 设置波形格式wfx.nSamplesPerSec = 44100; // 采样率wfx.wBitsPerSample = 16;    // 每个样本的位数wfx.nChannels = 2;          // 通道数(立体声)wfx.cbSize = 0;             // 额外信息的大小wfx.wFormatTag = WAVE_FORMAT_PCM; // PCM 格式wfx.nBlockAlign = (wfx.wBitsPerSample * wfx.nChannels) / 8;wfx.nAvgBytesPerSec = wfx.nSamplesPerSec * wfx.nBlockAlign;// 打开波形音频输出设备if (waveOutOpen(&hWaveOut, WAVE_MAPPER, &wfx, 0, 0, CALLBACK_NULL) != MMSYSERR_NOERROR) {// 处理错误}
}

使用 waveInOpen 函数打开一个波形音频输入设备

要使用 waveInOpen 函数打开一个波形音频输入设备,你需要按照以下步骤进行操作:

  1. 定义波形音频格式:使用 WAVEFORMATEX 结构体定义音频格式。
  2. 调用 waveInOpen 函数:传递设备句柄、设备 ID、音频格式、回调函数等参数。
    以下是一个示例,展示如何使用 waveInOpen 函数打开一个波形音频输入设备:
#include <windows.h>
#include <mmeapi.h>
#include <iostream>// 回调函数,用于处理音频输入事件
void CALLBACK WaveInProc(HWAVEIN hwi,UINT uMsg,DWORD_PTR dwInstance,DWORD_PTR dwParam1,DWORD_PTR dwParam2
) {switch (uMsg) {case WIM_OPEN:std::cout << "Wave input device opened." << std::endl;break;case WIM_CLOSE:std::cout << "Wave input device closed." << std::endl;break;case WIM_DATA:std::cout << "Wave input data received." << std::endl;break;}
}int main() {HWAVEIN hWaveIn;WAVEFORMATEX wfx;// 设置波形格式wfx.nSamplesPerSec = 44100; // 采样率wfx.wBitsPerSample = 16;    // 每个样本的位数wfx.nChannels = 2;          // 通道数(立体声)wfx.cbSize = 0;             // 额外信息的大小wfx.wFormatTag = WAVE_FORMAT_PCM; // PCM 格式wfx.nBlockAlign = (wfx.wBitsPerSample * wfx.nChannels) / 8;wfx.nAvgBytesPerSec = wfx.nSamplesPerSec * wfx.nBlockAlign;// 打开波形音频输入设备MMRESULT result = waveInOpen(&hWaveIn, WAVE_MAPPER, &wfx, (DWORD_PTR)WaveInProc, 0, CALLBACK_FUNCTION);if (result != MMSYSERR_NOERROR) {std::cerr << "Failed to open wave input device." << std::endl;return 1;}std::cout << "Wave input device opened successfully." << std::endl;// 关闭波形音频输入设备waveInClose(hWaveIn);return 0;
}

WAVE_FORMAT常量解析:

#define WAVE_FORMAT_1M08      0x00000001       /* 11.025 kHz, Mono,   8-bit */
#define WAVE_FORMAT_1S08      0x00000002       /* 11.025 kHz, Stereo, 8-bit */
#define WAVE_FORMAT_1M16      0x00000004       /* 11.025 kHz, Mono,   16-bit */
#define WAVE_FORMAT_1S16      0x00000008       /* 11.025 kHz, Stereo, 16-bit */
#define WAVE_FORMAT_2M08      0x00000010       /* 22.05  kHz, Mono,   8-bit */
#define WAVE_FORMAT_2S08      0x00000020       /* 22.05  kHz, Stereo, 8-bit */
#define WAVE_FORMAT_2M16      0x00000040       /* 22.05  kHz, Mono,   16-bit */
#define WAVE_FORMAT_2S16      0x00000080       /* 22.05  kHz, Stereo, 16-bit */
#define WAVE_FORMAT_4M08      0x00000100       /* 44.1   kHz, Mono,   8-bit */
#define WAVE_FORMAT_4S08      0x00000200       /* 44.1   kHz, Stereo, 8-bit */
#define WAVE_FORMAT_4M16      0x00000400       /* 44.1   kHz, Mono,   16-bit */
#define WAVE_FORMAT_4S16      0x00000800       /* 44.1   kHz, Stereo, 16-bit */#define WAVE_FORMAT_44M08     0x00000100       /* 44.1   kHz, Mono,   8-bit */
#define WAVE_FORMAT_44S08     0x00000200       /* 44.1   kHz, Stereo, 8-bit */
#define WAVE_FORMAT_44M16     0x00000400       /* 44.1   kHz, Mono,   16-bit */
#define WAVE_FORMAT_44S16     0x00000800       /* 44.1   kHz, Stereo, 16-bit */
#define WAVE_FORMAT_48M08     0x00001000       /* 48     kHz, Mono,   8-bit */
#define WAVE_FORMAT_48S08     0x00002000       /* 48     kHz, Stereo, 8-bit */
#define WAVE_FORMAT_48M16     0x00004000       /* 48     kHz, Mono,   16-bit */
#define WAVE_FORMAT_48S16     0x00008000       /* 48     kHz, Stereo, 16-bit */
#define WAVE_FORMAT_96M08     0x00010000       /* 96     kHz, Mono,   8-bit */
#define WAVE_FORMAT_96S08     0x00020000       /* 96     kHz, Stereo, 8-bit */
#define WAVE_FORMAT_96M16     0x00040000       /* 96     kHz, Mono,   16-bit */
#define WAVE_FORMAT_96S16     0x00080000       /* 96     kHz, Stereo, 16-bit */
  • WAVE_FORMAT_ 后跟采样率(如 1 表示 11.025 kHz,2 表示 22.05 kHz,4 表示 44.1 kHz,48 表示 48 kHz,96 表示 96 kHz)。
  • M 表示单声道(Mono),S 表示立体声(Stereo)。
  • 数字 08 表示 8 位深度,16 表示 16 位深度。
    例如,WAVE_FORMAT_44S16 表示 44.1 kHz 采样率、立体声、16 位深度的音频格式。

http://www.ppmy.cn/news/1500105.html

相关文章

在 Qt 中获取 MouseMove 事件

在编写 Qt 程序时&#xff0c;我希望在鼠标移动时&#xff08;即使鼠标在另一个窗口上&#xff09;能够调用 mouseMoveEvent(QMouseEvent* event) 方法。目前&#xff0c;在我的 mainwindow.cpp 文件中&#xff0c;我有如下代码&#xff1a; void MainWindow::mouseMoveEvent(…

力扣高频SQL 50题(基础版)第七题

文章目录 力扣高频SQL 50题&#xff08;基础版&#xff09;第七题1068. 产品销售分析 I题目说明思路分析实现过程准备数据&#xff1a;实现方式&#xff1a;结果截图:总结&#xff1a; 力扣高频SQL 50题&#xff08;基础版&#xff09;第七题 1068. 产品销售分析 I 题目说明 …

HTML + CSS编程规范

编程规范 HTML CSS 命名规范 HTML CSS 命名规范 1. 命名需要是具备语义性的单词&#xff0c;不能用 数字 拼音 数字,符号开头正确示范 &#xff1a; wrap description title content错误示范 : aaaa a1 $we 4tdds 2. 命名需要多个单词连接的情况下, 标记语言中可以使用 …

react.16+

1、函数式组件 在vite脚手架中执行&#xff1a; app.jsx: import { useState } from react import reactLogo from ./assets/react.svg import viteLogo from /vite.svg import ./App.cssfunction App() {console.log(this)return <h2>我是函数式组件</h2> }exp…

基于python的当当二手书数据分析与可视化系统设计与实现

1.1 研究背景及现状 1.1.1 研究背景 生态文明建设是我国的基本国情之一&#xff0c;资源利用作为应该重要的环节[1]。然而随着大学校园内掀起倡导的低碳环保热潮&#xff0c;高校学生教材及其他书籍的目前的处理方式已被大多人所关注[2]。从循环利用资源的角度出发[3]&…

防火墙——iptables实验

[rootlocalhost ~] # yum install iptables -y [rootlocalhost ~] # systemctl stop firewalld [rootlocalhost ~] # systemctl start iptables [rootserver ~] # iptables -F # 清空所有的规则表&#xff0c;清空之后客户端可以访问 ssh 和 http 服务 &#xff08; 2 &…

决策树的概念

决策树的概念 决策树是一种监督学习算法&#xff0c;主要用于分类任务。它通过构建一棵树结构模型来进行预测&#xff0c;其中每个内部节点表示一个特征属性上的判断条件&#xff0c;每条边代表一个判断结果对应的分支&#xff0c;而叶节点则代表最终的类别标签。 应用领域 …

【JVM】JVM相关概念详解

没有特殊说明&#xff0c;本文使用的是jdk8 参考 黑马程序员JVM虚拟机入门到实战全套视频教程&#xff0c;java大厂面试必会的jvm一套搞定&#xff08;丰富的实战案例及最热面试题&#xff09;_哔哩哔哩_bilibili 目录 JVM作用 解释和运行字节码 内存管理 即时编译 字节码…