From 72a8577ad5d60a98de85990d2af5cfb731c38be7 Mon Sep 17 00:00:00 2001 From: Alex Li Date: Fri, 29 Nov 2024 20:10:29 +0800 Subject: [PATCH] =?UTF-8?q?=F0=9F=90=9B=20Predicate=20the=20flash=20mode?= =?UTF-8?q?=20correctly=20when=20retrying=20the=20initialization=20(#280)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Resolves https://github.com/fluttercandies/flutter_wechat_camera_picker/issues/213#issuecomment-2437115670 --- CHANGELOG.md | 4 ++ lib/src/states/camera_picker_state.dart | 55 +++++++++++++------------ 2 files changed, 32 insertions(+), 27 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 2bd457f..76d0ac5 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -16,6 +16,10 @@ See the [Migration Guide](guides/migration_guide.md) for breaking changes betwee - Allows `sensor_plus` v6. +### Fixes + +- Predicate the flash mode correctly when retrying the initialization. + ## 4.3.4 ### Fixes diff --git a/lib/src/states/camera_picker_state.dart b/lib/src/states/camera_picker_state.dart index 2663246..c955fe2 100644 --- a/lib/src/states/camera_picker_state.dart +++ b/lib/src/states/camera_picker_state.dart @@ -318,18 +318,18 @@ class CameraPickerState extends State Future wrapControllerMethod( String key, Future Function() method, { - CameraDescription? description, + CameraDescription? camera, VoidCallback? onError, T? fallback, }) async { - description ??= currentCamera; - if (invalidControllerMethods[description]!.contains(key)) { + camera ??= currentCamera; + if (invalidControllerMethods[camera]!.contains(key)) { return fallback; } try { return await method(); } catch (e) { - invalidControllerMethods[description]!.add(key); + invalidControllerMethods[camera]!.add(key); onError?.call(); rethrow; } @@ -407,10 +407,10 @@ class CameraPickerState extends State index = currentCameraIndex; } // Initialize the controller with the given resolution preset. - final description = cameraDescription ?? cameras[index]; - invalidControllerMethods[description] ??= {}; + final camera = cameraDescription ?? cameras[index]; + invalidControllerMethods[camera] ??= {}; final CameraController newController = CameraController( - description, + camera, pickerConfig.resolutionPreset, enableAudio: enableAudio, imageFormatGroup: pickerConfig.imageFormatGroup, @@ -440,37 +440,37 @@ class CameraPickerState extends State wrapControllerMethod( 'getExposureOffsetStepSize', () => newController.getExposureOffsetStepSize(), - description: description, + camera: camera, fallback: exposureStep, ).then((value) => exposureStep = value!), wrapControllerMethod( 'getMaxExposureOffset', () => newController.getMaxExposureOffset(), - description: description, + camera: camera, fallback: maxAvailableExposureOffset, ).then((value) => maxAvailableExposureOffset = value!), wrapControllerMethod( 'getMinExposureOffset', () => newController.getMinExposureOffset(), - description: description, + camera: camera, fallback: minAvailableExposureOffset, ).then((value) => minAvailableExposureOffset = value!), wrapControllerMethod( 'getMaxZoomLevel', () => newController.getMaxZoomLevel(), - description: description, + camera: camera, fallback: maxAvailableZoom, ).then((value) => maxAvailableZoom = value!), wrapControllerMethod( 'getMinZoomLevel', () => newController.getMinZoomLevel(), - description: description, + camera: camera, fallback: minAvailableZoom, ).then((value) => minAvailableZoom = value!), wrapControllerMethod( 'getMinZoomLevel', () => newController.getMinZoomLevel(), - description: description, + camera: camera, fallback: minAvailableZoom, ).then((value) => minAvailableZoom = value!), if (pickerConfig.lockCaptureOrientation != null) @@ -479,23 +479,24 @@ class CameraPickerState extends State () => newController.lockCaptureOrientation( pickerConfig.lockCaptureOrientation, ), - description: description, + camera: camera, ), // Do not set flash modes for the front camera. - if (description.lensDirection != CameraLensDirection.front && - pickerConfig.preferredFlashMode != FlashMode.auto) - wrapControllerMethod( - 'setFlashMode', - () => newController.setFlashMode( - pickerConfig.preferredFlashMode, - ), - description: description, - onError: () { - validFlashModes[description]?.remove( - pickerConfig.preferredFlashMode, + if (camera.lensDirection != CameraLensDirection.front) + Future(() async { + final flashMode = pickerConfig.preferredFlashMode; + if (flashMode != FlashMode.auto && + validFlashModes[camera]?.contains(flashMode) != false) { + return wrapControllerMethod( + 'setFlashMode', + () => newController.setFlashMode(flashMode), + camera: camera, + onError: () { + validFlashModes[camera]?.remove(flashMode); + }, ); - }, - ), + } + }), ], eagerError: false, );