历史第N天,终于把之前预定的目标实现了:使用致远电子i.Mx6U linux开发板自带的麦克风输入实现声音的采集。回首在做这个东西,中途被卡了很久,实属是自己能力不够,又或者是自己平时工作的时候注意力不集中。现将使用自己的开发板实现声音的采集做了一个总结。
使用的linux 的alsa (Advanced Linux Sound Architecture)
遇到的问题:
1、在makefile编译时,明明头文件已经写在了头部,却在编译时提示没有定义某个函数,如上图所示。这种问题有点像使用keil编程的时候,没有在includepath加上你头文件的路径一样。在linux中的写法是arm-linux-gcc alsa_audio.c -o sound_test -lasound -I/opt/alsa/include -L/opt/alsa/lib -I/usr/include/ 在后面加上-I/你的头文件路径。
2、写入文件用rc = fwrite( buffer,sizeof(char), size,fp); 当执行./sound_test时,就会自动将音频数据保存至目标文件。
而用rc = write(1,buffer,size);时,运行得使用./sound_test > 名字.wav。
3、使用自己代码直接获取的数据无法直接打开,得使用软件
4、查看音频设备指令 cat /proc/asound/cards
查看输入设备 arecord -l
查看输出设备 aplay -l
录音指令 arecord -Dhw:0,0 -d 10 -f cd -r 44100 -c 2 -t wav test.wav
参数解析
-D 指定了录音设备,0,1 是card 0 device 1的意思,也就是 ax
-d 指定录音的时长,单位时秒
-f 指定录音格式,通过上面的信息知道只支持 cd cdr dat
-r 指定了采样率,单位时Hz
-c 指定channel 个数
-t 指定生成的文件格式