10#include <initializer_list>
31class FrameBufferAllocator;
68 using iterator = std::vector<StreamConfiguration>::iterator;
93 std::size_t
size()
const;
113class Camera final :
public Object,
public std::enable_shared_from_this<Camera>,
119 static std::shared_ptr<Camera>
create(std::unique_ptr<Private> d,
120 const std::string &
id,
121 const std::set<Stream *> &
streams);
123 const std::string &
id()
const;
135 const std::set<Stream *> &
streams()
const;
137 std::unique_ptr<CameraConfiguration>
140 std::unique_ptr<CameraConfiguration>
157 Camera(std::unique_ptr<Private> d,
const std::string &
id,
158 const std::set<Stream *> &
streams);
163 void requestComplete(
Request *request);
166 int exportFrameBuffers(
Stream *stream,
167 std::vector<std::unique_ptr<FrameBuffer>> *buffers);
Utilities to help constructing class interfaces.
#define LIBCAMERA_DECLARE_PRIVATE()
Declare private data for a public class.
#define LIBCAMERA_DISABLE_COPY(klass)
Disable copy construction and assignment of the klass.
Hold configuration for streams of the camera.
Definition: camera.h:60
std::vector< StreamConfiguration >::iterator iterator
Iterator for the stream configurations in the camera configuration.
Definition: camera.h:68
std::vector< StreamConfiguration > config_
The vector of stream configurations.
Definition: camera.h:110
Status validateColorSpaces(ColorSpaceFlags flags=ColorSpaceFlag::None)
Check the color spaces requested for each stream.
Definition: camera.cpp:486
std::optional< SensorConfiguration > sensorConfig
The camera sensor configuration.
Definition: camera.h:95
virtual Status validate()=0
Validate and possibly adjust the camera configuration.
ColorSpaceFlag
Specify the behaviour of validateColorSpaces.
Definition: camera.h:101
@ None
No extra validation of color spaces is required.
@ StreamsShareColorSpace
Non-raw output streams must share the same color space.
StreamConfiguration & at(unsigned int index)
Retrieve a reference to a stream configuration.
Definition: camera.cpp:348
Orientation orientation
The desired orientation of the images produced by the camera.
Definition: camera.h:96
Status
Validity of a camera configuration.
Definition: camera.h:62
@ Valid
Definition: camera.h:63
@ Adjusted
Definition: camera.h:64
@ Invalid
Definition: camera.h:65
const StreamConfiguration & operator[](unsigned int index) const
Retrieve a const reference to a stream configuration.
Definition: camera.h:82
bool empty() const
Check if the camera configuration is empty.
Definition: camera.cpp:437
CameraConfiguration()
Create an empty camera configuration.
Definition: camera.cpp:293
std::size_t size() const
Retrieve the number of stream configurations.
Definition: camera.cpp:446
void addConfiguration(const StreamConfiguration &cfg)
Add a stream configuration to the camera configuration.
Definition: camera.cpp:306
iterator begin()
Retrieve an iterator to the first stream configuration in the sequence.
Definition: camera.cpp:397
iterator end()
Retrieve an iterator pointing to the past-the-end stream configuration in the sequence.
Definition: camera.cpp:417
std::vector< StreamConfiguration >::const_iterator const_iterator
Const iterator for the stream configuration in the camera configuration.
Definition: camera.h:69
StreamConfiguration & operator[](unsigned int index)
Retrieve a reference to a stream configuration.
Definition: camera.h:78
Camera device.
Definition: camera.h:115
const std::set< Stream * > & streams() const
Retrieve all the camera's stream information.
Definition: camera.cpp:1070
const ControlInfoMap & controls() const
Retrieve the list of controls supported by the camera.
Definition: camera.cpp:1041
const std::string & id() const
Retrieve the ID of the camera.
Definition: camera.cpp:872
std::unique_ptr< CameraConfiguration > generateConfiguration(Span< const StreamRole > roles={})
Generate a default camera configuration according to stream roles.
Definition: camera.cpp:1090
static std::shared_ptr< Camera > create(std::unique_ptr< Private > d, const std::string &id, const std::set< Stream * > &streams)
Create a camera instance.
Definition: camera.cpp:831
int configure(CameraConfiguration *config)
Configure the camera prior to capture.
Definition: camera.cpp:1158
int stop()
Stop capture from camera.
Definition: camera.cpp:1370
int acquire()
Acquire the camera device for exclusive access.
Definition: camera.cpp:977
int release()
Release exclusive access to the camera device.
Definition: camera.cpp:1014
int start(const ControlList *controls=nullptr)
Start capture from camera.
Definition: camera.cpp:1333
std::unique_ptr< Request > createRequest(uint64_t cookie=0)
Create a request object for the camera.
Definition: camera.cpp:1230
Signal< Request * > requestCompleted
Signal emitted when a request queued to the camera has completed.
Definition: camera.h:126
std::unique_ptr< CameraConfiguration > generateConfiguration(std::initializer_list< StreamRole > roles)
Definition: camera.h:141
int queueRequest(Request *request)
Queue a request to the camera.
Definition: camera.cpp:1270
const ControlList & properties() const
Retrieve the list of properties of the camera.
Definition: camera.cpp:1054
Signal disconnected
Signal emitted when the camera is disconnected from the system.
Definition: camera.h:127
Signal< Request *, FrameBuffer * > bufferCompleted
Signal emitted when a buffer for a request queued to the camera has completed.
Definition: camera.h:125
A map of ControlId to ControlInfo.
Definition: controls.h:306
Associate a list of ControlId with their values for an object.
Definition: controls.h:350
Base class to manage private data through a d-pointer.
Definition: class.h:62
Type-safe container for enum-based bitfields.
Definition: flags.h:16
FrameBuffer allocator for applications.
Definition: framebuffer_allocator.h:23
Base object to support automatic signal disconnection.
Definition: object.h:25
Create and manage cameras based on a set of media devices.
Definition: pipeline_handler.h:39
Describe a rectangle's position and dimensions.
Definition: geometry.h:243
A frame capture request.
Definition: request.h:31
Camera sensor configuration.
Definition: camera.h:36
unsigned int bitDepth
The sensor image format bit depth.
Definition: camera.h:38
unsigned int binX
Horizontal binning factor.
Definition: camera.h:43
unsigned int binY
Vertical binning factor.
Definition: camera.h:44
Size outputSize
The frame output (visible) size.
Definition: camera.h:54
unsigned int xEvenInc
Horizontal increment for even rows. Default to 1.
Definition: camera.h:49
unsigned int yOddInc
Vertical increment for odd columns. Default to 1.
Definition: camera.h:50
bool isValid() const
Check if the sensor configuration is valid.
Definition: camera.cpp:234
struct libcamera::SensorConfiguration::@0 binning
Sensor binning configuration.
unsigned int yEvenInc
Vertical increment for even columns. Default to 1.
Definition: camera.h:51
struct libcamera::SensorConfiguration::@1 skipping
The sensor skipping configuration.
unsigned int xOddInc
Horizontal increment for odd rows. Default to 1.
Definition: camera.h:48
Rectangle analogCrop
The analog crop rectangle.
Definition: camera.h:40
Generic signal and slot communication mechanism.
Definition: signal.h:39
Describe a two-dimensional size.
Definition: geometry.h:53
Video stream for a camera.
Definition: stream.h:75
Framework to manage controls related to an object.
Data structures related to geometric objects.
Top-level libcamera namespace.
Definition: backtrace.h:17
Orientation
The image orientation in a memory buffer.
Definition: orientation.h:14
Base object to support automatic signal disconnection.
Image orientation definition.
Describes a frame capture request to be processed by a camera.
Signal & slot implementation.
Video stream for a Camera.
Configuration parameters for a stream.
Definition: stream.h:41