1

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();
            }
        }

誰かが同様の問題を抱えていますか?なぜ録音が中止されるのか、なぜそれが特定の時間にのみ発生するのかわかりません。バグの発生にはパターンがない(または少なくともパターンがあるかどうかはわかりませんでした)ため、デバッグがかなり難しくなります。誰かがこれについて私を助けてくれるといいですね。

4

0 に答える 0