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?