HAL 层多声卡同时录音框架设计 - 多语言
1. 声卡工作原理
- 定义
声卡(Codec), 从名字上看就能看出是一种专用于音频 编(Encode) 解(Decode) 码 的硬件芯片, 通常采用 I2C 协议与外部进行通信, 采用 I2S 协议传输音频信号. - 核心参数
采样率(rate): 定义了每秒从连续信号中提取并组成离散信号的采样个数.
位宽(bit):
通道数(channel): 表示音频信号的数量, 通常分为单声道和立体声.
2. 音频格式
- 常见
▪ MP3 ▪ WAVE ▪ PCM ▪ FLAC ▪ M4A - 其他
▪ RealAudio ▪ VQF ▪ OggVorbis ▪ APE ▪ AAC
▪ CD ▪ AIFF ▪ MPEG ▪ MPEG-4 ▪ MIDI ▪ WMA ▪ AMR
3. 动手来设计多声卡录音框架
-
适用场景
智能音箱 2麦, 4麦, 6麦, 8麦方案. -
如何设计
需要用到多线程, 互斥锁, 数据队列, 一个总线程用于处理(合并, AEC)子线程采集到的数据, 多个子线程用于读取声卡数据, 互斥锁保障了数据的原子性, 数据队列用作于子线程写入、总线程读取的数据传输工作. 实际上就是用到了 buffer 原理. -
代码设计
-
数据结构