http://www.oschina.net/code/snippet_3307_2324
Java code
package eoe.demo; import android.media.AudioFormat; import android.media.AudioRecord; import android.media.MediaRecorder; import android.util.Log; publicclass RecordThread extends Thread { private AudioRecord ar; privateint bs; privatestaticint SAMPLE_RATE_IN_HZ =8000; privateboolean isRun =false; public RecordThread() { super(); bs = AudioRecord.getMinBufferSize(SAMPLE_RATE_IN_HZ, AudioFormat.CHANNEL_CONFIGURATION_MONO, AudioFormat.ENCODING_PCM_16BIT); ar =new AudioRecord(MediaRecorder.AudioSource.MIC, SAMPLE_RATE_IN_HZ, AudioFormat.CHANNEL_CONFIGURATION_MONO, AudioFormat.ENCODING_PCM_16BIT, bs); } publicvoid run() { super.run(); ar.startRecording(); // 用于读取的 buffer byte[] buffer =newbyte[bs]; isRun =true; while (isRun) { int r = ar.read(buffer, 0, bs); int v =0; // 将 buffer 内容取出,进行平方和运算 for (int i =0; i < buffer.length; i++) { // 这里没有做运算的优化,为了更加清晰的展示代码 v += buffer[i] * buffer[i]; } // 平方和除以数据总长度,得到音量大小。可以获取白噪声值,然后对实际采样进行标准化。 // 如果想利用这个数值进行操作,建议用 sendMessage 将其抛出,在 Handler 里进行处理。 Log.d("spl", String.valueOf(v / (float) r)); } ar.stop(); } publicvoid pause() { // 在调用本线程的 Activity 的 onPause 里调用,以便 Activity 暂停时释放麦克风 isRun =false; } publicvoid start() { // 在调用本线程的 Activity 的 onResume 里调用,以便 Activity 恢复后继续获取麦克风输入音量 if (!isRun) { super.start(); } } }
轻松实现语音识别
最新推荐文章于 2025-12-28 16:49:38 发布
3749

被折叠的 条评论
为什么被折叠?



