在Galaxy S3上录制时,视频显示会出现乱码

时间:2012-10-02 18:45:44

标签: android android-camera galaxy android-mediarecorder

我正在写一个相机应用程序,我遇到了S3的问题。每当我开始录制时,显示屏都会变成垃圾(见下面的截图)。然后,当我停止录制时,我得到一个例外:

10-02 13:36:31.647: E/MediaRecorder(24283): stop failed: -1007
10-02 13:36:31.647: D/AndroidRuntime(24283): Shutting down VM
10-02 13:36:31.647: W/dalvikvm(24283): threadid=1: thread exiting with uncaught exception (group=0x40c49a68)
10-02 13:36:31.647: E/AndroidRuntime(24283): FATAL EXCEPTION: main
10-02 13:36:31.647: E/AndroidRuntime(24283): java.lang.RuntimeException: stop failed.
10-02 13:36:31.647: E/AndroidRuntime(24283):    at android.media.MediaRecorder.native_stop(Native Method)
10-02 13:36:31.647: E/AndroidRuntime(24283):    at android.media.MediaRecorder.stop(MediaRecorder.java:742)
10-02 13:36:31.647: E/AndroidRuntime(24283):    at com.myapp.android.ui.camera.NewCameraActivity.stopRecording(NewCameraActivity.java:178)
10-02 13:36:31.647: E/AndroidRuntime(24283):    at com.myapp.android.ui.camera.NewCameraActivity.toggleRecording(NewCameraActivity.java:189)
10-02 13:36:31.647: E/AndroidRuntime(24283):    at com.myapp.android.ui.camera.NewCameraActivity.onClick(NewCameraActivity.java:97)
10-02 13:36:31.647: E/AndroidRuntime(24283):    at android.view.View.performClick(View.java:3565)
10-02 13:36:31.647: E/AndroidRuntime(24283):    at android.view.View$PerformClick.run(View.java:14165)
10-02 13:36:31.647: E/AndroidRuntime(24283):    at android.os.Handler.handleCallback(Handler.java:605)
10-02 13:36:31.647: E/AndroidRuntime(24283):    at android.os.Handler.dispatchMessage(Handler.java:92)
10-02 13:36:31.647: E/AndroidRuntime(24283):    at android.os.Looper.loop(Looper.java:137)
10-02 13:36:31.647: E/AndroidRuntime(24283):    at android.app.ActivityThread.main(ActivityThread.java:4514)
10-02 13:36:31.647: E/AndroidRuntime(24283):    at java.lang.reflect.Method.invokeNative(Native Method)
10-02 13:36:31.647: E/AndroidRuntime(24283):    at java.lang.reflect.Method.invoke(Method.java:511)
10-02 13:36:31.647: E/AndroidRuntime(24283):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:980)
10-02 13:36:31.647: E/AndroidRuntime(24283):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:747)
10-02 13:36:31.647: E/AndroidRuntime(24283):    at dalvik.system.NativeStart.main(Native Method)

我在Galaxy Nexus(4.1),Galaxy S2,Nexus S和Galaxy Tab 10.1上测试了我的应用程序。所有这些都很好。我跟着development guidelines for video recording。我不明白为什么这个设备与其他设备如此不同。这就是我在设备上看到的内容。第一张照片是在我开始录制之前。第二张照片是我开始录制后会发生的事情。

Before I've started recording

After I start recording

这是我准备和启动MediaRecorder对象的代码:

@Override
public void onClick( View v ) {

    switch (v.getId()) {
        case R.id.camera_action_ImageView:
            int mode = getMode();
            if ( mode == MODE_PHOTO ) {
                focusThenTakePicture();
            }
            else if ( mode == MODE_VIDEO ) {
                toggleRecording();
            }
            break;
    }
}

private void startRecording() {

    if ( prepareRecorder() ) {
        getRecorder().start();
        setRecording( true );
    }
}

@TargetApi( 9 )
private boolean prepareRecorder() {

    Camera camera = getCamera();
    camera.unlock();

    MediaRecorder recorder = new MediaRecorder();
    setRecorder( recorder );
    recorder.setCamera( camera );
    recorder.setAudioSource( MediaRecorder.AudioSource.CAMCORDER );
    recorder.setVideoSource( MediaRecorder.VideoSource.CAMERA );

    CamcorderProfile profile;
    if ( Build.VERSION.SDK_INT < Build.VERSION_CODES.GINGERBREAD ) {
        profile = CamcorderProfile.get( CamcorderProfile.QUALITY_HIGH );
    }
    else {
        profile = CamcorderProfile.get( getCameraId(), CamcorderProfile.QUALITY_HIGH );
    }
    recorder.setProfile( profile );

    File outputFile = LocalMediaUtil.getOutputMediaFile( LocalMediaUtil.MEDIA_TYPE_VIDEO );
    setRecorderOutputFile( outputFile );
    recorder.setOutputFile( outputFile.toString() );
    recorder.setPreviewDisplay( getPreview().getHolder().getSurface() );

    try {
        recorder.prepare();
    }
    catch (Exception e) {
        camera.lock();
        setRecorder( null );
        return false;
    }

    return true;
}

private void stopRecording() {

    MediaRecorder recorder = getRecorder();
    recorder.stop();
    releaseRecorder();
    setRecording( false );

    LocalMediaUtil.scanMedia( this, getRecorderOutputFile().toString(), 90 );
    setRecorderOutputFile( null );
}

private void toggleRecording() {

    if ( isRecording() ) {
        stopRecording();
    }
    else {
        startRecording();
    }
}

private void releaseRecorder() {

    MediaRecorder recorder = getRecorder();
    if ( recorder != null ) {

        recorder.reset();
        recorder.release();
        setRecorder( null );

        getCamera().lock();
    }
}

修改:这与设置的CamcorderProfile有关。我将其更改为CamcorderProfile.QUALITY_LOW并且工作正常。那么如何在没有乱码输出的情况下获得高分辨率视频?

编辑2:因此设置CamcorderProfile.QUALITY_LOW时,使用录像机我没有错误。但是,输出视频与上面发布的乱码截图非常相似。那是什么给出了什么?

3 个答案:

答案 0 :(得分:10)

我有一个类似的问题,最后发现它是由于共享相机和媒体记录器之间的预览表面(我不确定这实际上是根本原因,但是从API调用它看来是这样的)。

我假设您已经打开相机并附加了预览显示,如果是这样,请尝试在prepareRecorder方法的顶部插入以下行:

Camera camera = getCamera();
camera.stopPreview();
camera.lock();
camera.release();

camera = Camera.open();
camera.unlock();

您可能还需要将相机本地重新分配给隐藏在getCamera()后面的字段,遗憾的是我无法告诉您如何使用给定的代码段实现它。

希望这有帮助。

答案 1 :(得分:1)

我和三星Note有类似的问题。我的问题是预览是以分辨率设置的,并且录制设置为另一个更大的分辨率(我的手机不支持的分辨率),这就是为什么它看起来像这样。你应该试试:

recorder.setVideoSize(320, 240);

如果有效,则表示不支持您的初始分辨率/

答案 2 :(得分:0)

这是因为预览分辨率和Mediarecorder分辨率不同(它们可能因设备而异,但在某些设备上似乎会导致问题)。

检查Android相机应用程序,它不会停止预览然后开始录制(您可以通过保持闪光灯开启来检查,如果您停止预览然后开始录制,闪光灯将关闭然后再打开,而在Android相机应用程序中,没有发生)。

此处的“已接受”答案仅适用,因为相机会释放预览曲面,然后mediarecorder可以将分辨率调整为其中一个mediarecorder分辨率,但技术上并不正确。