RMVL  1.2.0
Robotic Manipulation and Vision Library
samples/camera/mv/sample_mv_writer.cpp

迈德威视相机录屏例程

#include <opencv2/highgui.hpp>
#include <opencv2/videoio.hpp>
using namespace rm;
using namespace std;
using namespace cv;
int main()
{
Mat tmp;
while (!capture.read(tmp))
ERROR_("fail to read the image.");
VideoWriter writer("ts.avi", VideoWriter::fourcc('F', 'L', 'V', '1'), 40, tmp.size());
int exposure = 1000;
int gain = 64;
int r_gain = 100;
int g_gain = 100;
int b_gain = 100;
// Load the last parameters
FileStorage fs("out_para.yml", FileStorage::READ);
if (fs.isOpened())
{
fs["exposure"].isNone() ? void(0) : (fs["exposure"] >> exposure);
fs["gain"].isNone() ? void(0) : (fs["gain"] >> gain);
fs["r_gain"].isNone() ? void(0) : (fs["r_gain"] >> r_gain);
fs["g_gain"].isNone() ? void(0) : (fs["g_gain"] >> g_gain);
fs["b_gain"].isNone() ? void(0) : (fs["b_gain"] >> b_gain);
}
capture.set(CAMERA_MANUAL_EXPOSURE);
capture.set(CAMERA_EXPOSURE, exposure);
capture.set(CAMERA_GAIN, gain);
capture.set(CAMERA_MANUAL_WB);
capture.set(CAMERA_WB_RGAIN, r_gain);
capture.set(CAMERA_WB_GGAIN, g_gain);
capture.set(CAMERA_WB_BGAIN, b_gain);
Mat frame;
while (capture.read(frame))
{
imshow("frame", frame);
writer.write(frame);
if (waitKey(1) == 27)
if (waitKey(0) == 27)
break;
}
}
迈德威视相机库
@ OpenCV
使用 OpenCV 的 'cvtColor' 进行处理
@ CAMERA_WB_BGAIN
白平衡蓝色分量
Definition: camutils.hpp:105
@ CAMERA_WB_GGAIN
白平衡绿色分量
Definition: camutils.hpp:104
@ CAMERA_MANUAL_EXPOSURE
手动曝光
Definition: camutils.hpp:98
@ CAMERA_EXPOSURE
曝光值
Definition: camutils.hpp:100
@ CAMERA_MANUAL_WB
手动白平衡
Definition: camutils.hpp:99
@ CAMERA_WB_RGAIN
白平衡红色分量
Definition: camutils.hpp:103
@ CAMERA_GAIN
模拟增益
Definition: camutils.hpp:101
@ Continuous
连续采样
#define ERROR_(...)
Definition: util.hpp:50
Definition: uty_math.hpp:65
Definition: camutils.hpp:17
static CameraConfig create(Args... modes)
创建相机初始化配置模式
Definition: camutils.hpp:70