CameraDevice.StateCallback


public static abstract class CameraDevice.StateCallback
extends Object

java.lang.Object
   ↳ android.hardware.camera2.CameraDevice.StateCallback


A callback objects for receiving updates about the state of a camera device.

A callback instance must be provided to the CameraManager.openCamera method to open a camera device.

These state updates include notifications about the device completing startup ( allowing for CameraDevice.createCaptureSession(SessionConfiguration) to be called), about device disconnection or closure, and about unexpected device errors.

Events about the progress of specific CaptureRequests are provided through a CameraCaptureSession.CaptureCallback given to the CameraCaptureSession.capture, CameraCaptureSession.captureBurst, CameraCaptureSession.setRepeatingRequest, or CameraCaptureSession.setRepeatingBurst methods.

Summary

Constants

int ERROR_CAMERA_DEVICE

An error code that can be reported by onError(CameraDevice, int) indicating that the camera device has encountered a fatal error.

int ERROR_CAMERA_DISABLED

An error code that can be reported by onError(CameraDevice, int) indicating that the camera device could not be opened due to a device policy.

int ERROR_CAMERA_IN_USE

An error code that can be reported by onError(CameraDevice, int) indicating that the camera device is in use already.

int ERROR_CAMERA_SERVICE

An error code that can be reported by onError(CameraDevice, int) indicating that the camera service has encountered a fatal error.

int ERROR_MAX_CAMERAS_IN_USE

An error code that can be reported by onError(CameraDevice, int) indicating that the camera device could not be opened because there are too many other open camera devices.

Public constructors

StateCallback()

Public methods

void onClosed(CameraDevice camera)

The method called when a camera device has been closed with CameraDevice.close.

abstract void onDisconnected(CameraDevice camera)

The method called when a camera device is no longer available for use.

abstract void onError(CameraDevice camera, int error)

The method called when a camera device has encountered a serious error.

abstract void onOpened(CameraDevice camera)

The method called when a camera device has finished opening.

Inherited methods

Object clone()

Creates and returns a copy of this object.

boolean equals(Object obj)

Indicates whether some other object is "equal to" this one.

void finalize()

Called by the garbage collector on an object when garbage collection determines that there are no more references to the object.

final Class<?> getClass()

Returns the runtime class of this Object.

int hashCode()

Returns a hash code value for the object.

final void notify()

Wakes up a single thread that is waiting on this object's monitor.

final void notifyAll()

Wakes up all threads that are waiting on this object's monitor.

String toString()

Returns a string representation of the object.

final void wait(long timeoutMillis, int nanos)

Causes the current thread to wait until it is awakened, typically by being notified or interrupted, or until a certain amount of real time has elapsed.

final void wait(long timeoutMillis)

Causes the current thread to wait until it is awakened, typically by being notified or interrupted, or until a certain amount of real time has elapsed.

final void wait()

Causes the current thread to wait until it is awakened, typically by being notified or interrupted.

Constants

ERROR_CAMERA_DEVICE

Added in API level 21
public static final int ERROR_CAMERA_DEVICE

An error code that can be reported by onError(CameraDevice, int) indicating that the camera device has encountered a fatal error.

The camera device needs to be re-opened to be used again.

Constant Value: 4 (0x00000004)

ERROR_CAMERA_DISABLED

Added in API level 21
public static final int ERROR_CAMERA_DISABLED

An error code that can be reported by onError(CameraDevice, int) indicating that the camera device could not be opened due to a device policy.

Constant Value: 3 (0x00000003)

ERROR_CAMERA_IN_USE

Added in API level 21
public static final int ERROR_CAMERA_IN_USE

An error code that can be reported by onError(CameraDevice, int) indicating that the camera device is in use already.

This error can be produced when opening the camera fails due to the camera being used by a higher-priority camera API client.

Constant Value: 1 (0x00000001)

ERROR_CAMERA_SERVICE

Added in API level 21
public static final int ERROR_CAMERA_SERVICE

An error code that can be reported by onError(CameraDevice, int) indicating that the camera service has encountered a fatal error.

The Android device may need to be shut down and restarted to restore camera function, or there may be a persistent hardware problem.

An attempt at recovery may be possible by closing the CameraDevice and the CameraManager, and trying to acquire all resources again from scratch.

Constant Value: 5 (0x00000005)

ERROR_MAX_CAMERAS_IN_USE

Added in API level 21
public static final int ERROR_MAX_CAMERAS_IN_USE

An error code that can be reported by onError(CameraDevice, int) indicating that the camera device could not be opened because there are too many other open camera devices.

The system-wide limit for number of open cameras has been reached, and more camera devices cannot be opened until previous instances are closed.

This error can be produced when opening the camera fails.

Constant Value: 2 (0x00000002)

Public constructors

StateCallback

public StateCallback ()

Public methods

onClosed

Added in API level 21
public void onClosed (CameraDevice camera)

The method called when a camera device has been closed with CameraDevice.close.

Any attempt to call methods on this CameraDevice in the future will throw a IllegalStateException.

The default implementation of this method does nothing.

Parameters
camera CameraDevice: the camera device that has become closed This value cannot be null.

onDisconnected

Added in API level 21
public abstract void onDisconnected (CameraDevice camera)

The method called when a camera device is no longer available for use.

This callback may be called instead of onOpened(CameraDevice) if opening the camera fails.

Any attempt to call methods on this CameraDevice will throw a CameraAccessException. The disconnection could be due to a change in security policy or permissions; the physical disconnection of a removable camera device; or the camera being needed for a higher-priority camera API client.

There may still be capture callbacks that are invoked after this method is called, or new image buffers that are delivered to active outputs.

The default implementation logs a notice to the system log about the disconnection.

You should clean up the camera with CameraDevice.close after this happens, as it is not recoverable until the camera can be opened again. For most use cases, this will be when the camera again becomes available.

Parameters
camera CameraDevice: the device that has been disconnected This value cannot be null.

onError

Added in API level 21
public abstract void onError (CameraDevice camera, 
                int error)

The method called when a camera device has encountered a serious error.

This callback may be called instead of onOpened(CameraDevice) if opening the camera fails.

This indicates a failure of the camera device or camera service in some way. Any attempt to call methods on this CameraDevice in the future will throw a CameraAccessException with the CAMERA_ERROR reason.

There may still be capture completion or camera stream callbacks that will be called after this error is received.

You should clean up the camera with CameraDevice.close after this happens. Further attempts at recovery are error-code specific.

Parameters
camera CameraDevice: The device reporting the error This value cannot be null.

error int: The error code. Value is ERROR_CAMERA_IN_USE, ERROR_MAX_CAMERAS_IN_USE, ERROR_CAMERA_DISABLED, ERROR_CAMERA_DEVICE, or ERROR_CAMERA_SERVICE

onOpened

Added in API level 21
public abstract void onOpened (CameraDevice camera)

The method called when a camera device has finished opening.

At this point, the camera device is ready to use, and CameraDevice.createCaptureSession can be called to set up the first capture session.

Parameters
camera CameraDevice: the camera device that has become opened This value cannot be null.

Discover the latest app development tools, platform updates, training, and documentation for developers across every Android device.

Updated Dec 18, 2024