Status Update
Comments
wu...@google.com <wu...@google.com>
xi...@google.com <xi...@google.com>
xi...@google.com <xi...@google.com> #2
Thanks for filing the bug. Looks like ImageAnalysis picks a different resolution after adding the ResolutionSelector API. I wonder what is the workaround though. What is your ResolutionSelector/ResolutionStrategy that fixed the issue?
Also adding ResolutionSelector should not affect the existing logic and cause the target resolution to regress. Charcoal, do you have more insight on this?
The a better fix is allowing MlKitAnalyzer to provide a ResolutionSelector and deprecate the Analyzer#getDefaultTargetResolution
. It's probably too late for 1.4. We will do it in the next version.
ch...@google.com <ch...@google.com> #3
Thanks for reporting this issue. After checking, the issue is caused by that the Analyzer's default target resolution is not correctly merged to the final ResolutionSelector instance.
When using ResolutionSelector with ResolutionStrategy directly, the set ResolutionSelector will directly be used no matter the analyzer has default target resolution or not.
I will fix this issue.
ne...@miracl.com <ne...@miracl.com> #4
Thanks for your swift response and for identifying the issue. Looking forward to the fix.
ap...@google.com <ap...@google.com> #5
Branch: androidx-main
commit 1c3f4cb30dc07227c1d3d0dc1d3804b5c4447e15
Author: CharcoalChen <charcoalchen@google.com>
Date: Fri Mar 22 10:45:47 2024
Fix ImageAnalysis analyzer default target resolution merge issue
ImageAnalysis analyzer default target resolution was not correctly merged into ResolutionSelector.
Relnote: "Fixed ImageAnalysis' resolution selection issue related to the analyzer default target resolution setting: target resolution was incorrectly kept as 640x480 even if applications has set a different analyzer default resolution setting. If applications encounter this issue (1.3.0 ~ 1.3.2) and can't upgrade to use the newer version releases which contain the solution, directly setting a ResolutionSelector with the preferred resolution and a matching AspectRatioStrategy to the ImageAnalysis UseCase can workaround this issue."
Bug: 330091012
Test: ImageAnalysisTest
Change-Id: I81f72a850dcedb664e5b661247991ee4851bdfc6
M camera/camera-core/src/main/java/androidx/camera/core/ImageAnalysis.java
M camera/camera-core/src/main/java/androidx/camera/core/UseCase.java
M camera/camera-core/src/test/java/androidx/camera/core/ImageAnalysisTest.java
ch...@google.com <ch...@google.com> #6
na...@google.com <na...@google.com> #7
The following release(s) address this bug.It is possible this bug has only been partially addressed:
androidx.camera:camera-core:1.3.3
androidx.camera:camera-core:1.4.0-alpha05
av...@gmail.com <av...@gmail.com> #9
Porque no me yega AMI villera
Description
CAMERAX VERSION: 1.3.0
DESCRIPTION:
We are using MLKitAnalyzer with CameraController to scan QR codes. When upgrading from version 1.2.3 to 1.3.0 and above, we've noticed that the camera must be positioned very close to the QR code in order to successfully scan it. Previously, QR codes were scannable from a greater distance away from the camera.
ADDITIONAL INFORMATION:
It appears that the issue may be related to the resolution and the new ResolutionSelector API. Manually setting the ResolutionStrategy via setImageAnalysisResolutionSelector added in version 1.4.0-alpha4 improves the accuracy.
EXAMPLE CONFIGURATION: