pub struct AndroidCameraFrameEvent {Show 16 fields
pub session_id: Option<u64>,
pub camera_id: Option<u32>,
pub frame_number: Option<i64>,
pub request_id: Option<i64>,
pub request_received_ns: Option<i64>,
pub request_processing_started_ns: Option<i64>,
pub start_of_exposure_ns: Option<i64>,
pub start_of_frame_ns: Option<i64>,
pub responses_all_sent_ns: Option<i64>,
pub capture_result_status: Option<i32>,
pub skipped_sensor_frames: Option<i32>,
pub capture_intent: Option<i32>,
pub num_streams: Option<i32>,
pub node_processing_details: Vec<CameraNodeProcessingDetails>,
pub vendor_data_version: Option<i32>,
pub vendor_data: Option<Bytes>,
}
Expand description
A profiling event corresponding to a single camera frame. This message collects important details and timestamps involved in producing a single camera frame. Next ID: 17
Fields§
§session_id: Option<u64>
Identifier for the CameraCaptureSession this frame originates from. See: https://developer.android.com/reference/android/hardware/camera2/CameraCaptureSession
camera_id: Option<u32>
Identifier for the camera sensor that is the source of this frame. This may be either a physical or logical camera (up to vendor interpretation).
frame_number: Option<i64>
The frame number identifying this frame on this camera.
request_id: Option<i64>
Identifier for the CaptureRequest. See: https://developer.android.com/reference/android/hardware/camera2/CaptureRequest
If multiple cameras are streaming simultaneously, the request_id may be used to identify which frames were captured in service of the same request.
request_received_ns: Option<i64>
The CLOCK_BOOTTIME timestamp at which the camera framework request is received by the camera HAL pipeline. Note that this request may wait for some time before processing actually begins. See also request_processing_started_ns.
request_processing_started_ns: Option<i64>
The CLOCK_BOOTTIME timestamp at which the framework request is accepted for processing by the camera HAL pipeline. This is the time at which the pipeline actually begins to work on the request.
start_of_exposure_ns: Option<i64>
The CLOCK_BOOTTIME timestamp at which the sensor begins its exposure.
start_of_frame_ns: Option<i64>
The CLOCK_BOOTTIME timestamp corresponding to the sensor start of frame event.
responses_all_sent_ns: Option<i64>
The CLOCK_BOOTTIME timestamp at which the camera HAL has sent all responses for the frame.
capture_result_status: Option<i32>
§skipped_sensor_frames: Option<i32>
The number of sensor frames that were skipped between this frame and the previous frame. Under normal operation, this should be zero. Any number greater than zero indicates dropped sensor frames.
capture_intent: Option<i32>
The value of CONTROL_CAPTURE_INTENT. See: https://developer.android.com/reference/android/hardware/camera2/CaptureRequest#CONTROL_CAPTURE_INTENT
num_streams: Option<i32>
The number of streams in the capture request.
node_processing_details: Vec<CameraNodeProcessingDetails>
§vendor_data_version: Option<i32>
These fields capture vendor-specific additions to this proto message. In
practice vendor_data
typically contains a serialized message of the
vendor’s design, and vendor_data_version
is incremented each time there
is a backwards incompatible change made to the message.
vendor_data: Option<Bytes>
Implementations§
Source§impl AndroidCameraFrameEvent
impl AndroidCameraFrameEvent
Sourcepub fn session_id(&self) -> u64
pub fn session_id(&self) -> u64
Returns the value of session_id
, or the default value if session_id
is unset.
Sourcepub fn camera_id(&self) -> u32
pub fn camera_id(&self) -> u32
Returns the value of camera_id
, or the default value if camera_id
is unset.
Sourcepub fn frame_number(&self) -> i64
pub fn frame_number(&self) -> i64
Returns the value of frame_number
, or the default value if frame_number
is unset.
Sourcepub fn request_id(&self) -> i64
pub fn request_id(&self) -> i64
Returns the value of request_id
, or the default value if request_id
is unset.
Sourcepub fn request_received_ns(&self) -> i64
pub fn request_received_ns(&self) -> i64
Returns the value of request_received_ns
, or the default value if request_received_ns
is unset.
Sourcepub fn request_processing_started_ns(&self) -> i64
pub fn request_processing_started_ns(&self) -> i64
Returns the value of request_processing_started_ns
, or the default value if request_processing_started_ns
is unset.
Sourcepub fn start_of_exposure_ns(&self) -> i64
pub fn start_of_exposure_ns(&self) -> i64
Returns the value of start_of_exposure_ns
, or the default value if start_of_exposure_ns
is unset.
Sourcepub fn start_of_frame_ns(&self) -> i64
pub fn start_of_frame_ns(&self) -> i64
Returns the value of start_of_frame_ns
, or the default value if start_of_frame_ns
is unset.
Sourcepub fn responses_all_sent_ns(&self) -> i64
pub fn responses_all_sent_ns(&self) -> i64
Returns the value of responses_all_sent_ns
, or the default value if responses_all_sent_ns
is unset.
Sourcepub fn capture_result_status(&self) -> CaptureResultStatus
pub fn capture_result_status(&self) -> CaptureResultStatus
Returns the enum value of capture_result_status
, or the default if the field is unset or set to an invalid enum value.
Sourcepub fn set_capture_result_status(&mut self, value: CaptureResultStatus)
pub fn set_capture_result_status(&mut self, value: CaptureResultStatus)
Sets capture_result_status
to the provided enum value.
Sourcepub fn skipped_sensor_frames(&self) -> i32
pub fn skipped_sensor_frames(&self) -> i32
Returns the value of skipped_sensor_frames
, or the default value if skipped_sensor_frames
is unset.
Sourcepub fn capture_intent(&self) -> i32
pub fn capture_intent(&self) -> i32
Returns the value of capture_intent
, or the default value if capture_intent
is unset.
Sourcepub fn num_streams(&self) -> i32
pub fn num_streams(&self) -> i32
Returns the value of num_streams
, or the default value if num_streams
is unset.
Sourcepub fn vendor_data_version(&self) -> i32
pub fn vendor_data_version(&self) -> i32
Returns the value of vendor_data_version
, or the default value if vendor_data_version
is unset.
Sourcepub fn vendor_data(&self) -> &[u8] ⓘ
pub fn vendor_data(&self) -> &[u8] ⓘ
Returns the value of vendor_data
, or the default value if vendor_data
is unset.
Trait Implementations§
Source§impl Clone for AndroidCameraFrameEvent
impl Clone for AndroidCameraFrameEvent
Source§fn clone(&self) -> AndroidCameraFrameEvent
fn clone(&self) -> AndroidCameraFrameEvent
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moreSource§impl Debug for AndroidCameraFrameEvent
impl Debug for AndroidCameraFrameEvent
Source§impl Default for AndroidCameraFrameEvent
impl Default for AndroidCameraFrameEvent
Source§impl Message for AndroidCameraFrameEvent
impl Message for AndroidCameraFrameEvent
Source§fn encoded_len(&self) -> usize
fn encoded_len(&self) -> usize
Source§fn encode<B>(&self, buf: &mut B) -> Result<(), EncodeError>
fn encode<B>(&self, buf: &mut B) -> Result<(), EncodeError>
Source§fn encode_to_vec(&self) -> Vec<u8>where
Self: Sized,
fn encode_to_vec(&self) -> Vec<u8>where
Self: Sized,
Source§fn encode_length_delimited<B>(&self, buf: &mut B) -> Result<(), EncodeError>
fn encode_length_delimited<B>(&self, buf: &mut B) -> Result<(), EncodeError>
Source§fn encode_length_delimited_to_vec(&self) -> Vec<u8>where
Self: Sized,
fn encode_length_delimited_to_vec(&self) -> Vec<u8>where
Self: Sized,
Source§fn decode<B>(buf: B) -> Result<Self, DecodeError>
fn decode<B>(buf: B) -> Result<Self, DecodeError>
Source§fn decode_length_delimited<B>(buf: B) -> Result<Self, DecodeError>
fn decode_length_delimited<B>(buf: B) -> Result<Self, DecodeError>
Source§fn merge<B>(&mut self, buf: B) -> Result<(), DecodeError>
fn merge<B>(&mut self, buf: B) -> Result<(), DecodeError>
self
. Read moreSource§fn merge_length_delimited<B>(&mut self, buf: B) -> Result<(), DecodeError>
fn merge_length_delimited<B>(&mut self, buf: B) -> Result<(), DecodeError>
self
.