1. Videocapture类

 C++: VideoCapture::VideoCapture();
 C++: VideoCapture::VideoCapture(const string& filename);
 C++: VideoCapture::VideoCapture(int device);
功能:创建一个VideoCapture类的实例,如果传入对应的参数,可以直接打开视频文件或者要调用的摄像头。

参数:
filename – 打开的视频文件名。

device – 打开的视频捕获设备id ,如果只有一个摄像头可以填0,表示打开默认的摄像
————————————————

注: 

1)如果默认笔记本/台式机只有一个USB摄像头,Index=0; 如果有2个,一般Index为0和1,根据具体情况区分,摄像头接入和断开会改变Index值 

2)如果接入2个以上,但只想用指定的一个,可以在设备管理器中禁用其他,同时Index设置为0 

pythonopencv目标检测摄像头 opencv识别摄像头物体_视频流

3)因为开启摄像头后一直在进行读取,所以需要用waitKey()返回值判断退出预览 
imshow(“video”, frame); 
if(waitKey(30)>0)//无按键按下返回-1,按键按下时退出 
break; 
也可以指定按键退出: 
if(waitKey(30)==27) //Esc键退出,ESC的ASCLL码为27 
break;

读取摄像头程序:

 

VideoCapture caputer(0);
 string filename = "E:\\欣奕华\\项目\\OPENCV\\Video\\";
 int i = 0;
 while (1)
 {
         Mat frame, frame1; //用于存储每一帧的图像
         caputer >> frame; // 读取当前帧
         cvtColor(frame, frame1, COLOR_BGR2GRAY);
         Canny(frame1, frame1, 50, 200);
         imshow("读取视频", frame1);
         waitKey(30);
         int key = waitKey();
  
         if ((uchar)key == 's' || (uchar)key == 'S')
         {   
             imwrite(filename + to_string(i) + ".jpg", frame1);
              i++;
        }
       if((uchar)key == 'q'|| (uchar)key == 'Q')
       {
          break;
       }
 }

2.获取指定视频类的相关参数信息

CV_CAP_PROP_POS_MSEC 视频当前点的毫秒值或视频捕捉的时间戳

CV_CAP_PROP_POS_FRAMES 下次将被捕获的0基索引的帧
CV_CAP_PROP_POS_AVI_RATIO 视频文件的相关位置: 0 - start of the film, 1 - end of the film.
CV_CAP_PROP_FRAME_WIDTH 视频流帧的宽度
CV_CAP_PROP_FRAME_HEIGHT 视频流帧的高.
CV_CAP_PROP_FPS 帧率.
CV_CAP_PROP_FOURCC 4字符编码的编码器.
CV_CAP_PROP_FRAME_COUNT 视频文件的帧数.
CV_CAP_PROP_FORMAT 由retrieve()返回矩阵对象的格式 .
CV_CAP_PROP_MODE 后端指定值指示当前捕捉的模式.
CV_CAP_PROP_BRIGHTNESS 图像亮度 (只对摄像头).
CV_CAP_PROP_CONTRAST 图像对比度 (only for cameras).
CV_CAP_PROP_SATURATION 图像饱和度 (only for cameras).
CV_CAP_PROP_HUE 色调 (only for cameras).
CV_CAP_PROP_GAIN 增益(only for cameras).
CV_CAP_PROP_EXPOSURE 曝光(only for cameras).
CV_CAP_PROP_CONVERT_RGB 布尔型标记图像是否应该被转换为RGB.
CV_CAP_PROP_WHITE_BALANCE 白平衡(目前不支持)
CV_CAP_PROP_RECTIFICATION 立体相机的矫正标记(note: only supported by DC1394 v 2.x backend currently)

3. 其他参考

    

    https://docs.opencv.org/2.4/modules/highgui/doc/reading_and_writing_images_and_video.html?highlight=videocapture#VideoCapture