Example of how to use the VideoCapture class to get raw video frames and show the stream on screen using the OpenCV library.
#include <iostream>
#include <iomanip>
#include <opencv2/opencv.hpp>
int main(
int argc,
char *argv[])
{
(void)argc;
(void)argv;
{
std::cerr << "Cannot open camera video capture" << std::endl;
std::cerr << "See verbosity level for more details." << std::endl;
return EXIT_FAILURE;
}
#ifdef TEST_FPS
uint64_t lastFrameTs = 0;
#endif
while (1)
{
{
#ifdef TEST_FPS
if(lastFrameTs!=0)
{
double elapsed_sec = now - lastTime;
lastTime = now;
std::cout << "[System] Frame period: " << elapsed_sec << "sec - Freq: " << 1./elapsed_sec << " Hz" << std::endl;
double frame_dT =
static_cast<double>(frame.
timestamp-lastFrameTs)/1e9;
std::cout << "[Camera] Frame period: " << frame_dT << "sec - Freq: " << 1./frame_dT << " Hz" << std::endl;
}
#endif
}
int key = cv::waitKey( 5 );
if(key=='q' || key=='Q')
break;
}
return EXIT_SUCCESS;
}
The VideoCapture class provides image grabbing functions and settings control for all the Stereolabs ...
const Frame & getLastFrame(uint64_t timeout_msec=100)
Get the last received camera image.
bool initializeVideo(int devId=-1)
Open a ZED camera using the specified ID or searching for the first available.
std::string getDeviceName()
Retrieve the OS device name.
int getSerialNumber()
Retrieve the serial number of the connected camera.
uint64_t getSteadyTimestamp()
Get the current system clock as steady clock, so with no jumps even if the system time changes.
@ FPS_60
60 Frames per second. Not available for RESOLUTION::HD2K and RESOLUTION::HD1080.
The Frame struct containing the acquired video frames.
uint64_t timestamp
Timestamp in nanoseconds.
uint16_t height
Frame height.
uint16_t width
Frame width.
uint8_t * data
Frame data in YUV 4:2:2 format.
The camera configuration parameters.
RESOLUTION res
Camera resolution.
FPS fps
Frames per second.
sl_oc::video::VideoParams params
int main(int argc, char *argv[])