一、AudioRecord API详解
AudioRecord是Android系统提供的用于实现录音的功能类。
要想了解这个类的具体的说明和用法,我们可以去看一下官方的文档:
AndioRecord类的主要功能是让各种JAVA应用能够管理音频资源,以便它们通过此类能够录制声音相关的硬件所收集的声音。此功能的实现就是通过”pulling”(读取)AudioRecord对象的声音数据来完成的。在录音过程中,应用所需要做的就是通过后面三个类方法中的一个去及时地获取AudioRecord对象的录音数据. AudioRecord类提供的三个获取声音数据的方法分别是read(byte[], int, int), read(short[], int, int), read(ByteBuffer, int). 无论选择使用那一个方法都必须事先设定方便用户的声音数据的存储格式。
开始录音的时候,AudioRecord需要初始化一个相关联的声音buffer, 这个buffer主要是用来保存新的声音数据。这个buffer的大小,我们可以在对象构造期间去指定。它表明一个AudioRecord对象还没有被读取(同步)声音数据前能录多长的音(即一次可以录制的声音容量)。声音数据从音频硬件中被读出,数据大小不超过整个录音数据的大小(可以分多次读出),即每次读取初始化buffer容量的数据。
实现Android录音的流程为:
构造一个AudioRecord对象,其中需要的最小录音缓存buffer大小可以通过getMinBufferSize方法得到。如果buffer容量过小,将导致对象构造的失败。
初始化一个buffer,该buffer大于等于AudioRecord对象用于写声音数据的buffer大小。
开始录音
创建一个数据流,一边从AudioRecord中读取声音数据到初始化的buffer,一边将buffer中数据导入数据流。
关闭数据流
停止录音
二、使用 AudioRecord 实现录音,并生成wav
2.1 创建一个AudioRecord对象
首先要声明一些全局的变量参数:
private AudioRecord audioRecord = null; //声明 AudioRecord 对象
private int recordBufSize = 0; //声明recoordBufffer的大小字段
获取buffer的大小并创建AudioRecord:
public voidcreateAudioRecord() {
recordBufSize= AudioRecord.getMinBufferSize(frequency, channelConfiguration, EncodingBitRate); //audioRecord能接受的最小的buffer大小
audioRecord = newAudioRecord(MediaRecorder.AudioSource.MIC, frequency, channelConfiguration, EncodingBitRa