AppOpsManager#checkOp(AppOpsManager.OPSTR_CAMERA, Process.myUid(), getPackageName()) возвращает AppOpsManager#MODE_ALLOWEDОднако при попытке Camera.open (i) для проверки свойств камеры я получаю
I/CameraService: Camera 0: Access for "package" has been restricted
Очевидно, это могло произойти [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();
}
}
По-видимому, это проблема устройства. Nokia 6 / TA-1000, Android 7.1.1
Сценарий
Воспроизводится с любым другим приложением, включая приложение камеры по умолчанию.