W/CameraBase: при подключении к камере произошла ошибка: 0

Был аналогичный вопрос, но он остался нерешенным:

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)

Можете ли вы посоветовать, как я могу "разблокировать" заблокированную камеру следующим образом?

Ответ 1

"Не удается подключиться к службе камеры" означает, что ваше (или другое) приложение камеры не смогло правильно освободить камеру. Иногда это происходило со мной, когда я разрабатывал приложение. Первое, что я попробую, - открыть камеру из приложения камеры по умолчанию, которое поставляется вместе с телефоном (просто нажав кнопку "камера" ). Если это не удалось открыть, то единственным вариантом было перезапустить телефон.

Это спекуляция, но у вашего кода может быть ошибка, которая возникает только изредка, и она просто не появилась до сих пор благодаря чистой удаче. Если он сохраняется, проверьте вопросы, связанные с "как правильно освободить камеру в android". Они помогли мне справиться с этим.

Ответ 2

Начиная с Android 6.0 (уровень API 23), пользователи предоставляют разрешения для приложений во время работы приложения, а не при установке приложения. Этот подход упрощает процесс установки приложения, поскольку пользователю не нужно предоставлять разрешения при установке или обновлении приложения. Это также дает пользователю больше контроля над функциональностью приложения; например, пользователь может выбрать доступ к камере для камеры, но не к местоположению устройства. Пользователь может отменить разрешения в любое время, перейдя на экран настроек приложения. http://developer.android.com/training/permissions/requesting.html

Ответ 3

Я не знаю, было ли это ваше дело, но это случилось со мной, поэтому я решил поделиться этим. Мое приложение выполняло то же самое (хотя у меня была проблема с Camera.open(), поэтому я не видел его сначала). НО я сделал то, что сказал Panonski, и включил камеру из приложения для системной камеры и увидел, что это используя фронтальную камеру. Переключение обратно на заднюю камеру позволило моему приложению снова работать.

Я изменил использование Camera.open() в Camera.open(Camera.CameraInfo.CAMERA_FACING_BACK), и теперь это работает независимо от того, как камера была оставлена ​​раньше. (Использование Galaxy Note 4).

Надеюсь, это поможет.