【问题标题】:Camera not working - startPreview fails相机不工作 - startPreview 失败
【发布时间】:2024-01-21 07:00:02
【问题描述】:

我的相机应用在 Android 2.x 设备上运行时总是会出现异常。在较新的 Android 设备上,该应用运行良好。

堆栈跟踪:

10-31 19:51:52.187: W/System.err(14904): java.lang.RuntimeException: startPreview failed
10-31 19:51:52.195: W/System.err(14904):    at android.hardware.Camera.startPreview(Native Method)
10-31 19:51:52.195: W/System.err(14904):    at com.example.MainActivity.startCamera(MainActivity.java:418)
10-31 19:51:52.195: W/System.err(14904):    at com.example.MainActivity.surfaceChanged(MainActivity.java:467)
10-31 19:51:52.195: W/System.err(14904):    at android.view.SurfaceView.updateWindow(SurfaceView.java:558)
10-31 19:51:52.195: W/System.err(14904):    at android.view.SurfaceView.dispatchDraw(SurfaceView.java:350)
10-31 19:51:52.195: W/System.err(14904):    at android.view.ViewGroup.drawChild(ViewGroup.java:1644)
10-31 19:51:52.195: W/System.err(14904):    at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1373)
10-31 19:51:52.195: W/System.err(14904):    at android.view.ViewGroup.drawChild(ViewGroup.java:1644)
10-31 19:51:52.195: W/System.err(14904):    at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1373)
10-31 19:51:52.195: W/System.err(14904):    at android.view.ViewGroup.drawChild(ViewGroup.java:1644)
10-31 19:51:52.195: W/System.err(14904):    at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1373)
10-31 19:51:52.195: W/System.err(14904):    at android.view.ViewGroup.drawChild(ViewGroup.java:1644)
10-31 19:51:52.195: W/System.err(14904):    at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1373)
10-31 19:51:52.195: W/System.err(14904):    at android.view.ViewGroup.drawChild(ViewGroup.java:1644)
10-31 19:51:52.203: W/System.err(14904):    at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1373)
10-31 19:51:52.203: W/System.err(14904):    at android.view.ViewGroup.drawChild(ViewGroup.java:1644)
10-31 19:51:52.203: W/System.err(14904):    at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1373)
10-31 19:51:52.203: W/System.err(14904):    at android.view.View.draw(View.java:6883)
10-31 19:51:52.203: W/System.err(14904):    at android.widget.FrameLayout.draw(FrameLayout.java:357)
10-31 19:51:52.203: W/System.err(14904):    at com.android.internal.policy.impl.PhoneWindow$DecorView.draw(PhoneWindow.java:1964)
10-31 19:51:52.203: W/System.err(14904):    at android.view.ViewRoot.draw(ViewRoot.java:1529)
10-31 19:51:52.203: W/System.err(14904):    at android.view.ViewRoot.performTraversals(ViewRoot.java:1266)
10-31 19:51:52.203: W/System.err(14904):    at android.view.ViewRoot.handleMessage(ViewRoot.java:1867)
10-31 19:51:52.203: W/System.err(14904):    at android.os.Handler.dispatchMessage(Handler.java:99)
10-31 19:51:52.203: W/System.err(14904):    at android.os.Looper.loop(Looper.java:130)
10-31 19:51:52.203: W/System.err(14904):    at android.app.ActivityThread.main(ActivityThread.java:3687)
10-31 19:51:52.203: W/System.err(14904):    at java.lang.reflect.Method.invokeNative(Native Method)
10-31 19:51:52.203: W/System.err(14904):    at java.lang.reflect.Method.invoke(Method.java:507)
10-31 19:51:52.203: W/System.err(14904):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:867)
10-31 19:51:52.203: W/System.err(14904):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:625)
10-31 19:51:52.203: W/System.err(14904):    at dalvik.system.NativeStart.main(Native Method)

【问题讨论】:

    标签: android exception camera surfaceview


    【解决方案1】:

    在 SurfaceView Holder 上,确保将类型设置为 SURFACE_TYPE_PUSH_BUFFERS

    @Override
    public void onCreate(Bundle savedInstanceState) {
       // ...
       SurfaceView s=(SurfaceView)findViewById(R.id.surface);
       SurfaceHolder h=s.getHolder();
       h.setType(SurfaceHolder.SURFACE_TYPE_PUSH_BUFFERS);
    }
    

    【讨论】:

    • 谢谢,由于弃用状态,这一行在我的代码中被注释掉了。在应用程序中取消注释后,它起作用了。
    • 仍然没有解决我的问题。
    • Android 是我见过的最糟糕的垃圾
    最近更新 更多