CameraController
public abstract class CameraController
LifecycleCameraController |
A controller that provides most of the CameraX features. |
The abstract base camera controller class.
This a high level controller that provides most of the CameraX core features in a single class. It handles camera initialization, creates and configures UseCases. It also listens to device motion sensor and set the target rotation for the use cases.
The controller is required to be used with a PreviewView. PreviewView provides the UI elements to display camera preview. The layout of the PreviewView is used to set the crop rect so the output from other use cases matches the preview display in a WYSIWYG way. The controller also listens to PreviewView's touch events to handle tap-to-focus and pinch-to-zoom features.
This class provides features of 4 UseCases: Preview, ImageCapture, ImageAnalysis and VideoCapture. Preview is required and always enabled. ImageCapture and ImageAnalysis are enabled by default. The video capture is disabled by default because it might affect other use cases, especially on lower end devices. It might be necessary to disable ImageCapture and/or ImageAnalysis before the video capture feature can be enabled. Disabling/enabling UseCases freezes the preview for a short period of time. To avoid the glitch, the UseCases need to be enabled/disabled before the controller is set on PreviewView.
Summary
Nested types |
|---|
public final class CameraController.OutputSizeThis class is deprecated. Use |
Constants |
|
|---|---|
static final int |
This field is deprecated. Use |
static final int |
IMAGE_ANALYSIS = 2Bitmask option to enable |
static final int |
IMAGE_CAPTURE = 1Bitmask option to enable |
static final int |
The previous tap-to-focus action was failed to complete. |
static final int |
The previous tap-to-focus action was completed successfully and the camera is focused. |
static final int |
The previous tap-to-focus action was completed successfully but the camera is still unfocused, similar to the |
static final int |
No tap-to-focus action has been started by the end user. |
static final int |
A tap-to-focus action has started but not completed. |
static final int |
VIDEO_CAPTURE = 4Bitmask option to enable video capture use case. |
Public methods |
|
|---|---|
void |
Removes all effects. |
void |
Removes a previously set analyzer. |
@NonNull ListenableFuture<Void> |
@MainThreadEnable the torch or disable the torch. |
@Nullable CameraControl |
Gets the |
@Nullable CameraInfo |
Gets the |
@NonNull CameraSelector |
Gets the |
@Nullable Executor |
Gets the default executor for |
int |
Returns the mode with which images are acquired. |
int |
Gets the image queue depth of |
int |
Gets the output image format for |
@Nullable ResolutionSelector |
Returns the |
@Nullable CameraController.OutputSize |
This method is deprecated. Use |
int |
Gets the flash mode for |
@Nullable Executor |
Gets the default executor for |
int |
Returns the image capture mode. |
@Nullable ResolutionSelector |
Returns the |
@Nullable CameraController.OutputSize |
This method is deprecated. Use |
@NonNull ListenableFuture<Void> |
Gets a |
@Nullable ResolutionSelector |
Returns the |
@Nullable CameraController.OutputSize |
This method is deprecated. Use |
@NonNull LiveData<TapToFocusInfo> |
Returns a |
@NonNull LiveData<Integer> |
This method is deprecated. Use |
@NonNull LiveData<Integer> |
Returns a |
@NonNull DynamicRange |
Gets the |
int |
Gets the mirror mode for video capture. |
@NonNull QualitySelector |
Returns the |
@NonNull Range<Integer> |
Gets the target frame rate in frames per second for video capture. |
@NonNull LiveData<ZoomState> |
|
boolean |
@MainThreadChecks if the given |
boolean |
Checks if |
boolean |
Checks if |
boolean |
Returns whether pinch-to-zoom is enabled. |
boolean |
Returns whether there is an in-progress video recording. |
boolean |
Returns whether tap-to-focus is enabled. |
boolean |
Checks if video capture is enabled. |
void |
@MainThreadSets the |
void |
@MainThreadSets |
void |
@MainThreadEnables or disables use cases. |
void |
@MainThreadSets an analyzer to receive and analyze images. |
void |
Sets the executor that will be used for |
void |
@MainThreadSets the backpressure strategy to apply to the image producer to deal with scenarios where images may be produced faster than they can be analyzed. |
void |
@MainThreadSets the image queue depth of |
void |
@MainThreadSets the output image format for |
void |
@MainThreadSets the |
void |
This method is deprecated. Use |
void |
@MainThreadSets the flash mode for |
void |
@MainThreadSets the default executor that will be used for |
void |
@MainThreadSets the image capture mode. |
void |
@MainThreadSets the |
void |
This method is deprecated. Use |
@NonNull ListenableFuture<Void> |
@MainThreadSets current zoom by a linear zoom value ranging from 0f to 1.0f. |
void |
@MainThreadEnables/disables pinch-to-zoom. |
void |
@MainThreadSets the |
void |
This method is deprecated. Use |
void |
@MainThreadSets the auto-cancel duration for tap-to-focus events. |
void |
@MainThreadEnables/disables tap-to-focus. |
void |
@MainThreadSets the |
void |
@MainThreadSets the mirror mode for video capture. |
void |
@MainThreadSets the |
void |
@MainThreadSets the target frame rate range in frames per second for video capture. |
@NonNull ListenableFuture<Void> |
@MainThreadSets current zoom by ratio. |
@NonNull Recording |
@RequiresApi(value = 26)Takes a video to a given file descriptor. |
@NonNull Recording |
@MainThreadTakes a video to a given file. |
@NonNull Recording |
@MainThreadTakes a video to MediaStore. |
void |
@MainThreadCaptures a new still image for in memory access. |
void |
@MainThreadCaptures a new still image and saves to a file along with application specified metadata. |
Constants
public static final int COORDINATE_SYSTEM_VIEW_REFERENCED = 1
ImageAnalysis.Analyzer option for returning PreviewView coordinates.
When the ImageAnalysis.Analyzer is configured with this option, it will receive a Matrix that will receive a value that represents the transformation from camera sensor to the PreviewView, which can be used for highlighting detected result in PreviewView. For example, laying over a bounding box on top of the detected face.
Note this option only works if the ImageAnalysis.Analyzer is set via setImageAnalysisAnalyzer. It will not be effective when used with camera-core directly.
| See also | |
|---|---|
ImageAnalysis.Analyzer |
IMAGE_ANALYSIS
public static final int IMAGE_ANALYSIS = 2
Bitmask option to enable ImageAnalysis. In setEnabledUseCases, if (enabledUseCases & IMAGE_ANALYSIS) != 0, then controller will enable image analysis features.
IMAGE_CAPTURE
public static final int IMAGE_CAPTURE = 1
Bitmask option to enable ImageCapture. In setEnabledUseCases, if (enabledUseCases & IMAGE_CAPTURE) != 0, then controller will enable image capture features.
TAP_TO_FOCUS_FAILED
public static final int TAP_TO_FOCUS_FAILED = 4
The previous tap-to-focus action was failed to complete. This is usually due to device limitations.
TAP_TO_FOCUS_FOCUSED
public static final int TAP_TO_FOCUS_FOCUSED = 2
The previous tap-to-focus action was completed successfully and the camera is focused.
TAP_TO_FOCUS_NOT_FOCUSED
public static final int TAP_TO_FOCUS_NOT_FOCUSED = 3
The previous tap-to-focus action was completed successfully but the camera is still unfocused, similar to the CONTROL_AF_STATE_NOT_FOCUSED_LOCKED state. The end user might be able to get a better result by trying again with different camera distances and/or lighting.
TAP_TO_FOCUS_NOT_STARTED
public static final int TAP_TO_FOCUS_NOT_STARTED = 0
No tap-to-focus action has been started by the end user.
TAP_TO_FOCUS_STARTED
public static final int TAP_TO_FOCUS_STARTED = 1
A tap-to-focus action has started but not completed. The app also gets notified with this state if a new action happens before the previous one could finish.
VIDEO_CAPTURE
public static final int VIDEO_CAPTURE = 4
Bitmask option to enable video capture use case. In setEnabledUseCases, if (enabledUseCases & VIDEO_CAPTURE) != 0, then controller will enable video capture features.
Public methods
clearEffects
@MainThread
public void clearEffects()
Removes all effects.
Once called, CameraX will remove all the effects and rebind the UseCase.
clearImageAnalysisAnalyzer
@MainThread
public void clearImageAnalysisAnalyzer()
Removes a previously set analyzer.
This will stop data from streaming to the ImageAnalysis.
If the current getDefaultTargetResolution returns non-null value, calling this method will reconfigure the camera which might cause additional latency. To avoid this, call this method when the lifecycle is not active.
| See also | |
|---|---|
clearAnalyzer |
enableTorch
@MainThread
public @NonNull ListenableFuture<Void> enableTorch(boolean torchEnabled)
Enable the torch or disable the torch.
If the value is set before the camera is ready, CameraController waits for the camera to be ready and then enables the torch.
| Parameters | |
|---|---|
boolean torchEnabled |
|
| Returns | |
|---|---|
@NonNull ListenableFuture<Void> |
A |
| See also | |
|---|---|
enableTorch |
getCameraControl
@MainThread
public @Nullable CameraControl getCameraControl()
Gets the CameraControl of the currently attached camera.
For controls available directly through CameraController as well as CameraControl, it's recommended to use the ones with CameraController, e.g. setLinearZoom v.s. setLinearZoom. CameraControl is a lower-layer API and may require more steps to achieve the same effect, and will not maintain control values when switching between cameras.
| Returns | |
|---|---|
@Nullable CameraControl |
The |
| See also | |
|---|---|
getCameraControl |
getCameraInfo
@MainThread
public @Nullable CameraInfo getCameraInfo()
Gets the CameraInfo of the currently attached camera.
For info available directly through CameraController as well as CameraInfo, it's recommended to use the ones with CameraController, e.g. getTorchState v.s. getTorchState. CameraInfo is a lower-layer API and may require more steps to achieve the same effect, and will not maintain values when switching between cameras.
| Returns | |
|---|---|
@Nullable CameraInfo |
The |
| See also | |
|---|---|
getCameraInfo |
getCameraSelector
@MainThread
public @NonNull CameraSelector getCameraSelector()
Gets the CameraSelector.
The default value isDEFAULT_BACK_CAMERA.
| See also | |
|---|---|
CameraSelector |
getImageAnalysisBackgroundExecutor
@MainThread
public @Nullable Executor getImageAnalysisBackgroundExecutor()
Gets the default executor for ImageAnalysis background tasks.
| See also | |
|---|---|
setBackgroundExecutor |
getImageAnalysisBackpressureStrategy
@MainThread
public int getImageAnalysisBackpressureStrategy()
Returns the mode with which images are acquired.
If not set, it defaults to STRATEGY_KEEP_ONLY_LATEST.
| Returns | |
|---|---|
int |
The backpressure strategy applied to the image producer. |
| See also | |
|---|---|
getBackpressureStrategy |
getImageAnalysisImageQueueDepth
@MainThread
public int getImageAnalysisImageQueueDepth()
Gets the image queue depth of ImageAnalysis.
| See also | |
|---|---|
getImageQueueDepth |
getImageAnalysisOutputImageFormat
@MainThread
public int getImageAnalysisOutputImageFormat()
Gets the output image format for ImageAnalysis.
The returned image format can be either OUTPUT_IMAGE_FORMAT_YUV_420_888, OUTPUT_IMAGE_FORMAT_RGBA_8888 or OUTPUT_IMAGE_FORMAT_NV21.
getImageAnalysisResolutionSelector
@MainThread
public @Nullable ResolutionSelector getImageAnalysisResolutionSelector()
Returns the ResolutionSelector for ImageAnalysis.
This method returns the value set by setImageAnalysisResolutionSelector. It returns null if the value has not been set.
@MainThread
public @Nullable CameraController.OutputSizegetImageAnalysisTargetSize()
Returns the intended output size for ImageAnalysis set by setImageAnalysisTargetSize, or null if not set.
getImageCaptureFlashMode
@MainThread
public int getImageCaptureFlashMode()
Gets the flash mode for ImageCapture.
| Returns | |
|---|---|
int |
the flashMode. Value is |
| See also | |
|---|---|
ImageCapture |
getImageCaptureIoExecutor
@MainThread
public @Nullable Executor getImageCaptureIoExecutor()
Gets the default executor for ImageCapture IO tasks.
getImageCaptureMode
@MainThread
public int getImageCaptureMode()
Returns the image capture mode.
| See also | |
|---|---|
getCaptureMode |
getImageCaptureResolutionSelector
@MainThread
public @Nullable ResolutionSelector getImageCaptureResolutionSelector()
Returns the ResolutionSelector for ImageCapture.
This method returns the value set by setImageCaptureResolutionSelector (ResolutionSelector)}. It returns null if the value has not been set.
@MainThread
public @Nullable CameraController.OutputSizegetImageCaptureTargetSize()
Returns the intended output size for ImageCapture set by setImageCaptureTargetSize, or null if not set.
getInitializationFuture
public @NonNull ListenableFuture<Void> getInitializationFuture()
Gets a ListenableFuture that completes when camera initialization completes.
This future may fail with an InitializationException and associated cause that can be retrieved by getCause. The cause will be a CameraUnavailableException if it fails to access any camera during initialization.
In the rare case that the future fails with CameraUnavailableException, the camera will become unusable. This could happen for various reasons, for example hardware failure or the camera being held by another process. If the failure is temporary, killing and restarting the app might fix the issue.
The initialization also try to bind use cases before completing the ListenableFuture. The ListenableFuture will complete successfully regardless of whether the use cases are ready to be bound, e.g. it will complete successfully even if the controller is not set on a PreviewView. However the ListenableFuture will fail if the enabled use cases are not supported by the current camera.
| See also | |
|---|---|
getInstance |
getPreviewResolutionSelector
@MainThread
public @Nullable ResolutionSelector getPreviewResolutionSelector()
Returns the ResolutionSelector for Preview.
This method returns the value set by setPreviewResolutionSelector. It returns null if the value has not been set.
@MainThread
public @Nullable CameraController.OutputSizegetPreviewTargetSize()
Returns the intended output size for Preview set by setPreviewTargetSize, or null if not set.
getTapToFocusInfoState
@MainThread
public @NonNull LiveData<TapToFocusInfo> getTapToFocusInfoState()
Returns a LiveData with a TapToFocusInfo containing the latest focus state and corresponding tap position.
When tap-to-focus feature is enabled, the LiveData will receive updates of focusing states. This usually happens when the end user taps on PreviewView, and then again when focusing is finished either successfully or unsuccessfully. The following table displays the states the LiveData can be in, and the possible transitions between them.
| State | Transition cause | New State |
|---|---|---|
| TAP_TO_FOCUS_NOT_STARTED | User taps on PreviewView |
TAP_TO_FOCUS_STARTED |
| TAP_TO_FOCUS_FOCUSED | User taps on PreviewView |
TAP_TO_FOCUS_STARTED |
| TAP_TO_FOCUS_NOT_FOCUSED | User taps on PreviewView |
TAP_TO_FOCUS_STARTED |
| TAP_TO_FOCUS_FAILED | User taps on PreviewView |
TAP_TO_FOCUS_STARTED |
| TAP_TO_FOCUS_STARTED | Focusing succeeded | TAP_TO_FOCUS_FOCUSED |
| Focusing failed due to lighting and/or camera distance | TAP_TO_FOCUS_NOT_FOCUSED | |
| Focusing failed due to device constraints | TAP_TO_FOCUS_FAILED | |
| TAP_TO_FOCUS_FOCUSED | Auto-cancel duration elapses | TAP_TO_FOCUS_NOT_STARTED |
| TAP_TO_FOCUS_NOT_FOCUSED | Auto-cancel duration elapses | TAP_TO_FOCUS_NOT_STARTED |
| TAP_TO_FOCUS_FAILED | Auto-cancel duration elapses | TAP_TO_FOCUS_NOT_STARTED |
@MainThread
public @NonNull LiveData<Integer>getTapToFocusState()
Returns a LiveData with the latest tap-to-focus state.
When tap-to-focus feature is enabled, the LiveData will receive updates of focusing states. This happens when the end user taps on PreviewView, and then again when focusing is finished either successfully or unsuccessfully. The following table displays the states the LiveData can be in, and the possible transitions between them.
| State | Transition cause | New State |
|---|---|---|
| TAP_TO_FOCUS_NOT_STARTED | User taps on PreviewView |
TAP_TO_FOCUS_STARTED |
| TAP_TO_FOCUS_FOCUSED | User taps on PreviewView |
TAP_TO_FOCUS_STARTED |
| TAP_TO_FOCUS_NOT_FOCUSED | User taps on PreviewView |
TAP_TO_FOCUS_STARTED |
| TAP_TO_FOCUS_FAILED | User taps on PreviewView |
TAP_TO_FOCUS_STARTED |
| TAP_TO_FOCUS_STARTED | Focusing succeeded | TAP_TO_FOCUS_FOCUSED |
| Focusing failed due to lighting and/or camera distance | TAP_TO_FOCUS_NOT_FOCUSED | |
| Focusing failed due to device constraints | TAP_TO_FOCUS_FAILED | |
| TAP_TO_FOCUS_FOCUSED | Auto-cancel duration elapses | TAP_TO_FOCUS_NOT_STARTED |
| TAP_TO_FOCUS_NOT_FOCUSED | Auto-cancel duration elapses | TAP_TO_FOCUS_NOT_STARTED |
| TAP_TO_FOCUS_FAILED | Auto-cancel duration elapses | TAP_TO_FOCUS_NOT_STARTED |
getTorchState
@MainThread
public @NonNull LiveData<Integer> getTorchState()
Returns a LiveData of current TorchState.
The torch can be turned on and off via enableTorch which will trigger the change event to the returned LiveData.
| See also | |
|---|---|
getTorchState |
getVideoCaptureDynamicRange
@MainThread
public @NonNull DynamicRange getVideoCaptureDynamicRange()
Gets the DynamicRange for video capture.
getVideoCaptureMirrorMode
@MainThread
public int getVideoCaptureMirrorMode()
Gets the mirror mode for video capture.
getVideoCaptureQualitySelector
@MainThread
public @NonNull QualitySelector getVideoCaptureQualitySelector()
Returns the QualitySelector for VIDEO_CAPTURE.
| Returns | |
|---|---|
@NonNull QualitySelector |
the |
getVideoCaptureTargetFrameRate
@MainThread
public @NonNull Range<Integer> getVideoCaptureTargetFrameRate()
Gets the target frame rate in frames per second for video capture.
getZoomState
@MainThread
public @NonNull LiveData<ZoomState> getZoomState()
Returns a LiveData of ZoomState.
The LiveData will be updated whenever the set zoom state has been changed. This can occur when the application updates the zoom via setZoomRatio or setLinearZoom. The zoom state can also change anytime a camera starts up, for example when setCameraSelector is called.
| See also | |
|---|---|
getZoomState |
hasCamera
@MainThread
public boolean hasCamera(@NonNull CameraSelector cameraSelector)
Checks if the given CameraSelector can be resolved to a camera.
Use this method to check if the device has the given camera.
Only call this method after camera is initialized. e.g. after the ListenableFuture from getInitializationFuture is finished. Calling it prematurely throws IllegalStateException. Example:
controller.getInitializationFuture().addListener(() -> { if (controller.hasCamera(cameraSelector)) { controller.setCameraSelector(cameraSelector); } else { // Update UI if the camera is not available. } // Attach PreviewView after we know the camera is available. previewView.setController(controller); }, ContextCompat.getMainExecutor(requireContext()));
| Returns | |
|---|---|
boolean |
|
| Throws | |
|---|---|
java.lang.IllegalStateException |
if the camera is not initialized. |
isImageAnalysisEnabled
@MainThread
public boolean isImageAnalysisEnabled()
Checks if ImageAnalysis is enabled.
| See also | |
|---|---|
ImageAnalysis |
isImageCaptureEnabled
@MainThread
public boolean isImageCaptureEnabled()
Checks if ImageCapture is enabled.
ImageCapture is enabled by default. It has to be enabled before takePicture can be called.
| See also | |
|---|---|
ImageCapture |
isPinchToZoomEnabled
@MainThread
public boolean isPinchToZoomEnabled()
Returns whether pinch-to-zoom is enabled.
By default pinch-to-zoom is enabled.
| Returns | |
|---|---|
boolean |
|
isRecording
@MainThread
public boolean isRecording()
Returns whether there is an in-progress video recording.
isTapToFocusEnabled
@MainThread
public boolean isTapToFocusEnabled()
Returns whether tap-to-focus is enabled.
By default tap-to-focus is enabled.
| Returns | |
|---|---|
boolean |
|
isVideoCaptureEnabled
@MainThread
public boolean isVideoCaptureEnabled()
Checks if video capture is enabled.
Video capture is disabled by default. It has to be enabled before startRecording can be called.
setCameraSelector
@MainThread
public void setCameraSelector(@NonNull CameraSelector cameraSelector)
Sets the CameraSelector.
Calling this method with a CameraSelector that resolves to a different camera will change the camera being used by the controller. If camera initialization is complete, the controller will immediately rebind use cases with the new CameraSelector; otherwise, the new CameraSelector will be used when the camera becomes ready.
The default value is DEFAULT_BACK_CAMERA.
| Throws | |
|---|---|
java.lang.IllegalStateException |
If the provided camera selector is unable to resolve a camera to be used for the enabled use cases. |
| See also | |
|---|---|
CameraSelector |
setEffects
@MainThread
public void setEffects(@NonNull Set<CameraEffect> effects)
Sets CameraEffect.
Call this method to set a list of active effects. There is maximum one effect per UseCase. Adding effects with duplicate or invalid targets throws IllegalArgumentException. Once called, CameraX will rebind the UseCase with the effects applied. Effects not in the list are automatically removed.
The method throws IllegalArgumentException if the effects combination is not supported by CameraX. Please see the Javadoc of addEffect to see the supported effects combinations.
| Parameters | |
|---|---|
@NonNull Set<CameraEffect> effects |
The effects applied to camera output. |
| Throws | |
|---|---|
java.lang.IllegalArgumentException |
if the combination of effects is not supported by CameraX. |
| See also | |
|---|---|
addEffect |
setEnabledUseCases
@MainThread
public void setEnabledUseCases(int enabledUseCases)
Enables or disables use cases.
Use cases need to be enabled before they can be used. By default, IMAGE_CAPTURE and IMAGE_ANALYSIS are enabled, and VIDEO_CAPTURE is disabled. This is necessary because VIDEO_CAPTURE may affect the available resolutions for other use cases, especially on lower end devices.
To make sure getting the maximum resolution, only enable VIDEO_CAPTURE when shooting video. For example:
// By default, image capture is enabled. Taking picture works. controller.takePicture(...); // Switch to video capture to shoot video. controller.setEnabledUseCases(VIDEO_CAPTURE); controller.startRecording(...); // Switch back to image capture and image analysis before taking another picture. controller.setEnabledUseCases(IMAGE_CAPTURE|IMAGE_ANALYSIS); controller.takePicture(...);
| Parameters | |
|---|---|
int enabledUseCases |
one or more of the following use cases, bitwise-OR-ed together: |
| Throws | |
|---|---|
java.lang.IllegalStateException |
If the current camera selector is unable to resolve a camera to be used for the enabled use cases. |
| See also | |
|---|---|
UseCase |
|
ImageCapture |
|
ImageAnalysis |
setImageAnalysisAnalyzer
@MainThread
public void setImageAnalysisAnalyzer(
@NonNull Executor executor,
@NonNull ImageAnalysis.Analyzer analyzer
)
Sets an analyzer to receive and analyze images.
Applications can process or copy the image by implementing the ImageAnalysis.Analyzer. The image needs to be closed by calling close when the analyzing is done.
Setting an analyzer function replaces any previous analyzer. Only one analyzer can be set at any time.
If the getTargetCoordinateSystem returns COORDINATE_SYSTEM_VIEW_REFERENCED, the analyzer will receive a transformation via updateTransform that converts coordinates from the ImageAnalysis's coordinate system to the PreviewView's coordinate system.
If the getDefaultTargetResolution returns a non-null value, calling this method will reconfigure the camera which might cause additional latency. To avoid this, set the value before controller is bound to the lifecycle.
| Parameters | |
|---|---|
@NonNull Executor executor |
The executor in which the |
@NonNull ImageAnalysis.Analyzer analyzer |
of the images. |
| See also | |
|---|---|
setAnalyzer |
setImageAnalysisBackgroundExecutor
@MainThread
public void setImageAnalysisBackgroundExecutor(@Nullable Executor executor)
Sets the executor that will be used for ImageAnalysis background tasks.
If not set, the background executor will default to an automatically generated Executor.
Changing the value will reconfigure the camera, which will cause additional latency. To avoid this, set the value before controller is bound to lifecycle.
| Parameters | |
|---|---|
@Nullable Executor executor |
The executor for |
| See also | |
|---|---|
setBackgroundExecutor |
setImageAnalysisBackpressureStrategy
@MainThread
public void setImageAnalysisBackpressureStrategy(int strategy)
Sets the backpressure strategy to apply to the image producer to deal with scenarios where images may be produced faster than they can be analyzed.
The available values are STRATEGY_BLOCK_PRODUCER and STRATEGY_KEEP_ONLY_LATEST. If not set, the backpressure strategy will default to STRATEGY_KEEP_ONLY_LATEST.
Changing the value will reconfigure the camera which will cause additional latency. To avoid this, set the value before controller is bound to lifecycle.
| Parameters | |
|---|---|
int strategy |
The strategy to use. |
| See also | |
|---|---|
setBackpressureStrategy |
setImageAnalysisImageQueueDepth
@MainThread
public void setImageAnalysisImageQueueDepth(int depth)
Sets the image queue depth of ImageAnalysis.
This sets the number of images available in parallel to ImageAnalysis.Analyzer. The value is only used if the backpressure strategy is STRATEGY_BLOCK_PRODUCER.
Changing the value will reconfigure the camera which will cause additional latency. To avoid this, set the value before controller is bound to lifecycle.
| Parameters | |
|---|---|
int depth |
The total number of images available. |
| See also | |
|---|---|
setImageQueueDepth |
setImageAnalysisOutputImageFormat
@MainThread
public void setImageAnalysisOutputImageFormat(int imageAnalysisOutputImageFormat)
Sets the output image format for ImageAnalysis.
The supported output image format are OUTPUT_IMAGE_FORMAT_YUV_420_888 and OUTPUT_IMAGE_FORMAT_RGBA_8888.
If not set, OUTPUT_IMAGE_FORMAT_YUV_420_888 will be used.
Requesting OUTPUT_IMAGE_FORMAT_RGBA_8888 or OUTPUT_IMAGE_FORMAT_NV21 causes extra overhead because format conversion takes time.
Changing the value will reconfigure the camera, which may cause additional latency. To avoid this, set the value before controller is bound to lifecycle. If the value is changed when the camera is active, check the getFormat value to determine when the new format takes effect.
setImageAnalysisResolutionSelector
@MainThread
public void setImageAnalysisResolutionSelector(
@Nullable ResolutionSelector resolutionSelector
)
Sets the ResolutionSelector for ImageAnalysis.
CameraX uses this value as a hint to select the resolution for images. The actual output may differ from the requested value due to device constraints. When set to null, CameraX will use the default config of ImageAnalysis. ImageAnalysis has a default ResolutionStrategy with bound size as 640x480 and fallback rule of FALLBACK_RULE_CLOSEST_HIGHER_THEN_LOWER.
Changing the value will reconfigure the camera which will cause additional latency. To avoid this, set the value before controller is bound to lifecycle.
| See also | |
|---|---|
setResolutionSelector |
@MainThread
public voidsetImageAnalysisTargetSize(
@Nullable CameraController.OutputSize targetSize
)
Sets the intended output size for ImageAnalysis.
The value is used as a hint when determining the resolution and aspect ratio of the output buffer. The actual output may differ from the requested value due to device constraints.
When set to null, the output will be based on the default config of ImageAnalysis.
Changing the value will reconfigure the camera which will cause additional latency. To avoid this, set the value before controller is bound to lifecycle.
| Parameters | |
|---|---|
@Nullable CameraController.OutputSize targetSize |
The intended output size for |
| See also | |
|---|---|
setTargetAspectRatio |
|
setTargetResolution |
setImageCaptureFlashMode
@MainThread
public void setImageCaptureFlashMode(int flashMode)
Sets the flash mode for ImageCapture.
If not set, the flash mode will default to FLASH_MODE_OFF.
If FLASH_MODE_SCREEN is set, a valid android.view.Window instance must be set to a PreviewView or ScreenFlashView which this controller is set to. Trying to use FLASH_MODE_SCREEN with a non-front camera or without setting a non-null window will throw an exception. While switching the camera, it is the application's responsibility to change flash mode to the desired one if it leads to a no-op case (e.g. switching to rear camera while FLASH_MODE_SCREEN is still set). Otherwise, FLASH_MODE_OFF will be set.
| Parameters | |
|---|---|
int flashMode |
the flash mode for |
| Throws | |
|---|---|
java.lang.IllegalArgumentException |
If flash mode is invalid or |
| See also | |
|---|---|
setScreenFlashWindow |
|
setScreenFlashWindow |
setImageCaptureIoExecutor
@MainThread
public void setImageCaptureIoExecutor(@Nullable Executor executor)
Sets the default executor that will be used for ImageCapture IO tasks.
This executor will be used for any IO tasks specifically for ImageCapture, such as takePicture. If no executor is set, then a default Executor specifically for IO will be used instead.
Changing the value will reconfigure the camera which will cause additional latency. To avoid this, set the value before controller is bound to lifecycle.
setImageCaptureMode
@MainThread
public void setImageCaptureMode(int captureMode)
Sets the image capture mode.
Valid capture modes are CAPTURE_MODE_MINIMIZE_LATENCY, which prioritizes latency over image quality, or CAPTURE_MODE_MAXIMIZE_QUALITY, which prioritizes image quality over latency.
Changing the value will reconfigure the camera which will cause additional latency. To avoid this, set the value before controller is bound to lifecycle.
| Parameters | |
|---|---|
int captureMode |
The requested image capture mode. |
setImageCaptureResolutionSelector
@MainThread
public void setImageCaptureResolutionSelector(
@Nullable ResolutionSelector resolutionSelector
)
Sets the ResolutionSelector for ImageCapture.
CameraX uses this value as a hint to select the resolution for captured images. The actual output may differ from the requested value due to device constraints. When set to null, CameraX will use the default config of ImageCapture. The default resolution strategy for ImageCapture is HIGHEST_AVAILABLE_STRATEGY, which will select the largest available resolution to use.
Changing the value will reconfigure the camera which will cause additional latency. To avoid this, set the value before controller is bound to lifecycle.
| See also | |
|---|---|
setResolutionSelector |
@MainThread
public voidsetImageCaptureTargetSize(
@Nullable CameraController.OutputSize targetSize
)
Sets the intended image size for ImageCapture.
The value is used as a hint when determining the resolution and aspect ratio of the captured image. The actual output may differ from the requested value due to device constraints.
When set to null, the output will be based on the default config of ImageCapture.
Changing the value will reconfigure the camera which will cause additional latency. To avoid this, set the value before controller is bound to lifecycle.
| Parameters | |
|---|---|
@Nullable CameraController.OutputSize targetSize |
The intended image size for |
setLinearZoom
@MainThread
public @NonNull ListenableFuture<Void> setLinearZoom(@FloatRange(from = 0.0, to = 1.0) float linearZoom)
Sets current zoom by a linear zoom value ranging from 0f to 1.0f.
LinearZoom 0f represents the minimum zoom while linearZoom 1.0f represents the maximum zoom. The advantage of linearZoom is that it ensures the field of view (FOV) varies linearly with the linearZoom value, for use with slider UI elements (while setZoomRatio works well for pinch-zoom gestures).
If the value is set before the camera is ready, CameraController waits for the camera to be ready and then sets the linear zoom.
| Returns | |
|---|---|
@NonNull ListenableFuture<Void> |
A |
| See also | |
|---|---|
setLinearZoom |
setPinchToZoomEnabled
@MainThread
public void setPinchToZoomEnabled(boolean enabled)
Enables/disables pinch-to-zoom.
Once enabled, end user can pinch on the PreviewView to zoom in/out if the bound camera supports zooming.
| Parameters | |
|---|---|
boolean enabled |
|
setPreviewResolutionSelector
@MainThread
public void setPreviewResolutionSelector(
@Nullable ResolutionSelector resolutionSelector
)
Sets the ResolutionSelector for Preview.
CameraX uses this value as a hint to select the resolution for preview. The actual output may differ from the requested value due to device constraints. When set to null, CameraX will use the default config of Preview. By default, the selected resolution will be limited by the PREVIEW size which is defined as the best size match to the device's screen resolution, or to 1080p (1920x1080), whichever is smaller.
Changing the value will reconfigure the camera which will cause additional latency. To avoid this, set the value before controller is bound to lifecycle.
| See also | |
|---|---|
setResolutionSelector |
@MainThread
public voidsetPreviewTargetSize(@Nullable CameraController.OutputSize targetSize)
Sets the intended output size for Preview.
The value is used as a hint when determining the resolution and aspect ratio of the preview. The actual output may differ from the requested value due to device constraints.
When set to null, the output will be based on the default config of Preview.
Changing the value will reconfigure the camera which will cause additional latency. To avoid this, set the value before controller is bound to lifecycle.
| Parameters | |
|---|---|
@Nullable CameraController.OutputSize targetSize |
the intended output size for |
| See also | |
|---|---|
setTargetAspectRatio |
|
setTargetResolution |
setTapToFocusAutoCancelDuration
@MainThread
public void setTapToFocusAutoCancelDuration(
@IntRange(from = 0) long duration,
@NonNull TimeUnit timeUnit
)
Sets the auto-cancel duration for tap-to-focus events.
By default, CameraX uses a value of 5 seconds.
| Parameters | |
|---|---|
@IntRange(from = 0) long duration |
The duration after which CameraX automatically cancels a tap-to-focus event. A value of 0 will disable the auto-cancellation behavior. |
@NonNull TimeUnit timeUnit |
The |
| See also | |
|---|---|
getTapToFocusInfoState |
setTapToFocusEnabled
@MainThread
public void setTapToFocusEnabled(boolean enabled)
Enables/disables tap-to-focus.
Once enabled, end user can tap on the PreviewView to set focus point.
| Parameters | |
|---|---|
boolean enabled |
|
setVideoCaptureDynamicRange
@MainThread
public void setVideoCaptureDynamicRange(@NonNull DynamicRange dynamicRange)
Sets the DynamicRange for video capture.
The dynamic range specifies how the range of colors, highlights and shadows that are captured by the video producer are displayed on a display. Some dynamic ranges will allow the video to make full use of the extended range of brightness of a display when the video is played back.
The supported dynamic ranges for video capture can be queried through the androidx.camera.video.VideoCapabilities returned by getVideoCapabilities via getSupportedDynamicRanges.
It is possible to choose a high dynamic range (HDR) with unspecified encoding by providing HDR_UNSPECIFIED_10_BIT.
If the dynamic range is not provided, the default value is SDR.
| See also | |
|---|---|
setDynamicRange |
setVideoCaptureMirrorMode
@MainThread
public void setVideoCaptureMirrorMode(int mirrorMode)
Sets the mirror mode for video capture.
Valid values include: MIRROR_MODE_OFF, MIRROR_MODE_ON and MIRROR_MODE_ON_FRONT_ONLY. If not set, it defaults to MIRROR_MODE_OFF.
| See also | |
|---|---|
setMirrorMode |
setVideoCaptureQualitySelector
@MainThread
public void setVideoCaptureQualitySelector(@NonNull QualitySelector qualitySelector)
Sets the QualitySelector for VIDEO_CAPTURE.
The provided quality selector is used to select the resolution of the recording depending on the resolutions supported by the camera and codec capabilities.
If no quality selector is provided, the default is DEFAULT_QUALITY_SELECTOR.
Changing the value will reconfigure the camera which will cause video capture to stop. To avoid this, set the value before controller is bound to lifecycle.
| Parameters | |
|---|---|
@NonNull QualitySelector qualitySelector |
The quality selector for |
| See also | |
|---|---|
QualitySelector |
setVideoCaptureTargetFrameRate
@MainThread
public void setVideoCaptureTargetFrameRate(@NonNull Range<Integer> targetFrameRate)
Sets the target frame rate range in frames per second for video capture.
This target will be used as a part of the heuristics for the algorithm that determines the final frame rate range and resolution of all concurrently bound use cases.
It is not guaranteed that this target frame rate will be the final range, as other use cases as well as frame rate restrictions of the device may affect the outcome of the algorithm that chooses the actual frame rate.
By default, the value is FRAME_RATE_RANGE_UNSPECIFIED. For supported frame rates, see getSupportedFrameRateRanges.
| See also | |
|---|---|
setTargetFrameRate |
setZoomRatio
@MainThread
public @NonNull ListenableFuture<Void> setZoomRatio(float zoomRatio)
Sets current zoom by ratio.
Valid zoom values range from getMinZoomRatio to getMaxZoomRatio.
If the value is set before the camera is ready, CameraController waits for the camera to be ready and then sets the zoom ratio.
| Parameters | |
|---|---|
float zoomRatio |
The requested zoom ratio. |
| Returns | |
|---|---|
@NonNull ListenableFuture<Void> |
A |
| See also | |
|---|---|
getZoomState |
|
setZoomRatio |
startRecording
@RequiresApi(value = 26)
@MainThread
public @NonNull Recording startRecording(
@NonNull FileDescriptorOutputOptions outputOptions,
@NonNull AudioConfig audioConfig,
@NonNull Executor executor,
@NonNull Consumer<VideoRecordEvent> listener
)
Takes a video to a given file descriptor.
Currently, file descriptors as output destinations are not supported on pre-Android O (API 26) devices.
Only a single recording can be active at a time, so if isRecording is true, this will throw an IllegalStateException.
Upon successfully starting the recording, a VideoRecordEvent.Start event will be the first event sent to the provided event listener.
If errors occur while starting the recording, a VideoRecordEvent.Finalize event will be the first event sent to the provided listener, and information about the error can be found in that event's getError method.
Recording with audio requires the RECORD_AUDIO permission; without it, starting a recording will fail with a SecurityException.
| Parameters | |
|---|---|
@NonNull FileDescriptorOutputOptions outputOptions |
The options to store the newly captured video. |
@NonNull AudioConfig audioConfig |
The configuration of audio. |
@NonNull Executor executor |
The executor that the event listener will be run on. |
@NonNull Consumer<VideoRecordEvent> listener |
The event listener to handle video record events. |
| Throws | |
|---|---|
java.lang.IllegalStateException |
if there is an unfinished active recording. |
java.lang.SecurityException |
if the audio config specifies audio should be enabled but the |
startRecording
@MainThread
public @NonNull Recording startRecording(
@NonNull FileOutputOptions outputOptions,
@NonNull AudioConfig audioConfig,
@NonNull Executor executor,
@NonNull Consumer<VideoRecordEvent> listener
)
Takes a video to a given file.
Only a single recording can be active at a time, so if isRecording is true, this will throw an IllegalStateException.
Upon successfully starting the recording, a VideoRecordEvent.Start event will be the first event sent to the provided event listener.
If errors occur while starting the recording, a VideoRecordEvent.Finalize event will be the first event sent to the provided listener, and information about the error can be found in that event's getError method.
Recording with audio requires the RECORD_AUDIO permission; without it, starting a recording will fail with a SecurityException.
| Parameters | |
|---|---|
@NonNull FileOutputOptions outputOptions |
The options to store the newly captured video. |
@NonNull AudioConfig audioConfig |
The configuration of audio. |
@NonNull Executor executor |
The executor that the event listener will be run on. |
@NonNull Consumer<VideoRecordEvent> listener |
The event listener to handle video record events. |
| Throws | |
|---|---|
java.lang.IllegalStateException |
if there is an unfinished active recording. |
java.lang.SecurityException |
if the audio config specifies audio should be enabled but the |
startRecording
@MainThread
public @NonNull Recording startRecording(
@NonNull MediaStoreOutputOptions outputOptions,
@NonNull AudioConfig audioConfig,
@NonNull Executor executor,
@NonNull Consumer<VideoRecordEvent> listener
)
Takes a video to MediaStore.
Only a single recording can be active at a time, so if isRecording is true, this will throw an IllegalStateException.
Upon successfully starting the recording, a VideoRecordEvent.Start event will be the first event sent to the provided event listener.
If errors occur while starting the recording, a VideoRecordEvent.Finalize event will be the first event sent to the provided listener, and information about the error can be found in that event's getError method.
Recording with audio requires the RECORD_AUDIO permission; without it, starting a recording will fail with a SecurityException.
| Parameters | |
|---|---|
@NonNull MediaStoreOutputOptions outputOptions |
The options to store the newly captured video. |
@NonNull AudioConfig audioConfig |
The configuration of audio. |
@NonNull Executor executor |
The executor that the event listener will be run on. |
@NonNull Consumer<VideoRecordEvent> listener |
The event listener to handle video record events. |
| Throws | |
|---|---|
java.lang.IllegalStateException |
if there is an unfinished active recording. |
java.lang.SecurityException |
if the audio config specifies audio should be enabled but the |
takePicture
@MainThread
public void takePicture(
@NonNull Executor executor,
@NonNull ImageCapture.OnImageCapturedCallback callback
)
Captures a new still image for in memory access.
The listener is responsible for calling close on the returned image.
| Parameters | |
|---|---|
@NonNull Executor executor |
The executor in which the callback methods will be run. |
@NonNull ImageCapture.OnImageCapturedCallback callback |
Callback to be invoked for the newly captured image |
| Throws | |
|---|---|
java.lang.IllegalStateException |
If |
| See also | |
|---|---|
takePicture |
takePicture
@MainThread
public void takePicture(
@NonNull ImageCapture.OutputFileOptions outputFileOptions,
@NonNull Executor executor,
@NonNull ImageCapture.OnImageSavedCallback imageSavedCallback
)
Captures a new still image and saves to a file along with application specified metadata.
The callback will be called only once for every invocation of this method.
By default, the saved image is mirrored to match the output of the preview if front camera is used. To override this behavior, the app needs to explicitly set the flag to false using setReversedHorizontal and setMetadata.
The saved image is cropped to match the aspect ratio of the PreviewView. To take a picture with the maximum available resolution, make sure that the PreviewView's aspect ratio matches the max JPEG resolution supported by the camera.
| Parameters | |
|---|---|
@NonNull ImageCapture.OutputFileOptions outputFileOptions |
Options to store the newly captured image. |
@NonNull Executor executor |
The executor in which the callback methods will be run. |
@NonNull ImageCapture.OnImageSavedCallback imageSavedCallback |
Callback to be called for the newly captured image. |
| Throws | |
|---|---|
java.lang.IllegalStateException |
If |
| See also | |
|---|---|
takePicture |