http://i-liger.com/article/android-wav-audio-recordingのExtAudioRecorderを使用して、さらにオーディオ処理するためにWAVファイルを録音しています。ただし、次の一連のエラーメッセージが表示されることがあります。
12-08 18:58:18.217: E/AndroidRuntime(7323): FATAL EXCEPTION: main
12-08 18:58:18.217: E/AndroidRuntime(7323): java.lang.RuntimeException: Unable to start activity ComponentInfo{musicscoreify.app/musicscoreify.app.ReadWavFile}: java.lang.NullPointerException
12-08 18:58:18.217: E/AndroidRuntime(7323): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1651)
12-08 18:58:18.217: E/AndroidRuntime(7323): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1667)
12-08 18:58:18.217: E/AndroidRuntime(7323): at android.app.ActivityThread.access$1500(ActivityThread.java:117)
12-08 18:58:18.217: E/AndroidRuntime(7323): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:935)
12-08 18:58:18.217: E/AndroidRuntime(7323): at android.os.Handler.dispatchMessage(Handler.java:99)
12-08 18:58:18.217: E/AndroidRuntime(7323): at android.os.Looper.loop(Looper.java:130)
12-08 18:58:18.217: E/AndroidRuntime(7323): at android.app.ActivityThread.main(ActivityThread.java:3691)
12-08 18:58:18.217: E/AndroidRuntime(7323): at java.lang.reflect.Method.invokeNative(Native Method)
12-08 18:58:18.217: E/AndroidRuntime(7323): at java.lang.reflect.Method.invoke(Method.java:507)
12-08 18:58:18.217: E/AndroidRuntime(7323): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:907)
12-08 18:58:18.217: E/AndroidRuntime(7323): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:665)
12-08 18:58:18.217: E/AndroidRuntime(7323): at dalvik.system.NativeStart.main(Native Method)
12-08 18:58:18.217: E/AndroidRuntime(7323): Caused by: java.lang.NullPointerException
12-08 18:58:18.217: E/AndroidRuntime(7323): at musicscoreify.app.ReadWavFile.onCreate(ReadWavFile.java:138)
12-08 18:58:18.217: E/AndroidRuntime(7323): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
12-08 18:58:18.217: E/AndroidRuntime(7323): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1615)
12-08 18:58:18.217: E/AndroidRuntime(7323): ... 11 more
ExtAudioRecorderのメソッドの1つがクラッシュしたためです。方法は次のとおりです。
public void onPeriodicNotification(AudioRecord recorder)
{
audioRecorder.read(buffer, 0, buffer.length); // Fill buffer
try
{
randomAccessWriter.write(buffer); // Write buffer to file
payloadSize += buffer.length;
if (bSamples == 16)
{
for (int i=0; i<buffer.length/2; i++)
{ // 16bit sample size
short curSample = getShort(buffer[i*2], buffer[i*2+1]);
if (curSample > cAmplitude)
{ // Check amplitude
cAmplitude = curSample;
}
}
}
else
{ // 8bit sample size
for (int i=0; i<buffer.length; i++)
{
if (buffer[i] > cAmplitude)
{ // Check amplitude
cAmplitude = buffer[i];
}
}
}
}
catch (IOException e)
{
Log.e(ExtAudioRecorder.class.getName(), "Error occured in updateListener, recording is aborted");
//stop();
}
}
誰かが同様の問題を抱えていますか?なぜ録音が中止されるのか、なぜそれが特定の時間にのみ発生するのかわかりません。バグの発生にはパターンがない(または少なくともパターンがあるかどうかはわかりませんでした)ため、デバッグがかなり難しくなります。誰かがこれについて私を助けてくれるといいですね。