CameraProvider


public interface CameraProvider

Known direct subclasses
LifecycleCameraProvider

Provides access to a camera which has its opening and closing controlled by a LifecycleOwner.

ProcessCameraProvider

A singleton which can be used to bind the lifecycle of cameras to any LifecycleOwner within an application's process.


A CameraProvider provides basic access to a set of cameras such as querying for camera existence or information.

A device might have multiple cameras. According to the applications' design, they might need to search for a suitable camera which supports their functions. A CameraProvider allows the applications to check whether any camera exists to fulfill the requirements or to get CameraInfo instances of all cameras to retrieve the camera information.

Summary

Public methods

default void

Adds a listener for changes in camera presence.

abstract @NonNull List<@NonNull CameraInfo>

The CameraInfo instances of the available cameras.

default @NonNull CameraInfo

Returns the CameraInfo instance of the camera resulted from the specified CameraSelector.

abstract boolean
hasCamera(@NonNull CameraSelector cameraSelector)

Checks whether this provider supports at least one camera that meets the requirements from a CameraSelector.

default void

Removes a previously registered camera presence listener.

Public methods

addCameraPresenceListener

Added in 1.6.0-alpha01
default void addCameraPresenceListener(
    @NonNull Executor executor,
    @NonNull CameraPresenceListener listener
)

Adds a listener for changes in camera presence.

The listener will be notified when cameras are added to or removed from the set of devices that can be used by CameraX. This list of "usable" cameras has already been processed by any configured CameraSelector limiters and compatibility filters.

Important Note on Synchronization: To prevent race conditions, this method immediately invokes CameraPresenceListener.onCamerasAdded once on the provided executor with a Set containing all cameras that are currently available. This guarantees that the listener's state is synchronized with the provider's state at the moment of registration.

This listener reports on persistent hardware changes and does not fire for temporary, recoverable errors, such as when a camera is in use by another application.

Parameters
@NonNull Executor executor

The Executor on which the listener's methods will be invoked.

@NonNull CameraPresenceListener listener

The listener to be added.

getAvailableCameraInfos

Added in 1.1.0
abstract @NonNull List<@NonNull CameraInfogetAvailableCameraInfos()

The CameraInfo instances of the available cameras.

While iterating through all the available CameraInfo, if one of them meets some predefined requirements, a CameraSelector that uniquely identifies its camera can be retrieved using CameraInfo.getCameraSelector, which can then be used to bind use cases to that camera.

getCameraInfo

Added in 1.4.0
default @NonNull CameraInfo getCameraInfo(@NonNull CameraSelector cameraSelector)

Returns the CameraInfo instance of the camera resulted from the specified CameraSelector.

The returned CameraInfo corresponds to the camera that will be bound when calling bindToLifecycle with the specified CameraSelector.

Parameters
@NonNull CameraSelector cameraSelector

the CameraSelector to use for selecting the camera to receive information about.

Returns
@NonNull CameraInfo

the corresponding CameraInfo.

Throws
kotlin.IllegalArgumentException

if the given CameraSelector can't result in a valid camera to provide the CameraInfo.

hasCamera

Added in 1.1.0
abstract boolean hasCamera(@NonNull CameraSelector cameraSelector)

Checks whether this provider supports at least one camera that meets the requirements from a CameraSelector.

If this method returns true, then the camera selector can be used to bind use cases and retrieve a Camera instance.

Parameters
@NonNull CameraSelector cameraSelector

the CameraSelector that filters available cameras.

Returns
boolean

true if the device has at least one available camera, otherwise false.

Throws
androidx.camera.core.CameraInfoUnavailableException

if unable to access cameras, perhaps due to insufficient permissions.

removeCameraPresenceListener

Added in 1.6.0-alpha01
default void removeCameraPresenceListener(@NonNull CameraPresenceListener listener)

Removes a previously registered camera presence listener.

Once removed, the listener will no longer receive updates. If the listener was not previously registered, this method is a no-op.

Parameters
@NonNull CameraPresenceListener listener

The same listener instance that was passed to addCameraPresenceListener.