Camera.open () получает «Доступ для <package>ограничен» - PullRequest
0 голосов
/ 04 декабря 2018
  • Проблема возникает на Nokia 6 с Android 7.1.1
  • Разрешение предоставлено
  • AppOpsManager#checkOp(AppOpsManager.OPSTR_CAMERA, Process.myUid(), getPackageName()) возвращает AppOpsManager#MODE_ALLOWED

Еще при попыткеCamera.open (i) для проверки свойств камеры я получаю

I / CameraService: Camera 0: доступ к «пакету» был ограничен

Видимо, это могло произойти только[1] если пакет или uId приложения были явно ограничены при запуске AppOpsManager # OP_CAMERA.Но почему это случилось?После AppOpsManager#checkOp говорит AppOpsManager#MODE_ALLOWED

Пример кода

for (int i = 0; i < numCameras; ++i) {
    List<Size> supportedSizes = null;
    List<int[]> supportedFpsRanges = null;
    Camera camera = null;
    try {
        camera = Camera.open(i);
        Parameters parameters = camera.getParameters();
        supportedSizes = parameters.getSupportedPreviewSizes();
        supportedFpsRanges = getFpsRangesRobust(parameters);
    } catch (Exception e) {
        ...
    } finally {
        if (camera != null) {
            camera.release();
        }
    }

[1] https://github.com/aosp-mirror/platform_frameworks_base/blob/oreo-mr1-release/services/core/java/com/android/server/AppOpsService.java#L2588

1 Ответ

0 голосов
/ 07 января 2019

По-видимому, это проблема устройства.Nokia 6 / TA-1000, Android 7.1.1

Сценарий

  • попытка использовать камеру
  • Приложение запрашивает разрешение, нажмите Отказать
  • попробуйте использовать камеру
  • приложение запрашивает разрешение, нажмите Разрешить
  • Ошибка, отправленная в logcat, камера не работает

Воспроизводится с любым другим приложением,включая приложение камеры по умолчанию.

...