From f3e8bc9c9afd73b6fbeef70799f78324db765ec0 Mon Sep 17 00:00:00 2001 From: camsim99 Date: Mon, 6 May 2024 12:52:01 -0400 Subject: [PATCH 1/3] Add empty impl --- packages/camera/camera_android_camerax/CHANGELOG.md | 4 ++++ .../lib/src/android_camera_camerax.dart | 9 +++++++++ packages/camera/camera_android_camerax/pubspec.yaml | 2 +- 3 files changed, 14 insertions(+), 1 deletion(-) diff --git a/packages/camera/camera_android_camerax/CHANGELOG.md b/packages/camera/camera_android_camerax/CHANGELOG.md index 863f99b8aa80..01b2fb1e7354 100644 --- a/packages/camera/camera_android_camerax/CHANGELOG.md +++ b/packages/camera/camera_android_camerax/CHANGELOG.md @@ -1,3 +1,7 @@ +## 0.6.4+1 + +* Adds empty implementation for `prepareVideoRecording` since this optimization is not used on Android. + ## 0.6.4 * Prevents usage of unsupported concurrent `UseCase`s based on the capabiliites of the camera device. diff --git a/packages/camera/camera_android_camerax/lib/src/android_camera_camerax.dart b/packages/camera/camera_android_camerax/lib/src/android_camera_camerax.dart index b73ce0186bec..5ced7ccccb38 100644 --- a/packages/camera/camera_android_camerax/lib/src/android_camera_camerax.dart +++ b/packages/camera/camera_android_camerax/lib/src/android_camera_camerax.dart @@ -867,6 +867,15 @@ class AndroidCameraCameraX extends CameraPlatform { } } + /// Prepare the capture session for video recording. + /// + /// This optimization is not used on Android, so this implementation is a + /// no-op. + @override + Future prepareForVideoRecording() { + return Future.value(); + } + /// Configures and starts a video recording. Returns silently without doing /// anything if there is currently an active recording. /// diff --git a/packages/camera/camera_android_camerax/pubspec.yaml b/packages/camera/camera_android_camerax/pubspec.yaml index 8f1b5d11bbc6..cabd26b66a2d 100644 --- a/packages/camera/camera_android_camerax/pubspec.yaml +++ b/packages/camera/camera_android_camerax/pubspec.yaml @@ -2,7 +2,7 @@ name: camera_android_camerax description: Android implementation of the camera plugin using the CameraX library. repository: https://github.com/flutter/packages/tree/main/packages/camera/camera_android_camerax issue_tracker: https://github.com/flutter/flutter/issues?q=is%3Aissue+is%3Aopen+label%3A%22p%3A+camera%22 -version: 0.6.4 +version: 0.6.4+1 environment: sdk: ^3.1.0 From bad8384015d190d202b1ce5eb0bdea4298ac2b3f Mon Sep 17 00:00:00 2001 From: camsim99 Date: Mon, 6 May 2024 12:53:56 -0400 Subject: [PATCH 2/3] Typo --- packages/camera/camera_android_camerax/CHANGELOG.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/packages/camera/camera_android_camerax/CHANGELOG.md b/packages/camera/camera_android_camerax/CHANGELOG.md index 01b2fb1e7354..17c007087abf 100644 --- a/packages/camera/camera_android_camerax/CHANGELOG.md +++ b/packages/camera/camera_android_camerax/CHANGELOG.md @@ -1,6 +1,6 @@ ## 0.6.4+1 -* Adds empty implementation for `prepareVideoRecording` since this optimization is not used on Android. +* Adds empty implementation for `prepareForVideoRecording` since this optimization is not used on Android. ## 0.6.4 From bb9313a773023c71afca73c562157ce18377a0e3 Mon Sep 17 00:00:00 2001 From: camsim99 Date: Mon, 6 May 2024 13:23:00 -0400 Subject: [PATCH 3/3] Add test --- .../test/android_camera_camerax_test.dart | 18 ++++++++++++++++++ 1 file changed, 18 insertions(+) diff --git a/packages/camera/camera_android_camerax/test/android_camera_camerax_test.dart b/packages/camera/camera_android_camerax/test/android_camera_camerax_test.dart index f0caef74a24c..23af67c5ca18 100644 --- a/packages/camera/camera_android_camerax/test/android_camera_camerax_test.dart +++ b/packages/camera/camera_android_camerax/test/android_camera_camerax_test.dart @@ -4040,4 +4040,22 @@ void main() { verify( camera.processCameraProvider!.unbind([camera.imageAnalysis!])); }); + + test( + 'prepareForVideoRecording does not make any calls involving starting video recording', + () async { + final AndroidCameraCameraX camera = AndroidCameraCameraX(); + + // Set directly for test versus calling createCamera. + camera.processCameraProvider = MockProcessCameraProvider(); + camera.recorder = MockRecorder(); + camera.videoCapture = MockVideoCapture(); + camera.camera = MockCamera(); + + await camera.prepareForVideoRecording(); + verifyNoMoreInteractions(camera.processCameraProvider); + verifyNoMoreInteractions(camera.recorder); + verifyNoMoreInteractions(camera.videoCapture); + verifyNoMoreInteractions(camera.camera); + }); }