D/CameraStateRegistry( 9840): Recalculating open cameras:
D/CameraStateRegistry( 9840): Camera State
D/CameraStateRegistry( 9840): -------------------------------------------------------------------
D/CameraStateRegistry( 9840): Camera@48d314e[id=10] UNKNOWN
D/CameraStateRegistry( 9840): Camera@810b77[id=1] OPEN
D/CameraStateRegistry( 9840): -------------------------------------------------------------------
D/CameraStateRegistry( 9840): Open count: 1 (Max allowed: 1)
D/CameraStateMachine( 9840): New public camera state CameraState{type=OPEN, error=null} from OPEN and null
D/CameraStateMachine( 9840): Publishing new public camera state CameraState{type=OPEN, error=null}
D/UseCaseAttachState( 9840): All use case: [androidx.camera.core.ImageCapture-37d83db3-143b-4eca-8d2d-efc666438751140185753, androidx.camera.core.Preview-50817409-2990-4cce-8950-506b065c63c99934749, androidx.camera.core.ImageAnalysis-5373193f-b794-47db-a97b-7e7e43e123e8201584447] for camera: 1
D/UseCaseAttachState( 9840): Active and attached use case: [androidx.camera.core.ImageCapture-37d83db3-143b-4eca-8d2d-efc666438751140185753, androidx.camera.core.Preview-50817409-2990-4cce-8950-506b065c63c99934749] for camera: 1
D/SyncCaptureSessionBase( 9840): [androidx.camera.camera2.internal.SynchronizedCaptureSessionBaseImpl@3678b83] getSurface...done
D/CaptureSession( 9840): Opening capture session.
D/DeferrableSurface( 9840): use count+1, useCount=2 androidx.camera.core.SurfaceRequest$2@75b2504
D/DeferrableSurface( 9840): New surface in use[total_surfaces=4, used_surfaces=2](androidx.camera.core.impl.ImmediateSurface@eca796e}
D/DeferrableSurface( 9840): use count+1, useCount=1 androidx.camera.core.impl.ImmediateSurface@eca796e
D/DeferrableSurface( 9840): New surface in use[total_surfaces=4, used_surfaces=3](androidx.camera.core.impl.ImmediateSurface@a8be7a}
D/DeferrableSurface( 9840): use count+1, useCount=1 androidx.camera.core.impl.ImmediateSurface@a8be7a
D/CaptureSession( 9840): Attempting to send capture request onConfigured
D/CaptureSession( 9840): Issuing request for session.
D/Camera2CaptureRequestBuilder( 9840): createCaptureRequest
D/CaptureSession( 9840): CameraCaptureSession.onConfigured() mState=OPENED
D/CaptureSession( 9840): CameraCaptureSession.onReady() OPENED
D/EGL_emulation( 9840): app_time_stats: avg=48.03ms min=10.81ms max=283.63ms count=22
D/EGL_emulation( 9840): app_time_stats: avg=33.92ms min=28.40ms max=50.28ms count=30
D/DeferrableSurface( 9840): surface closed, useCount=2 closed=true androidx.camera.core.SurfaceRequest$2@75b2504
D/DeferrableSurface( 9840): surface closed, useCount=0 closed=true androidx.camera.core.processing.SurfaceEdge$SettableSurface@e3aab58
D/DeferrableSurface( 9840): Surface terminated[total_surfaces=3, used_surfaces=3](androidx.camera.core.processing.SurfaceEdge$SettableSurface@e3aab58}
D/DeferrableSurface( 9840): use count-1, useCount=1 closed=true androidx.camera.core.SurfaceRequest$2@75b2504
D/Camera2CameraImpl( 9840): {Camera@810b77[id=1]} Use cases [androidx.camera.core.Preview-50817409-2990-4cce-8950-506b065c63c99934749] now DETACHED for camera
D/UseCaseAttachState( 9840): All use case: [androidx.camera.core.ImageCapture-37d83db3-143b-4eca-8d2d-efc666438751140185753, androidx.camera.core.ImageAnalysis-5373193f-b794-47db-a97b-7e7e43e123e8201584447] for camera: 1
D/Camera2CameraImpl( 9840): mMeteringRepeating is ATTACHED, SessionConfig Surfaces: 2, CaptureConfig Surfaces: 1
D/UseCaseAttachState( 9840): Active and attached use case: [androidx.camera.core.ImageCapture-37d83db3-143b-4eca-8d2d-efc666438751140185753] for camera: 1
D/CaptureSession( 9840): Attempting to submit CaptureRequest after setting
D/CaptureSession( 9840): Skipping issueRepeatingCaptureRequests for no surface.
D/Camera2CameraImpl( 9840): {Camera@810b77[id=1]} Resetting Capture Session
D/Camera2CameraImpl( 9840): {Camera@810b77[id=1]} Releasing session in state OPENED
D/UseCaseAttachState( 9840): All use case: [androidx.camera.core.ImageCapture-37d83db3-143b-4eca-8d2d-efc666438751140185753, androidx.camera.core.ImageAnalysis-5373193f-b794-47db-a97b-7e7e43e123e8201584447] for camera: 1
D/CaptureSession( 9840): onSessionFinished()
D/SyncCaptureSessionBase( 9840): [androidx.camera.camera2.internal.SynchronizedCaptureSessionBaseImpl@3202a30] getSurface...done
D/CaptureSession( 9840): Opening capture session.
D/DeferrableSurface( 9840): use count+1, useCount=2 androidx.camera.core.impl.ImmediateSurface@eca796e
D/DeferrableSurface( 9840): use count+1, useCount=2 androidx.camera.core.impl.ImmediateSurface@a8be7a
D/EGL_emulation( 9840): app_time_stats: avg=33.59ms min=5.88ms max=68.97ms count=30
D/DeferrableSurface( 9840): use count-1, useCount=0 closed=true androidx.camera.core.SurfaceRequest$2@75b2504
D/DeferrableSurface( 9840): Surface no longer in use[total_surfaces=3, used_surfaces=2](androidx.camera.core.SurfaceRequest$2@75b2504}
D/DeferrableSurface( 9840): Surface terminated[total_surfaces=2, used_surfaces=2](androidx.camera.core.SurfaceRequest$2@75b2504}
D/DeferrableSurface( 9840): use count-1, useCount=1 closed=false androidx.camera.core.impl.ImmediateSurface@eca796e
D/DeferrableSurface( 9840): use count-1, useCount=1 closed=false androidx.camera.core.impl.ImmediateSurface@a8be7a
D/CaptureSession( 9840): Attempting to send capture request onConfigured
D/CaptureSession( 9840): Skipping issueRepeatingCaptureRequests for no surface.
D/CaptureSession( 9840): CameraCaptureSession.onConfigured() mState=OPENED
D/CaptureSession( 9840): CameraCaptureSession.onReady() OPENED
D/CaptureSession( 9840): CameraCaptureSession.onReady() OPENED
D/ProfileInstaller( 9840): Installing profile for com.example.camera_resume_test2
D/CameraOrientationUtil( 9840): getRelativeImageRotation: destRotationDegrees=0, sourceRotationDegrees=270, isOppositeFacing=false, result=270
D/CameraOrientationUtil( 9840): getRelativeImageRotation: destRotationDegrees=0, sourceRotationDegrees=270, isOppositeFacing=false, result=270
D/CameraOrientationUtil( 9840): getRelativeImageRotation: destRotationDegrees=0, sourceRotationDegrees=270, isOppositeFacing=false, result=270
D/DynamicRangeResolver( 9840): Resolved dynamic range for use case androidx.camera.core.Preview-50817409-2990-4cce-8950-506b065c63c9 to no compatible HDR dynamic ranges.
D/DynamicRangeResolver( 9840): DynamicRange@fc0b46c{encoding=UNSPECIFIED, bitDepth=0}
D/DynamicRangeResolver( 9840): ->
D/DynamicRangeResolver( 9840): DynamicRange@329f91f{encoding=SDR, bitDepth=8}
D/EGL_emulation( 9840): app_time_stats: avg=340.82ms min=32.02ms max=1555.65ms count=5
D/CameraOrientationUtil( 9840): getRelativeImageRotation: destRotationDegrees=0, sourceRotationDegrees=270, isOppositeFacing=false, result=270
D/DeferrableSurface( 9840): Surface created[total_surfaces=3, used_surfaces=2](androidx.camera.core.processing.SurfaceEdge$SettableSurface@d55a1e1}
D/DeferrableSurface( 9840): Surface created[total_surfaces=4, used_surfaces=2](androidx.camera.core.SurfaceRequest$2@da97b1d}
D/DeferrableSurface( 9840): New surface in use[total_surfaces=4, used_surfaces=3](androidx.camera.core.SurfaceRequest$2@da97b1d}
D/DeferrableSurface( 9840): use count+1, useCount=1 androidx.camera.core.SurfaceRequest$2@da97b1d
D/CameraOrientationUtil( 9840): getRelativeImageRotation: destRotationDegrees=0, sourceRotationDegrees=270, isOppositeFacing=false, result=270
D/Camera2CameraImpl( 9840): {Camera@810b77[id=1]} Use cases [androidx.camera.core.Preview-50817409-2990-4cce-8950-506b065c63c99934749] now ATTACHED
D/UseCaseAttachState( 9840): All use case: [androidx.camera.core.ImageCapture-37d83db3-143b-4eca-8d2d-efc666438751140185753, androidx.camera.core.ImageAnalysis-5373193f-b794-47db-a97b-7e7e43e123e8201584447, androidx.camera.core.Preview-50817409-2990-4cce-8950-506b065c63c99934749] for camera: 1
D/UseCaseAttachState( 9840): Active and attached use case: [androidx.camera.core.ImageCapture-37d83db3-143b-4eca-8d2d-efc666438751140185753] for camera: 1
D/CaptureSession( 9840): Attempting to submit CaptureRequest after setting
D/CaptureSession( 9840): Skipping issueRepeatingCaptureRequests for no surface.
D/Camera2CameraImpl( 9840): {Camera@810b77[id=1]} Resetting Capture Session
D/Camera2CameraImpl( 9840): {Camera@810b77[id=1]} Releasing session in state OPENED
D/UseCaseAttachState( 9840): All use case: [androidx.camera.core.ImageCapture-37d83db3-143b-4eca-8d2d-efc666438751140185753, androidx.camera.core.ImageAnalysis-5373193f-b794-47db-a97b-7e7e43e123e8201584447, androidx.camera.core.Preview-50817409-2990-4cce-8950-506b065c63c99934749] for camera: 1
D/Camera2CameraImpl( 9840): {Camera@810b77[id=1]} Use case androidx.camera.core.Preview-50817409-2990-4cce-8950-506b065c63c99934749 ACTIVE
D/UseCaseAttachState( 9840): Active and attached use case: [androidx.camera.core.ImageCapture-37d83db3-143b-4eca-8d2d-efc666438751140185753, androidx.camera.core.Preview-50817409-2990-4cce-8950-506b065c63c99934749] for camera: 1
D/CaptureSession( 9840): onSessionFinished()
D/DeferrableSurface( 9840): use count-1, useCount=0 closed=false androidx.camera.core.impl.ImmediateSurface@eca796e
D/DeferrableSurface( 9840): Surface no longer in use[total_surfaces=4, used_surfaces=2](androidx.camera.core.impl.ImmediateSurface@eca796e}
D/DeferrableSurface( 9840): use count-1, useCount=0 closed=false androidx.camera.core.impl.ImmediateSurface@a8be7a
D/DeferrableSurface( 9840): Surface no longer in use[total_surfaces=4, used_surfaces=1](androidx.camera.core.impl.ImmediateSurface@a8be7a}
D/SyncCaptureSessionBase( 9840): [androidx.camera.camera2.internal.SynchronizedCaptureSessionBaseImpl@f4c8090] getSurface...done
D/CaptureSession( 9840): Opening capture session.
E/Camera-SurfaceUtils-JNI( 9840): getNativeWindow: Surface had no valid native window.
E/Camera-SurfaceUtils-JNI( 9840): SurfaceUtils_nativeDetectSurfaceDimens: Could not retrieve native window from surface.
W/CaptureSession( 9840): Opening session with fail OPENING
W/CaptureSession( 9840): java.lang.IllegalArgumentException: Surface was abandoned
W/CaptureSession( 9840): at android.hardware.camera2.utils.SurfaceUtils.getSurfaceSize(SurfaceUtils.java:135)
W/CaptureSession( 9840): at android.hardware.camera2.params.OutputConfiguration.<init>(OutputConfiguration.java:563)
W/CaptureSession( 9840): at android.hardware.camera2.params.OutputConfiguration.<init>(OutputConfiguration.java:404)
W/CaptureSession( 9840): at androidx.camera.camera2.internal.compat.params.OutputConfigurationCompatApi33Impl.<init>(OutputConfigurationCompatApi33Impl.java:37)
W/CaptureSession( 9840): at androidx.camera.camera2.internal.compat.params.OutputConfigurationCompat.<init>(OutputConfigurationCompat.java:64)
W/CaptureSession( 9840): at androidx.camera.camera2.internal.CaptureSession.getOutputConfigurationCompat(CaptureSession.java:406)
W/CaptureSession( 9840): at androidx.camera.camera2.internal.CaptureSession.openCaptureSession(CaptureSession.java:331)
W/CaptureSession( 9840): at androidx.camera.camera2.internal.CaptureSession.lambda$open$0$androidx-camera-camera2-internal-CaptureSession(CaptureSession.java:231)
W/CaptureSession( 9840): at androidx.camera.camera2.internal.CaptureSession$$ExternalSyntheticLambda1.apply(Unknown Source:8)
W/CaptureSession( 9840): at androidx.camera.core.impl.utils.futures.ChainingListenableFuture.run(ChainingListenableFuture.java:203)
W/CaptureSession( 9840): at androidx.camera.core.impl.utils.executor.SequentialExecutor$QueueWorker.workOnQueue(SequentialExecutor.java:231)
W/CaptureSession( 9840): at androidx.camera.core.impl.utils.executor.SequentialExecutor$QueueWorker.run(SequentialExecutor.java:173)
W/CaptureSession( 9840): at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)
W/CaptureSession( 9840): at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:644)
W/CaptureSession( 9840): at java.lang.Thread.run(Thread.java:1012)
D/Camera2CameraImpl( 9840): {Camera@810b77[id=1]} Transitioning camera internal state: OPENED --> OPENED
D/CameraStateMachine( 9840): New public camera state CameraState{type=OPEN, error=StateError{code=4, cause=java.lang.IllegalArgumentException: Surface was abandoned}} from OPEN and StateError{code=4, cause=java.lang.IllegalArgumentException: Surface was abandoned}
D/CameraStateMachine( 9840): Publishing new public camera state CameraState{type=OPEN, error=StateError{code=4, cause=java.lang.IllegalArgumentException: Surface was abandoned}}
What package does this bug report belong to?
camera
What target platforms are you seeing this bug on?
Android
Have you already upgraded your packages?
Yes
Dependency versions
pubspec.lock
Steps to reproduce
Expected results
The camera preview should be resumed. In the pubspec.lock if you have camera_android_camerax version: "0.6.8+3" the issue is persistent and happens on all devices. If you switch to "0.6.7+2" its fixed.
Actual results
The app silent crashes on android level and the camera preview is stuck
Code sample
Code sample
Screenshots or Videos
Screenshots / Video demonstration
Screen_recording_20240917_142220.webm
Logs
Logs
Flutter Doctor output
Doctor output