
VSourceLibCamera C++ library
v2.2.3
Table of contents
- Overview
- Versions
- Library files
- VSourceLibCamera class description
- VSourceLibCamera class declaration
- getVersion method
- openVSource method
- initVSource method
- isVSourceOpen method
- closeVSource method
- getFrame method
- setParam method
- getParam method
- getParams method
- executeCommand method
- decodeAndExecuteCommand method
- encodeSetParamCommand method of VSource interface class
- encodeCommand method of VSource interface class
- decodeCommand method of VSource interface class
- Data structures
- VSourceParams class description
- Build and connect to your project
- Simple example
- Test application
Overview
VSourceLibCamera C++ library provides video capture and video source control functions based on Libcamera API. The library inherits its interface from the open-source VSource interface class. VSource.h file contains data structures: VSourceParams class (contains video source params and provides methods for serialization/deserialization of params), VSourceCommand enum (describes video source action commands) and VSourceParam enum (describes video source params). VSourceLibCamera depends on: Libcamera API, VSource interface class (provides interface for video sources, source code included, Apache 2.0 license) and open-source Logger library (provides methods to write logs, source code included, Apache 2.0 license). The library provides auto-detection of supported resolution, format and FPS. If a particular device doesn’t support the requested pixel format, resolution or FPS, the library will set the most appropriate parameters. The library supports C++17 standard.
Versions
Table 1 - Library versions.
| Version | Release date | What’s new |
|---|---|---|
| 1.0.0 | 12.11.2023 | First version |
| 1.1.0 | 16.11.2023 | - Memory allocation mechanism rebuilt. |
| 1.2.0 | 21.11.2023 | - Code cleaned up. - Changed initialization string format. - Changed initialization procedure. |
| 1.3.0 | 14.12.2023 | - Added FPS control. - Mistakes in description fixed. |
| 2.0.0 | 15.09.2023 | - Changed interface to VSource interface. - Added pixel format control. - Test application rebuilt. - Added examples. - Documentation updated. |
| 2.0.1 | 15.09.2023 | - Fixed re-init. - Stop camera manager before configuration. - Exclude v4l2 style (/dev/video0) source name. |
| 2.1.0 | 27.12.2023 | - Region of interest support added. |
| 2.1.1 | 09.01.2024 | - Documentation updated. |
| 2.1.2 | 25.04.2024 | - Documentation updated. - Submodules updated. |
| 2.1.3 | 20.05.2024 | - Documentation updated. - Submodules updated. |
| 2.2.0 | 10.07.2024 | - CMake updated. - Submodules updated. - Repository structure updated. |
| 2.2.1 | 12.08.2024 | - Camera initialization bug solved for newer versions of Libcamera API. |
| 2.2.2 | 03.04.2025 | - Logger submodule update. |
| 2.2.3 | 28.03.2026 | - Fixed compilation error on x86 platform. - Fixed mistakes in documentation. |
Library files
The library is supplied only by source code. The user is given a set of files in the form of a CMake project (repository). The repository structure is shown below:
CMakeLists.txt -------------------- Main CMake file of the library.
3rdparty -------------------------- Folder with third-party libraries.
CMakeLists.txt ---------------- CMake file to include third-party libraries.
Logger ------------------------ Folder with Logger library source code.
VSource ----------------------- Folder with VSource library source code.
src ------------------------------- Folder with library source code.
Impl -------------------------- Folder with video source implementation files.
VSourceLibCameraImpl.h ---- Main library header file.
VSourceLibCameraImpl.cpp -- C++ implementation file.
CMakeLists.txt ---------------- CMake file of the library.
VSourceLibCamera.h ------------ Main library header file.
VSourceLibCameraVersion.h ----- Header file with library version.
VSourceLibCameraVersion.h.in -- File for CMake to generate version header.
VSourceLibCamera.cpp ---------- C++ implementation file.
test ------------------------------ Folder for test application files.
CMakeLists.txt ---------------- CMake file for test application.
main.cpp ---------------------- Source C++ file of test application.
example --------------------------- Folder for example application.
CMakeLists.txt ---------------- CMake file for example application.
main.cpp ---------------------- Source C++ file of example application.
VSourceLibCamera class description
VSourceLibCamera class declaration
VSourceLibCamera class is declared in VSourceLibCamera.h file. Class declaration:
namespace cr
{
namespace video
{
/// Video source implementation class.
class VSourceLibCameraImpl;
/// Video source class based on libcamera API.
class VSourceLibCamera : public VSource
{
public:
/**
* @brief Class constructor.
*/
VSourceLibCamera();
/// Class destructor.
~VSourceLibCamera();
/// Get string of current library version.
static std::string getVersion();
/// Open video source.
bool openVSource(std::string& initString) override;
/// Init video source.
bool initVSource(VSourceParams& params) override;
/// Get open status.
bool isVSourceOpen() override;
/// Close video source.
void closeVSource() override;
/// Get new video frame.
bool getFrame(Frame& frame, int32_t timeoutMsec = 0) override;
/// Set video source param.
bool setParam(VSourceParam id, float value) override;
/// Get video source param value.
float getParam(VSourceParam id) override;
/// Get video source params structure.
void getParams(VSourceParams& params) override;
/// Execute command.
bool executeCommand(VSourceCommand id) override;
/// Decode and execute command.
bool decodeAndExecuteCommand(uint8_t* data, int size) override;
};
}
}
getVersion method
The getVersion() method returns the string of the current version of VSourceLibCamera class. Method declaration:
static std::string getVersion();
The method can be used without VSourceLibCamera class instance:
cout << "VSourceLibCamera class version: " << VSourceLibCamera::getVersion() << endl;
Console output:
VSourceLibCamera class version: 2.2.3
openVSource method
The openVSource(…) method initializes video source. Video source params (VSourceParams class) will be initialized by default. Instead of the openVSource(…) method, the user can call initVSource(…) method. Method declaration:
bool openVSource(std::string& initString) override;
| Parameter | Value |
|---|---|
| initString | Initialization string. Valid formats: [camera number];[width];[height];[fps];[fourcc] or [camera number];[width];[height];[fps] or [camera number];[width];[height] Initialization string parameters: [camera number] - Camera number for Libcamera API. Default name format: “0”. [width] - Video frame width. Video frame height must be set as well. The library will try to set this value in video capture hardware parameters. If set to 0 the library will detect frame width automatically according to existing video device parameters. [height] - Video frame height. Video frame width must be set as well. The library will try to set this value in video capture hardware parameters. If set to 0 the library will detect frame height automatically according to existing video device parameters. [fps] - FPS. The library will try to set this value in video capture hardware parameters. If set to 0 the library will detect FPS automatically according to existing video device parameters. [fourcc] - Pixel format. Valid values: BGR24, RGB24, GRAY, YUV24, YUYV, UYVY, NV12, NV21, YV12, YU12. If fourcc is not set, the library will choose the appropriate format according to existing video device parameters. |
Returns: TRUE if the video source is open or FALSE if not.
initVSource method
The initVSource(…) method is designed to initialize video source by a set of parameters. Instead of the initVSource(…) method, the user can call openVSource(…). Method declaration:
bool initVSource(VSourceParams& params) override;
| Parameter | Value |
|---|---|
| params | VSourceParams class object. The video source will set parameters according to params structure. If particular parameters are not valid, the library will set them to default. Note: source field of VSourceParams must have value of [camera number] for Libcamera API. |
Returns: TRUE if the video source initialized or FALSE if not.
isVSourceOpen method
The isVSourceOpen() method returns video source initialization status. Initialization status is also included in VSourceParams class. Method declaration:
bool isVSourceOpen() override;
Returns: TRUE if the video source is open (initialized) or FALSE if not.
closeVSource method
The closeVSource() method is intended to close video source. Method declaration:
void closeVSource() override;
getFrame method
The getFrame(…) method is intended to get input video frame. Method declaration:
bool getFrame(Frame& frame, int32_t timeoutMsec = 0) override;
| Parameter | Value |
|---|---|
| frame | Output Frame class object. Video source class determines output pixel format. Pixel format can be set in initVSource(…) or openVSource(…) methods but if the specified pixel format is not supported by hardware, the library can return Frame object with different pixel format. |
| timeoutMsec | Timeout to wait new frame data, milliseconds: - timeoutMsec == -1 - Method will wait endlessly until new data arrives. - timeoutMsec == 0 - Method will only check if new data exists. - timeoutMsec > 0 - Method will wait for new data for the specified time. |
Returns: TRUE if new frame exists and copied or FALSE if not.
setParam method
The setParam(…) method is designed to set a new video source parameter value. Method declaration:
bool setParam(VSourceParam id, float value) override;
| Parameter | Description |
|---|---|
| id | Video source parameter ID according to VSourceParam enum. |
| value | Video source parameter value. |
Returns: TRUE if the parameter was set or FALSE if not.
getParam method
The getParam(…) method returns video source parameter value. Method declaration:
float getParam(VSourceParam id) override;
| Parameter | Description |
|---|---|
| id | Video source parameter ID according to VSourceParam enum. |
Returns: parameter value or -1 if the parameter is not supported.
getParams method
The getParams(…) method returns video source params (VSourceParams class object). Method declaration:
void getParams(VSourceParams& params) override;
| Parameter | Description |
|---|---|
| params | Reference to object of VSourceParams class. |
executeCommand method
The executeCommand(…) method executes a video source action command. Method declaration:
bool executeCommand(VSourceCommand id) override;
| Parameter | Description |
|---|---|
| id | Video source action command ID according to VSourceCommand enum. |
Returns: TRUE if the command was executed or FALSE if not.
decodeAndExecuteCommand method
The decodeAndExecuteCommand(…) method decodes and executes a command on the video source side. The method will decode commands encoded by encodeCommand(…) and encodeSetParamCommand(…) methods of VSource interface class. If the command is decoded, the method will call setParam(…) or executeCommand(…) methods. decodeAndExecuteCommand(…) is thread-safe. This means that the method can be safely called from any thread. Method declaration:
bool decodeAndExecuteCommand(uint8_t* data, int size) override;
| Parameter | Description |
|---|---|
| data | Pointer to input command. |
| size | Size of command. Must be 11 bytes for SET_PARAM and 7 bytes for COMMAND. |
Returns: TRUE if command decoded (SET_PARAM or COMMAND) and executed or FALSE if not.
encodeSetParamCommand method of VSource interface class
The encodeSetParamCommand(…) is a static method of VSource interface class designed to encode a command to change any parameter in a remote video source. To control video source remotely, the developer has to design his own protocol and according to it encode the command and deliver it over the communication channel. To simplify this, the VSource class contains static methods for encoding the control command. The VSource class provides two types of commands: a parameter change command (SET_PARAM) and an action command (COMMAND). encodeSetParamCommand(…) method encodes SET_PARAM command. Method declaration:
static void encodeSetParamCommand(uint8_t* data, int& size, VSourceParam id, float value);
| Parameter | Description |
|---|---|
| data | Pointer to data buffer for encoded command. Must have size >= 11. |
| size | Size of encoded data. Will be 11 bytes. |
| id | Parameter ID according to VSourceParam enum. |
| value | Parameter value. |
encodeSetParamCommand(…) is static and used without VSource class instance. This method is used on the client side (control system). Command encoding example:
// Buffer for encoded data.
uint8_t data[11];
// Size of encoded data.
int size = 0;
// Random parameter value.
float outValue = (float)(rand() % 20);
// Encode command.
VSource::encodeSetParamCommand(data, size, VSourceParam::EXPOSURE, outValue);
encodeCommand method of VSource interface class
The encodeCommand(…) is a static method of VSource interface class designed to encode a command for a remote video source. To control a video source remotely, the developer has to design his own protocol and according to it encode the command and deliver it over the communication channel. To simplify this, the VSource class contains static methods for encoding the control command. The VSource class provides two types of commands: a parameter change command (SET_PARAM) and an action command (COMMAND). encodeCommand(…) designed to encode COMMAND (action command). Method declaration:
static void encodeCommand(uint8_t* data, int& size, VSourceCommand id);
| Parameter | Description |
|---|---|
| data | Pointer to data buffer for encoded command. Must have size >= 11. |
| size | Size of encoded data. Will be 11 bytes. |
| id | Command ID according to VSourceCommand enum. |
encodeCommand(…) is static and used without VSource class instance. This method is used on the client side (control system). Command encoding example:
// Buffer for encoded data.
uint8_t data[11];
// Size of encoded data.
int size = 0;
// Encode command.
VSource::encodeCommand(data, size, VSourceCommand::RESTART);
decodeCommand method of VSource interface class
The decodeCommand(…) is a static method of VSource interface class designed to decode a command on the video source side (edge device). The method will decode commands encoded by encodeCommand(…) and encodeSetParamCommand(…) methods of VSource interface class. Method declaration:
static int decodeCommand(uint8_t* data, int size, VSourceParam& paramId, VSourceCommand& commandId, float& value);
| Parameter | Description |
|---|---|
| data | Pointer to input command. |
| size | Size of command. Should be 7 bytes for COMMAND or 11 bytes for SET_PARAM command. |
| paramId | Parameter ID according to VSourceParam enum. After decoding SET_PARAM command the method will return parameter ID. |
| commandId | Command ID according to VSourceCommand enum. After decoding COMMAND the method will return command ID. |
| value | Parameter value (after decoding SET_PARAM command). |
Returns: 0 - in case of decoding COMMAND, 1 - in case of decoding SET_PARAM command or -1 in case of errors.
Data structures
VSource.h file of VSource interface class defines IDs for parameters (VSourceParam enum) and IDs for action commands (VSourceCommand enum).
VSourceCommand enum
Enum declaration:
enum class VSourceCommand
{
/// Restart.
RESTART = 1
};
Table 2 - Video source action commands description.
| Command | Description |
|---|---|
| RESTART | Not supported by VSourceLibCamera library. |
VSourceParam enum
Enum declaration:
enum class VSourceParam
{
/// [read/write] Logging mode. Values: 0 - Disable, 1 - Only file,
/// 2 - Only terminal, 3 - File and terminal.
LOG_LEVEL = 1,
/// [read/write] Frame width. User can set frame width before initialization
/// or after. Some video source classes may set width automatically.
WIDTH,
/// [read/write] Frame height. User can set frame height before
/// initialization or after. Some video source classes may set height
/// automatically.
HEIGHT,
/// [read/write] Gain mode. Value depends on implementation but it is
/// recommended to keep default values: 0 - Manual control, 1 - Auto.
GAIN_MODE,
/// [read/write] Gain value. Value: 0(min for particular video source class)
/// - 65535(max for particular video source class).
GAIN,
/// [read/write] Exposure mode. Value depends on implementation but it is
/// recommended to keep default values: 0 - Manual control, 1 - Auto.
EXPOSURE_MODE,
/// [read/write] Exposure value. Value: 0(min for particular video source
/// class) - 65535(max for particular video source class).
EXPOSURE,
/// [read/write] Focus mode. Value depends on implementation but it is
/// recommended to keep default values: 0 - Manual control, 1 - Auto.
FOCUS_MODE,
/// [read/write] Focus position. Value: 0(full near) - 65535(full far).
FOCUS_POS,
/// [read only] Video capture cycle time. **VSource** class sets this value
/// automatically. This parameter means time interval between two captured
/// video frame.
CYCLE_TIME_MKS,
/// [read/write] FPS. User can set frame FPS before initialization or after.
/// Some video source classes may set FPS automatically.
FPS,
/// [read only] Open flag. 0 - not open, 1 - open.
IS_OPEN,
/// Region of interest upper left corner x coordinate.
ROI_X,
/// Region of interest upper left corner y coordinate.
ROI_Y,
/// Region of interest width.
ROI_WIDTH,
/// Region of interest height.
ROI_HEIGHT,
/// [read/write] Custom parameter. Depends on implementation.
CUSTOM_1,
/// [read/write] Custom parameter. Depends on implementation.
CUSTOM_2,
/// [read/write] Custom parameter. Depends on implementation.
CUSTOM_3
};
Table 3 - Video source params description.
| Parameter | Access | Description |
|---|---|---|
| LOG_LEVEL | read / write | Logging mode. Specifies the log output mode. Values: 0 - Disable, 1 - Only file, 2 - Only terminal (console), 3 - File and terminal. |
| WIDTH | read only | Video frames width, pixels. Can’t be changed after initialization. |
| HEIGHT | read only | Video frames height, pixels. Can’t be changed after initialization. |
| GAIN_MODE | read / write | Not supported. Can have any value. |
| GAIN | read / write | Not supported. Can have any value. |
| EXPOSURE_MODE | read / write | Not supported. Can have any value. |
| EXPOSURE | read / write | Not supported. Can have any value. |
| FOCUS_MODE | read / write | Not supported. Can have any value. |
| FOCUS_POS | read / write | Not supported. Can have any value. |
| CYCLE_TIME_MKS | read only | Video capture cycle time, microseconds. The library sets this value automatically. This parameter means time interval between two captured video frames. |
| FPS | read / write | FPS. Can’t be changed after initialization. |
| IS_OPEN | read only | Open flag. 0 - not open, 1 - open. |
| ROI_X | read / write | Region of interest top-left corner horizontal coordinate. |
| ROI_Y | read / write | Region of interest top-left corner vertical coordinate. |
| ROI_WIDTH | read / write | Region of interest width, pixels. |
| ROI_HEIGHT | read / write | Region of interest height, pixels. |
| CUSTOM_1 | read / write | Not supported. Can have any value. |
| CUSTOM_2 | read / write | Not supported. Can have any value. |
| CUSTOM_3 | read / write | Not supported. Can have any value. |
VSourceParams class description
VSourceParams class declaration
VSourceParams class used for video source initialization (initVSource(…) method) or to get all actual params (getParams(…) method). Also VSourceParams provides a structure to write/read params from JSON files (JSON_READABLE macro, see ConfigReader class description) and provides methods to encode and decode params. Class declaration:
class VSourceParams
{
public:
/// Logging mode. Values: 0 - Disable, 1 - Only file,
/// 2 - Only terminal, 3 - File and terminal.
int logLevel{0};
/// Video source: file, video stream, video device, camera num, etc.
std::string source{"/dev/video0"};
/// FOURCC: RGB24, BGR24, YUYV, UYVY, GRAY, YUV24, NV12, NV21, YU12, YV12.
/// Value says to video source class which pixel format preferable for
/// output video frame. Particular video source class can ignore this params
/// during initialization. Parameters should be set before initialization.
std::string fourcc{"YUYV"};
/// Frame width. User can set frame width before initialization
/// or after. Some video source classes may set width automatically.
int width{1920};
/// Frame height. User can set frame height before
/// initialization or after. Some video source classes may set height
/// automatically.
int height{1080};
/// Gain mode. Value depends on implementation but it is
/// recommended to keep default values: 0 - Manual control, 1 - Auto.
int gainMode{1};
/// Gain value. Value: 0(min for particular video source class)
/// - 65535(max for particular video source class).
int gain{0};
/// Exposure mode. Value depends on implementation but it is
/// recommended to keep default values: 0 - Manual control, 1 - Auto.
int exposureMode{1};
/// Exposure value. Value: 0(min for particular video source
/// class) - 65535(max for particular video source class).
int exposure{1};
/// Focus mode. Focus mode. Value depends on implementation but it is
/// recommended to keep default values: 0 - Manual control, 1 - Auto.
int focusMode{1};
/// Focus position. Value: 0(full near) - 65535(full far).
int focusPos{0};
/// Video capture cycle time. **VSource** class sets this value
/// automatically. This parameter means time interval between two captured
/// video frame.
int cycleTimeMks{0};
/// FPS. User can set frame FPS before initialization or after.
/// Some video source classes may set FPS automatically.
float fps{0};
/// Open flag. 0 - not open, 1 - open.
bool isOpen{false};
/// Region of intrest upper left corner x coordinate.
int roiX{0};
/// Region of intrest upper left corner y coordinate.
int roiY{0};
/// Region of intrest width.
int roiWidth{0};
/// Region of intrest heigth.
int roiHeight{0};
/// Custom parameter. Depends on implementation.
float custom1{0.0f};
/// Custom parameter. Depends on implementation.
float custom2{0.0f};
/// Custom parameter. Depends on implementation.
float custom3{0.0f};
JSON_READABLE(VSourceParams, logLevel, source, fourcc, width, height,
gainMode, exposureMode, focusMode, fps, roiX, roiY,
roiWidth, roiHeight, custom1, custom2, custom3);
/// Copy operator.
VSourceParams& operator= (const VSourceParams& src);
/// Encode (serialize) params.
bool encode(uint8_t* data, int bufferSize, int& size,
VSourceParamsMask* mask = nullptr);
/// Decode (deserialize) params.
bool decode(uint8_t* data, int dataSize);
};
Table 4 - VSourceParams class fields description.
| Field | Type | Description |
|---|---|---|
| logLevel | int | Logging mode. Specifies the log output mode. Values: 0 - Disable, 1 - Only file, 2 - Only terminal (console), 3 - File and terminal. |
| source | string | Camera number for Libcamera API. Default name format: “0”. |
| fourcc | string | Pixel format. Valid values: BGR24, RGB24, GRAY, YUV24, YUYV, UYVY, NV12, NV21, YV12, YU12. If fourcc not set the library will choose the appropriate format according to existing video device parameters. Value tells the video source class which pixel format is preferable for the output video frame. |
| width | int | Video frame width. Video frame height must be set as well. The library will try to set this value in video capture hardware parameters. If set to 0 the library will detect frame width automatically according to existing video device parameters. |
| height | int | Video frame height. Video frame width must be set as well. The library will try to set this value in video capture hardware parameters. If set to 0 the library will detect frame height automatically according to existing video device parameters. |
| gainMode | int | Not supported. Can have any value. |
| gain | int | Not supported. Can have any value. |
| exposureMode | int | Not supported. Can have any value. |
| exposure | int | Not supported. Can have any value. |
| focusMode | int | Not supported. Can have any value. |
| focusPos | int | Not supported. Can have any value. |
| cycleTimeMks | int | Video capture cycle time. The library sets this value automatically. This parameter means time interval between two captured video frames. |
| fps | float | FPS. Can’t be changed after initialization. |
| isOpen | bool | Open flag. false - not open, true - open. |
| roiX | int | Region of interest top-left corner horizontal coordinate. |
| roiY | int | Region of interest top-left corner vertical coordinate. |
| roiWidth | int | Region of interest width, pixels. |
| roiHeight | int | Region of interest height, pixels. |
| custom1 | float | Not supported. Can have any value. |
| custom2 | float | Not supported. Can have any value. |
| custom3 | float | Not supported. Can have any value. |
Note: VSourceParams class fields listed in Table 4 reflect params set/get by methods setParam(…) and getParam(…).
Encode video source params
VSourceParams class provides method encode(…) to serialize video source params (fields of VSourceParams class, see Table 4). Serialization of video source params is necessary in case when you need to send video source params via communication channels. The method doesn’t encode fields: source and fourcc. The method provides options to exclude particular parameters from serialization. To do this, the method inserts a binary mask (2 bytes) where each bit represents a particular parameter and the decode(…) method recognizes it. Method declaration:
bool encode(uint8_t* data, int bufferSize, int& size, VSourceParamsMask* mask = nullptr);
| Parameter | Value |
|---|---|
| data | Pointer to data buffer. |
| size | Size of encoded data. 78 bytes by default. |
| bufferSize | Data buffer size. If the buffer size is smaller than required, the buffer will be filled with fewer parameters. |
| mask | Parameters mask - pointer to VSourceParamsMask structure. VSourceParamsMask (declared in VSource.h file) determines flags for each field (parameter) declared in VSourceParams class. If the user wants to exclude any parameters from serialization, they can pass a pointer to the mask. If the user wants to exclude a particular parameter from serialization, they should set the corresponding flag in the VSourceParamsMask structure. |
VSourceParamsMask structure declaration:
struct VSourceParamsMask
{
bool logLevel{true};
bool width{true};
bool height{true};
bool gainMode{true};
bool gain{true};
bool exposureMode{true};
bool exposure{true};
bool focusMode{true};
bool focusPos{true};
bool cycleTimeMks{true};
bool fps{true};
bool isOpen{true};
bool roiX{true};
bool roiY{true};
bool roiWidth{true};
bool roiHeight{true};
bool custom1{true};
bool custom2{true};
bool custom3{true};
};
Example without parameters mask:
// Prepare random params.
VSourceParams in;
in.source = "alsfghljb";
in.logLevel = 0;
// Encode data.
uint8_t data[1024];
int size = 0;
in.encode(data, 1024, size);
cout << "Encoded data size: " << size << " bytes" << endl;
Example with parameters mask:
// Prepare random params.
VSourceParams in;
in.source = "alsfghljb";
in.logLevel = 0;
// Prepare params mask.
VSourceParamsMask mask;
mask.logLevel = false; // Exclude logLevel. Others by default.
// Encode data.
uint8_t data[1024];
int size = 0;
in.encode(data, 1024, size, &mask);
cout << "Encoded data size: " << size << " bytes" << endl;
Decode video source params
VSourceParams class provides method decode(…) to deserialize video source params (fields of VSourceParams class, see Table 4). Deserialization of video source params is necessary in case when you need to receive video source params via communication channels. The method doesn’t decode fields: source and fourcc. The method automatically recognizes which parameters were serialized by the encode(…) method. Method declaration:
bool decode(uint8_t* data, int dataSize);
| Parameter | Value |
|---|---|
| data | Pointer to encoded data buffer. Data size should be at least 62 bytes. |
| dataSize | Size of data. |
Returns: TRUE if data decoded (deserialized) or FALSE if not.
Example:
// Encode data.
VSourceParams in;
uint8_t data[1024];
int size = 0;
in.encode(data, 1024, size);
cout << "Encoded data size: " << size << " bytes" << endl;
// Decode data.
VSourceParams out;
if (!out.decode(data, size))
cout << "Can't decode data" << endl;
Read params from JSON file and write to JSON file
VSource library depends on ConfigReader library which provides methods to read params from JSON file and to write params to JSON file. Example of writing and reading params to JSON file:
// Write params to file.
VSourceParams in;
cr::utils::ConfigReader inConfig;
inConfig.set(in, "vSourceParams");
inConfig.writeToFile("TestVSourceParams.json");
// Read params from file.
cr::utils::ConfigReader outConfig;
if(!outConfig.readFromFile("TestVSourceParams.json"))
{
cout << "Can't open config file" << endl;
return false;
}
TestVSourceParams.json will look like:
{
"vSourceParams": {
"custom1": 150.0,
"custom2": 252.0,
"custom3": 30.0,
"exposureMode": 226,
"focusMode": 89,
"fourcc": "skdfjhvk",
"fps": 206.0,
"gainMode": 180,
"height": 61,
"logLevel": 17,
"roiHeight": 249,
"roiWidth": 167,
"roiX": 39,
"roiY": 223,
"source": "alsfghljb",
"width": 35
}
}
Build and connect to your project
If the Libcamera API is not installed, you have to install it by commands:
sudo apt-get install meson python3-pip libyaml-dev python3-yaml python3-ply python3-jinja2 libdrm-dev libjpeg-dev libsdl2-dev
git clone https://git.libcamera.org/libcamera/libcamera.git
cd libcamera
meson setup build
ninja -C build install
Typical commands to build VSourceLibCamera library:
cd VSourceLibCamera
mkdir build
cd build
cmake ..
make
If you want to connect VSourceLibCamera library to your CMake project as source code, you can do the following. For example, if your repository has structure:
CMakeLists.txt
src
CMakeList.txt
yourLib.h
yourLib.cpp
Create folder 3rdparty in your repository and copy repository folder VSourceLibCamera to 3rdparty folder. New structure of your repository:
CMakeLists.txt
src
CMakeList.txt
yourLib.h
yourLib.cpp
3rdparty
VSourceLibCamera
Create CMakeLists.txt file in 3rdparty folder. CMakeLists.txt should contain:
cmake_minimum_required(VERSION 3.13)
################################################################################
## 3RD-PARTY
## dependencies for the project
################################################################################
project(3rdparty LANGUAGES CXX)
################################################################################
## SETTINGS
## basic 3rd-party settings before use
################################################################################
# To inherit the top-level architecture when the project is used as a submodule.
SET(PARENT ${PARENT}_YOUR_PROJECT_3RDPARTY)
# Disable self-overwriting of parameters inside included subdirectories.
SET(${PARENT}_SUBMODULE_CACHE_OVERWRITE OFF CACHE BOOL "" FORCE)
################################################################################
## CONFIGURATION
## 3rd-party submodules configuration
################################################################################
SET(${PARENT}_SUBMODULE_VSOURCE_LIBCAMERA ON CACHE BOOL "" FORCE)
if (${PARENT}_SUBMODULE_VSOURCE_LIBCAMERA )
SET(${PARENT}_VSOURCE_LIBCAMERA ON CACHE BOOL "" FORCE)
SET(${PARENT}_VSOURCE_LIBCAMERA_TEST OFF CACHE BOOL "" FORCE)
SET(${PARENT}_VSOURCE_LIBCAMERA_EXAMPLE OFF CACHE BOOL "" FORCE)
endif()
################################################################################
## INCLUDING SUBDIRECTORIES
## Adding subdirectories according to the 3rd-party configuration
################################################################################
if (${PARENT}_SUBMODULE_VSOURCE_LIBCAMERA )
add_subdirectory(VSourceLibCamera)
endif()
File 3rdparty/CMakeLists.txt adds the folder VSourceLibCamera to your project and excludes the test application (VSourceLibCamera class test applications) from compiling. Your repository new structure will be:
CMakeLists.txt
src
CMakeList.txt
yourLib.h
yourLib.cpp
3rdparty
CMakeLists.txt
VSourceLibCamera
Next, you need to include the folder 3rdparty in the main CMakeLists.txt file of your repository. Add the following string at the end of your main CMakeLists.txt:
add_subdirectory(3rdparty)
Next, you have to include the VSourceLibCamera library in your src/CMakeLists.txt file:
target_link_libraries(${PROJECT_NAME} VSourceLibCamera)
Done!
Simple example
Example shows how to initialize video source with the generic VSource interface and how to capture video in a loop. Also, the example shows how to get a parameter value (video capture cycle time). Example:
#include <iostream>
#include "VSourceLibCamera.h"
int main(void)
{
// Init video source.
cr::video::VSource* source = new cr::video::VSourceLibCamera();
std::string initString = "0;1280;720;30;NV12";
if (!source->openVSource(initString))
return -1;
// Main loop.
cr::video::Frame frame;
while (true)
{
// Wait new frame 1 sec.
if (!source->getFrame(frame, 1000))
continue;
std::cout << "New frame " << frame.frameId <<
" (" << frame.width << "x" << frame.height << ") cycle time : " <<
(int)source->getParam(cr::video::VSourceParam::CYCLE_TIME_MKS) <<
" mksec" << std::endl;
}
return 1;
}
Test application
The VSourceLibCamera/test folder contains a test application for VSourceLibCamera class.
The test application will allow the user to test functionality of VSourceLibCamera class. Test application output will be like:
=================================================
VSourceLibCamera v2.2.3 test
=================================================
Enter camera index : 0
Enter width (0 - default 1280) : 1920
Enter height (0 - default 720) : 1080
Enter fps (0 - default 30) : 60
Enter pixel format (NV12, RGB24, BGR24, YUYV) : YUYV
Enter ROI x coordinate : 0
Enter ROI y coordinate : 0
Enter ROI width coordinate (0 for no roi) : 0
Enter ROI heigth coordinate (0 for no roi) : 0
Do you want to display frames (y/n) ? : n
[2:32:04.620978989] [22679] INFO Camera camera_manager.cpp:313 libcamera v0.3.0+65-6ddd79b5
[2:32:04.633756508] [22816] INFO RPI pisp.cpp:695 libpisp version v1.0.6 b567f0455680 17-06-2024 (10:20:00)
[2:32:04.650743601] [22816] INFO RPI pisp.cpp:1154 Registered camera /base/axi/pcie@120000/rp1/i2c@88000/imx708@1a to CFE device /dev/media0 and ISP device /dev/media1 using PiSP variant BCM2712_C0
[2:32:04.651222163] [22679] WARN V4L2 v4l2_pixelformat.cpp:344 Unsupported V4L2 pixel format RPBP
[2:32:04.658343349] [22679] INFO Camera camera.cpp:1183 configuring streams: (0) 1920x1080-YUYV
[2:32:04.658598093] [22816] INFO RPI pisp.cpp:1450 Sensor: /base/axi/pcie@120000/rp1/i2c@88000/imx708@1a - Selected sensor format: 2304x1296-SBGGR10_1X10 - Selected CFE format: 2304x1296-PC1B
FPS : 4
FPS : 33
FPS : 39
FPS : 45
FPS : 47
FPS : 48
FPS : 49
FPS : 51
FPS : 50
FPS : 54
FPS : 54
FPS : 54
FPS : 54
FPS : 54
FPS : 54
FPS : 55
FPS : 55
FPS : 55
FPS : 55
FPS : 55
FPS : 55