我正在寻找一种方法将文件中的音频数据输入麦克风,因此当第三方应用程序(例如arecord或Chromium的"按语音搜索"功能)使用麦克风进行音频输入时,它们会从文件中接收音频数据代替.
这是我的场景:我编写的应用程序从麦克风录制音频数据(使用ALSA)并将其保存到文件(audioFile0.raw).在未来的某个未知时间点,一些未知的第三方应用程序(例如,我没有开发的东西,所以我没有开发控制权,例如Chromium网络浏览器的"语音搜索"功能)将使用麦克风来获取音频数据.我希望第三方应用程序收集的音频数据来自audioFile.raw而不是实际的麦克风本身.
我在想是否可以将默认音频输入设备更改为音频文件,或者可能是命名管道并执行类似操作cat audioFile0.raw > mypipe
(因为我不知道其他应用程序何时会尝试从麦克风读取).也许有一种更简单的方法可以做到这一点?
我希望我提供了足够的细节和清晰度.如果不清楚,请告诉我.
编辑: 所以我想通过在我的主目录中创建以下.asoundrc文件来制作虚拟麦克风:
pcm.!virtmic {
type file
slave.pcm "hw:0,0"
file /dev/null
infile "/home/charles/audioFiles/audioFile0.raw"
}
pcm.!default {
type hw
card 0
}
ctl.!default {
type hw
card 0
}
Run Code Online (Sandbox Code Playgroud)
然后调用arecord test.raw -c 1 -f S16_LE -r 16000 -t raw -D virtmic
命令行,我能够记录音频数据是在audioFile0.raw
来test.raw
.
我现在的目标是用我的虚拟麦克风替换默认设备,这样任何访问麦克风的应用程序都将读取音频数据,audioFile0.raw
而不是实际的麦克风本身.所以我编辑了我的.asoundrc文件,如下所示:
pcm.!virtmic {
type file
slave.pcm "hw:0,0"
file /dev/null
infile "/home/charles/audioFiles/audioFile0.raw"
}
pcm.!default {
type asym
playback.pcm {
type hw
card …
Run Code Online (Sandbox Code Playgroud)