Был аналогичный вопрос, но он остался нерешенным:
W/CameraBase: при подключении к камере произошла ошибка: 0 на вызове camera.open()
У меня есть приложение, которое (естественно) использует камеру. Его работа прекрасна. Однако без каких-либо изменений кода между сборками приложение начало сбой (не проверено отсутствие изменений кода через Git историю фиксации).
Чтобы еще раз проверить, что проблема находится где-то в аппаратном обеспечении, я запускал тот же код на другом телефоне, и он работает нормально. Каким-то образом камера заблокирована и не откроется.
Вот соответствующий код:
Создайте объект previe
_cameraPreview = new CameraPreview(getActivity(),_camera);
Это код создания для него
public CameraPreview(Context context, Camera camera)
{
super(context);
_camera = camera;
_surfaceHolder = getHolder();
_surfaceHolder.addCallback(this);
}
Открытие камеры:
//Открывает обратную камеру по умолчанию
public static Camera getCameraInstance()
{
Camera c = null;
try
{
c = Camera.open();
}catch (Exception e)
{
e.printStackTrace();
}
return c;
}
В этом случае возникает ошибка. camera.Open выдает ошибку со следующей трассировкой стека. Объект моей камеры равен нулю. Этот код из официальных документов Android, но они не говорят о том, как "освободить камеру", если она заблокирована вне сеанса.
Полный выход
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)
Можете ли вы посоветовать, как я могу "разблокировать" заблокированную камеру следующим образом?