W / CameraBase ﹕ Ocorreu um erro ao conectar à câmera: 0

Havia uma pergunta semelhante, mas não foi resolvida:

W / CameraBase ﹕ Ocorreu um erro ao conectar-se à câmera: 0 na chamada camera.open ()

Eu tenho um aplicativo que (naturalmente) está usando a câmera. Está funcionando bem. No entanto, sem alterações no código, entre as compilações, o aplicativo começou a falhar (não foram verificadas alterações no código pelo histórico de confirmação do Git).

Para verificar se o problema está em algum lugar do hardware, executei o mesmo código em outro telefone e ele funciona muito bem. De alguma forma, a câmera está bloqueada e não abre.

Aqui está o código relevante:

Criar um objeto anterior

_cameraPreview = new CameraPreview(getActivity(),_camera);

Este é o código de criação para ele

 public CameraPreview(Context context, Camera camera) 
    {
        super(context);
        _camera = camera;
        _surfaceHolder = getHolder();
        _surfaceHolder.addCallback(this);
    }

Abrindo a câmera:

// Abre a câmera voltada para trás por padrão

public static Camera getCameraInstance()
{
    Camera c = null;
    try
    {
        c = Camera.open();
    }catch (Exception e)
    {
       e.printStackTrace();
    }

    return c;
}

É aqui que o erro ocorre, camera.Open lança o erro com o seguinte rastreamento de pilha. O objeto da minha câmera é nulo. Este código é dos documentos oficiais do Android, mas eles não falam sobre como 'liberar a câmera' se ela estiver bloqueada fora da sessão.

O logout completo é

W/CameraBase﹕ An error occurred while connecting to camera: 0
W/System.err﹕ java.lang.RuntimeException: Fail to connect to camera service
W/System.err﹕ at android.hardware.Camera.<init>(Camera.java:497)
W/System.err﹕ at android.hardware.Camera.open(Camera.java:357)
W/System.err﹕ at co.pumpup.app.EditPhotoFragment.getCameraInstance(EditPhotoFragment.java:241)
W/System.err﹕ at co.pumpup.app.EditPhotoFragment.onCreateView(EditPhotoFragment.java:76)
W/System.err﹕ at android.app.Fragment.performCreateView(Fragment.java:2053)
W/System.err﹕ at android.app.FragmentManagerImpl.moveToState(FragmentManager.java:894)
W/System.err﹕ at android.app.FragmentManagerImpl.moveToState(FragmentManager.java:1067)
W/System.err﹕ at android.app.BackStackRecord.run(BackStackRecord.java:834)
W/System.err﹕ at android.app.FragmentManagerImpl.execPendingActions(FragmentManager.java:1452)
W/System.err﹕ at android.app.Activity.performStart(Activity.java:6005)
W/System.err﹕ at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2288)
W/System.err﹕ at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2387)
W/System.err﹕ at android.app.ActivityThread.access$800(ActivityThread.java:151)
W/System.err﹕ at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1303)
W/System.err﹕ at android.os.Handler.dispatchMessage(Handler.java:102)
W/System.err﹕ at android.os.Looper.loop(Looper.java:135)
W/System.err﹕ at android.app.ActivityThread.main(ActivityThread.java:5254)
W/System.err﹕ at java.lang.reflect.Method.invoke(Native Method)
W/System.err﹕ at java.lang.reflect.Method.invoke(Method.java:372)
W/System.err﹕ at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:903)
W/System.err﹕ at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:698)

Você pode aconselhar como eu posso 'desbloquear' uma câmera trancada como esta?

questionAnswers(3)

yourAnswerToTheQuestion