1

我正在开发一个录制视频的应用程序。它大部分已经完成,但我在运行 2.3.3 (API 10) 的旧三星 Galaxy S1(澳大利亚型号)时遇到了一个奇怪的问题。

当我尝试通过mMediaRecorder.setOrientationHint(90);它设置方向时会引发异常:

05-28 10:46:53.628: E/AndroidRuntime(6373): java.lang.RuntimeException: setParameter failed.

随着 :

05-28 10:46:53.593: E/MediaRecorder(6373): setParameters(video-param-rotation-angle-degrees=90) failed: -2147483648

奇怪的是,其他运行 3.2.2 (API 10) 的设备运行良好,只有这个三星 Galaxy s1 似乎有一个不支持 setOrientation() 的混蛋定制操作系统。

我目前正在使用try {} catch() {}around setOrientation()。这不是处理这个问题的优雅方式吗?是否最好先检查setOrientation()设备是否支持然后尝试设置?我找不到任何检查这种支持的方法。

我已经检查过(http://developer.android.com/reference/android/media/MediaRecorder.html),除了我已经在使用的 API 级别 9 之外找不到帮助。即,仅在 API 级别 9 或更高级别时尝试设置方向

这是整个例外:

05-28 10:46:53.593: E/MediaRecorder(6373): setParameters(video-param-rotation-angle-degrees=90) failed: -2147483648
05-28 10:46:53.593: W/dalvikvm(6373): threadid=1: thread exiting with uncaught exception (group=0x40015578)
05-28 10:46:53.628: E/AndroidRuntime(6373): FATAL EXCEPTION: main
05-28 10:46:53.628: E/AndroidRuntime(6373): java.lang.RuntimeException: setParameter failed.
05-28 10:46:53.628: E/AndroidRuntime(6373):     at android.media.MediaRecorder.setParameter(Native Method)
05-28 10:46:53.628: E/AndroidRuntime(6373):     at android.media.MediaRecorder.setOrientationHint(MediaRecorder.java:341)
05-28 10:46:53.628: E/AndroidRuntime(6373):     at com.on3x.emergency.Recorder.prepareVideoRecorder(Recorder.java:223)
05-28 10:46:53.628: E/AndroidRuntime(6373):     at com.on3x.emergency.Recorder.startRecording(Recorder.java:104)
05-28 10:46:53.628: E/AndroidRuntime(6373):     at com.on3x.emergency.GUI.RecordActivity$1.onClick(RecordActivity.java:111)
05-28 10:46:53.628: E/AndroidRuntime(6373):     at android.view.View.performClick(View.java:2538)
05-28 10:46:53.628: E/AndroidRuntime(6373):     at android.view.View$PerformClick.run(View.java:9152)
05-28 10:46:53.628: E/AndroidRuntime(6373):     at android.os.Handler.handleCallback(Handler.java:587)
05-28 10:46:53.628: E/AndroidRuntime(6373):     at android.os.Handler.dispatchMessage(Handler.java:92)
05-28 10:46:53.628: E/AndroidRuntime(6373):     at android.os.Looper.loop(Looper.java:123)
05-28 10:46:53.628: E/AndroidRuntime(6373):     at android.app.ActivityThread.main(ActivityThread.java:3687)
05-28 10:46:53.628: E/AndroidRuntime(6373):     at java.lang.reflect.Method.invokeNative(Native Method)
05-28 10:46:53.628: E/AndroidRuntime(6373):     at java.lang.reflect.Method.invoke(Method.java:507)
05-28 10:46:53.628: E/AndroidRuntime(6373):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:842)
05-28 10:46:53.628: E/AndroidRuntime(6373):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:600)
05-28 10:46:53.628: E/AndroidRuntime(6373):     at dalvik.system.NativeStart.main(Native Method)

这是实际的设置代码:

...
    if (android.os.Build.VERSION.SDK_INT>=9) {
        // attempt to rotate the video 90 degrees.
        try {
            mMediaRecorder.setOrientationHint(90);
            Utils.logLine("orientation rotated 90", this, Utils.LOG_TYPE_DEBUG);
        } catch (Exception e) {
            Utils.logLine("error trying setOrientationHint"+ e.getMessage(), this, Utils.LOG_TYPE_ERROR, e);
        }           
    } else {
        Utils.logLine("orientation set skipped ", this, Utils.LOG_TYPE_DEBUG);
    }    
...
4

1 回答 1

0

如果您确信只有有限数量的设备使用此命令进行了自定义,您可以通过检查其设备类型来进行抢先检查。否则try catch阻塞是处理它的唯一方法。

于 2013-05-28T02:15:25.627 回答