gpt4 book ai didi

java - 调用 startRecording() 方法时 Android AudioRecord 失败

转载 作者:行者123 更新时间:2023-11-29 20:11:14 24 4
gpt4 key购买 nike

我正在尝试在 android 中录制音频并将其存储在一个字节数组中,为此我使用了 Android 的 AudioRecord 内置类。
我以前已经用过这个类,一切都很好,但由于某种原因,AudioRecord 似乎不再起作用了。

问题是 AudioRecord 已初始化且未显示任何错误,但是当需要通过调用其“startRecording() 方法来实际录制某些内容时,某些内容失败了,我什至没有找到正确的原因。

这是 ALL 调用此方法后 Logcat 的输出:

01-18 18:54:49.545  11303-11338/com.mypackage E/android.media.AudioRecord﹕ MediaRecorder prepare   CallingPid =  11303  Callinguid=  10128

01-18 18:54:49.545 11303-11338/com.mypackage E/android.media.AudioRecord﹕ java.lang.Throwable
at android.media.AudioRecord.startRecording(AudioRecord.java:631)
at mypackage.AudioRecorder.record(AudioRecorder.java:179)

当然,此后没有录制音频,对于那些想知道这是否只是内部错误消息的人来说。

这是初始化 AudioRecord 类的代码:

int bufferSize = AudioRecord.getMinBufferSize(AUDIO_SAMPLE_RATE, RECORDER_CHANNEL, RECORDER_AUDIO_ENCODING);

if (bufferSize != AudioRecord.ERROR_BAD_VALUE && bufferSize > 0)
{
// check if we can instantiate and have a success
AudioRecord recorder = new AudioRecord(MediaRecorder.AudioSource.MIC, AUDIO_SAMPLE_RATE, RECORDER_CHANNEL,
RECORDER_AUDIO_ENCODING, bufferSize);

if (recorder.getState() == AudioRecord.STATE_INITIALIZED)
{
m_Recorder = recorder;
m_RecordingThread = Executors.newSingleThreadExecutor();
m_IsInitialized = true;
return;
}
}

当使用的常量是:

/**
* Recorded audio's sample rate.
*/
private static final int AUDIO_SAMPLE_RATE = 44100;

/**
* Recorded audio's channel.
*/
private static final int RECORDER_CHANNEL = AudioFormat.CHANNEL_IN_MONO;

/**
* Recorded audio's encoding.
*/
private static final int RECORDER_AUDIO_ENCODING = AudioFormat.ENCODING_PCM_16BIT;

错误发生在这里:

if (m_Recorder != null)
m_Recorder.startRecording();

所以在看到这种情况发生几次之后,我决定更深入地尝试调试它,尽可能深入地使用 Jetbrain 的反编译器来调试 AudioRecord 类本身的错误源。
出于某种奇怪的原因,一旦应用程序遇到位于错误源的断点,下一步就无法完成,因为 AudioRecord 再次崩溃,并显示相同的错误消息。

我的下一步是创建一个示例项目来测试 AudioRecord 的功能,但这次我也添加了一个 AudioTrack,它将立即输出我的所有录音(一种回送),以防 AudioRecord 类管理记录一些东西,有或没有错误。
于是神奇的事情发生了——应用程序正在运行,AudioRecord 正在录音,AudioTrack 正在播放。
AudioTrack 类突然解决了我所有的问题,这似乎真的很奇怪,所以我将它从我的代码中删除并再次尝试运行该应用程序。
这一次,AudioRecord 的工作没有任何问题,即使我听不到它的输出,我可以向你保证它一直在录音。

我松了一口气,心想我终于克服了这个问题,我已经准备好继续前进了,所以我添加了一些额外的代码来编码和解码录制的音频数据。
为了听到输出,我使用 AudioTrack 类返回代码,然后运行该应用程序。

想听听有趣的事吗?该应用已崩溃并出现相同的错误,AGAIN

现在理论上问题可能是在使用完 AudioRecord 实例后没有释放它,但我也从一开始就介绍了这一点。

我已经尝试在 Internet 上几乎到处寻找解决方案,但似乎以前没有人遇到过这样的问题。

此外,我想指出我已经尝试重置我的设备、ADB 插件并重建所有项目。

我使用的是魅族 MX5 手机,Android Lollipop(API 21)。

最佳答案

好吧,我解决了这个问题,或者至少解决了一部分,现在它可以正常工作了。问题是在调用 AudioRecord 类的 read() 方法时,我试图读取比预分配缓冲区大小更多的字节。
虽然它没有解决这篇文章的主要问题,即奇怪的错误消息和未捕获的异常,但它使 AudioRecord 完美地工作,所以对我来说这个线程可以被视为已回答并关闭!

关于java - 调用 startRecording() 方法时 Android AudioRecord 失败,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34860767/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com