我正在寻找一种方法将文件中的音频数据输入麦克风,因此当第三方应用程序(例如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
}
然后我从命令行调用arecord test.raw -c 1 -f S16_LE -r 16000 -t raw -D virtmic,我