Android相机API应用程序在onResume崩溃

use*_*692 5 android android-camera

我正在使用相机API编写应用程序:显示预览,并拍照.第一个版本效果很好.在类预览中,SurfaceView实现了SurfaceHolder.Callback

public void surfaceCreated(SurfaceHolder holder) {
    // The Surface has been created, acquire the camera and tell it where
    // to draw.
    camera = Camera.open();
    try {
        camera.setPreviewDisplay(holder);
        camera.startPreview();

    } catch (IOException e) {
        e.printStackTrace();
    }

    hasSurface = true;
}


public void surfaceChanged(SurfaceHolder holder, int format, int w, int h) {
    // It will be called immediately after surfaceCreated
    // I move it to Resume.
    setCameraPreviewParameters();

    camera.startPreview();

}
Run Code Online (Sandbox Code Playgroud)

在主要活动中:

public class CameraDemo extends Activity
Run Code Online (Sandbox Code Playgroud)

我还设置了一个成员:CameraUnit ui; 它是:

public class CameraUnit extends LinearLayout
Run Code Online (Sandbox Code Playgroud)

在onCreate中,

    @Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);

    ui = new CameraUnit(this);
    setContentView((View) ui); 

    Log.d(TAG, "onCreate'd");
}
Run Code Online (Sandbox Code Playgroud)

它创建一个LinearLayout对象,其中包含surfaceView和一个相机按钮.

onResume是:

    @Override
protected void onResume() {
    super.onResume();
}
Run Code Online (Sandbox Code Playgroud)

虽然它有效,但我认为onResume不应该是空的.我还看到一个着名的Android应用程序示例OCRTest中的surfaceCreated和surfaceChanged是空的 所以我认为将surfaceCreated和surfaceChanged中的命令移动到onResume更好也更可行.

我认为我的应用程序第一版的流聊应该是:主要活动onCreate(创建LinearLayout及其surfaceView,相机按钮),surfaceCreated和surfaceChanged被调用,onResume.

所以我可以简单地将surfaceCreated和surfaceChanged中的命令移动到onResume.但它不起作用!我使用Debug来查找表面为空.我认为没有调用surfaceCreatd.我的应用程序是不同的OCRTest,它在主要活动中实现了SurfaceHolder.Callback.我在SurfaceView中实现了SurfaceHolder.Callback:

class Preview extends SurfaceView implements SurfaceHolder.Callback
Run Code Online (Sandbox Code Playgroud)

所以我在onResume中添加了另外两行

        ui.preview.surfaceCreated(ui.preview.mHolder);
    ui.preview.surfaceChanged(ui.preview.mHolder, 0, 800, 400);
Run Code Online (Sandbox Code Playgroud)

我随机设置了最后三个整数参数.当我开始活动时,Android手机中的错误窗口弹出.它说"引起:java.lang.RuntimeException:无法连接到摄像头服务".但是如何解决它???? 非常感谢!

错误是:

    01-07 00:27:57.173: W/dalvikvm(11625): threadid=1: thread exiting with uncaught exception (group=0x4001d5a0)
01-07 00:27:57.173: E/AndroidRuntime(11625): FATAL EXCEPTION: main
01-07 00:27:57.173: E/AndroidRuntime(11625): java.lang.RuntimeException: Unable to resume activity {com.example/com.example.CameraDemo}: java.lang.RuntimeException: Fail to connect to camera service
01-07 00:27:57.173: E/AndroidRuntime(11625):    at android.app.ActivityThread.performResumeActivity(ActivityThread.java:2460)
01-07 00:27:57.173: E/AndroidRuntime(11625):    at android.app.ActivityThread.handleResumeActivity(ActivityThread.java:2481)
01-07 00:27:57.173: E/AndroidRuntime(11625):    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1847)
01-07 00:27:57.173: E/AndroidRuntime(11625):    at android.app.ActivityThread.access$1500(ActivityThread.java:132)
01-07 00:27:57.173: E/AndroidRuntime(11625):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1038)
01-07 00:27:57.173: E/AndroidRuntime(11625):    at android.os.Handler.dispatchMessage(Handler.java:99)
01-07 00:27:57.173: E/AndroidRuntime(11625):    at android.os.Looper.loop(Looper.java:150)
01-07 00:27:57.173: E/AndroidRuntime(11625):    at android.app.ActivityThread.main(ActivityThread.java:4263)
01-07 00:27:57.173: E/AndroidRuntime(11625):    at java.lang.reflect.Method.invokeNative(Native Method)
01-07 00:27:57.173: E/AndroidRuntime(11625):    at java.lang.reflect.Method.invoke(Method.java:507)
01-07 00:27:57.173: E/AndroidRuntime(11625):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
01-07 00:27:57.173: E/AndroidRuntime(11625):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
01-07 00:27:57.173: E/AndroidRuntime(11625):    at dalvik.system.NativeStart.main(Native Method)
01-07 00:27:57.173: E/AndroidRuntime(11625): Caused by: java.lang.RuntimeException: Fail to connect to camera service
01-07 00:27:57.173: E/AndroidRuntime(11625):    at android.hardware.Camera.native_setup(Native Method)
01-07 00:27:57.173: E/AndroidRuntime(11625):    at android.hardware.Camera.<init>(Camera.java:265)
01-07 00:27:57.173: E/AndroidRuntime(11625):    at android.hardware.Camera.open(Camera.java:241)
01-07 00:27:57.173: E/AndroidRuntime(11625):    at com.example.Preview.surfaceCreated(Preview.java:60)
01-07 00:27:57.173: E/AndroidRuntime(11625):    at com.example.CameraDemo.onResume(CameraDemo.java:64)
01-07 00:27:57.173: E/AndroidRuntime(11625):    at android.app.Instrumentation.callActivityOnResume(Instrumentation.java:1242)
01-07 00:27:57.173: E/AndroidRuntime(11625):    at android.app.Activity.performResume(Activity.java:3904)
01-07 00:27:57.173: E/AndroidRuntime(11625):    at android.app.ActivityThread.performResumeActivity(ActivityThread.java:2450)
01-07 00:27:57.173: E/AndroidRuntime(11625):    ... 12 more
01-07 00:27:59.455: I/Process(11625): Sending signal. PID: 11625 SIG: 9
Run Code Online (Sandbox Code Playgroud)

Arc*_*pgc 5

你懂了

java.lang.RuntimeException: Fail to connect to camera service
Run Code Online (Sandbox Code Playgroud)

例外,当其他应用程序正在使用相机时.但我相信其他应用程序本身就是您的应用程序.你必须释放相机.

这些是您应该释放相机的情况:

在Preview类中:

public void surfaceDestroyed(SurfaceHolder holder) {

    // empty. Take care of releasing the Camera preview in your activity.
    if (mCamera != null) {
        mCamera.release();
    }
}
Run Code Online (Sandbox Code Playgroud)

在活动中:

@Override
public void onBackPressed() {
    super.onBackPressed();
    if (myCamera != null) {
        myCamera.release();
    }
    finish();
}

@Override
protected void onPause() {
    // TODO Auto-generated method stub
    super.onPause();
    if (myCamera != null) {
        myCamera.release();
    }
}
Run Code Online (Sandbox Code Playgroud)

同样在取消时点击,当你完成使用相机时,即当图像被捕获并且你回到活动时.

也试试这个:

public void surfaceChanged(SurfaceHolder holder, int format, int w, int h) {

    if (mHolder.getSurface() == null) {
        return;
    }

    try {
        mCamera.stopPreview();
    } catch (Exception e) {
        //You can ignore this, because this means the Preview doesn't Exist
        //So, no need to try stopping
    }

    try {
        mCamera.setPreviewDisplay(mHolder);
        mCamera.startPreview();
    } catch (Exception e) {
        //Catch this
    }
}
Run Code Online (Sandbox Code Playgroud)