Android - MediaRecorder start()抛出IllegalStateException

时间:2013-11-09 12:17:02

标签: android

我正在开发一款需要录制视频的应用

这是我的部分代码

mRecorder = new MediaRecorder();
mRecorder.setVideoSource(MediaRecorder.VideoSource.CAMERA);
mRecorder.setAudioSource(MediaRecorder.AudioSource.MIC);
mRecorder.setOutputFormat(MediaRecorder.OutputFormat.THREE_GPP);
String mFileName = Environment.getExternalStorageDirectory()
            .getAbsolutePath();
mFileName += "/youraudiofile.3gp";
mSurfaceHolder.getSurface();
mRecorder.setPreviewDisplay(mSurfaceHolder.getSurface());
mRecorder.setOutputFile(mFileName);
mRecorder.setVideoSize(320, 240);
mRecorder.setVideoFrameRate(15);
mRecorder.setVideoEncoder(MediaRecorder.VideoEncoder.H263);
mRecorder.setAudioEncoder(MediaRecorder.AudioEncoder.AMR_NB);
mRecorder.setMaxDuration(30000);
try {
mRecorder.prepare();
mRecorder.start();
} catch (IllegalStateException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}

上面的代码抛出了IllegalStateException。我已经在AndroidManifest.xml中输入了所有权限,我非常确定AndroidManifest.xml中没有任何错误。

我已经阅读了几个解决方案,但没有一个工作。我该如何解决这个问题?

下面提供的log cat

11-09 20:47:39.787: E/AndroidRuntime(29000): FATAL EXCEPTION: main
11-09 20:47:39.787: E/AndroidRuntime(29000): java.lang.IllegalStateException: Could not execute method of the activity
11-09 20:47:39.787: E/AndroidRuntime(29000):    at android.view.View$1.onClick(View.java:3624)
11-09 20:47:39.787: E/AndroidRuntime(29000):    at android.view.View.performClick(View.java:4117)
11-09 20:47:39.787: E/AndroidRuntime(29000):    at android.view.View$PerformClick.run(View.java:17052)
11-09 20:47:39.787: E/AndroidRuntime(29000):    at android.os.Handler.handleCallback(Handler.java:615)
11-09 20:47:39.787: E/AndroidRuntime(29000):    at android.os.Handler.dispatchMessage(Handler.java:92)
11-09 20:47:39.787: E/AndroidRuntime(29000):    at android.os.Looper.loop(Looper.java:137)
11-09 20:47:39.787: E/AndroidRuntime(29000):    at android.app.ActivityThread.main(ActivityThread.java:4812)
11-09 20:47:39.787: E/AndroidRuntime(29000):    at java.lang.reflect.Method.invokeNative(Native Method)
11-09 20:47:39.787: E/AndroidRuntime(29000):    at java.lang.reflect.Method.invoke(Method.java:511)
11-09 20:47:39.787: E/AndroidRuntime(29000):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:789)
11-09 20:47:39.787: E/AndroidRuntime(29000):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:556)
11-09 20:47:39.787: E/AndroidRuntime(29000):    at dalvik.system.NativeStart.main(Native Method)
11-09 20:47:39.787: E/AndroidRuntime(29000): Caused by: java.lang.reflect.InvocationTargetException
11-09 20:47:39.787: E/AndroidRuntime(29000):    at java.lang.reflect.Method.invokeNative(Native Method)
11-09 20:47:39.787: E/AndroidRuntime(29000):    at java.lang.reflect.Method.invoke(Method.java:511)
11-09 20:47:39.787: E/AndroidRuntime(29000):    at android.view.View$1.onClick(View.java:3619)
11-09 20:47:39.787: E/AndroidRuntime(29000):    ... 11 more
11-09 20:47:39.787: E/AndroidRuntime(29000): Caused by: java.lang.RuntimeException: start failed.
11-09 20:47:39.787: E/AndroidRuntime(29000):    at android.media.MediaRecorder.start(Native Method)
11-09 20:47:39.787: E/AndroidRuntime(29000):    at com.example.camera2.CameraView.startRecording(CameraView.java:149)
11-09 20:47:39.787: E/AndroidRuntime(29000):    ... 14 more

修改后的代码如下,即使setOutputFormat(),setVideoSource(),setAudioSource()出现在if {}之上,setProfile()也会抛出RunTimeException。 以下代码将抛出与上一个日志

相同的IllegalStateException
    mRecorder = new MediaRecorder();

    mRecorder.setVideoSource(MediaRecorder.VideoSource.CAMERA);
    mRecorder.setAudioSource(MediaRecorder.AudioSource.MIC);
    String mFileName = Environment.getExternalStorageDirectory()
            .getAbsolutePath();
    mFileName += "/youraudiofile.3gp";
    mRecorder.setPreviewDisplay(mSurfaceHolder.getSurface());

    if (Build.VERSION.SDK_INT < Build.VERSION_CODES.HONEYCOMB) {
        mRecorder.setOutputFormat(MediaRecorder.OutputFormat.DEFAULT);
        mRecorder.setAudioEncoder(MediaRecorder.AudioEncoder.DEFAULT);
        mRecorder.setVideoEncoder(MediaRecorder.VideoEncoder.DEFAULT);
    } else {

        if (! isFrontCamera) {
            CamcorderProfile camcorderProfile = CamcorderProfile.get(CamcorderProfile.QUALITY_HIGH);
            mRecorder.setProfile(camcorderProfile);

        } else {
            CamcorderProfile camcorderProfile = CamcorderProfile.get(findFrontFacingCamera(), CamcorderProfile.QUALITY_LOW);
            mRecorder.setProfile(camcorderProfile);
        }

        mRecorder.setVideoSize(720, 480);
    }
    mRecorder.setVideoFrameRate(15);
    mRecorder.setOutputFile(mFileName);
    mRecorder.setMaxDuration(30000);

    try {
        mRecorder.prepare();
        mRecorder.start();
    } catch (IllegalStateException e) {
        e.printStackTrace();
    } catch (IOException e) {
        e.printStackTrace();
    }

2 个答案:

答案 0 :(得分:2)

尝试删除此行并检查一次..

mRecorder.setVideoSize(320, 240);

你的一些设置不适用于3.0,所以像这样设置..

 if (Build.VERSION.SDK_INT < Build.VERSION_CODES.HONEYCOMB) {

        mMediaRecorder.setOutputFormat(MediaRecorder.OutputFormat.DEFAULT);
        mMediaRecorder.setAudioEncoder(MediaRecorder.AudioEncoder.DEFAULT);
        mMediaRecorder.setVideoEncoder(MediaRecorder.VideoEncoder.DEFAULT);

    } else {

        if (! isFrontCamera) {
            CamcorderProfile camcorderProfile = CamcorderProfile.get(CamcorderProfile.QUALITY_HIGH);
            mMediaRecorder.setProfile(camcorderProfile);

        } else {
            CamcorderProfile camcorderProfile = CamcorderProfile.get(mFrontCamId, CamcorderProfile.QUALITY_LOW);
            mMediaRecorder.setProfile(camcorderProfile);
        }

        mMediaRecorder.setVideoSize(720, 480);
    }

答案 1 :(得分:0)

你的清单中是否有这些权限:

<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.RECORD_VIDEO" />
<uses-permission android:name="android.permission.RECORD_AUDIO" / >