博客
关于我
Opencv读取视频或调用摄像头
阅读量:477 次
发布时间:2019-03-06

本文共 1509 字,大约阅读时间需要 5 分钟。

一、OpenCV 读取视频

在使用 OpenCV 读取视频时,首先需要导入相应的库文件。在编写代码时,请确保添加以下库:-lopencv_video -lopencv_videoio。这些库是 OpenCV 视频功能的必需组件。

接下来,通过 Include 语句引入必要的 헤더文件。具体来说,需要引入 OpenCV 的基础库和输入输出库:

`#include
` `#include
`

在代码中启用 OpenCV 和 标准输入输出库的命名空间:

`using namespace cv;` `using namespace std;`

接下来,在主函数中初始化 VideoCapture 对象,并使用相应的视频文件路径打开视频:

`VideoCapture cap;` `cap.open("./face.mp4");`

如果视频打开失败,可以通过判断返回值是否为 false 来检测。如果视频未正确打开,可以直接返回程序:

`if(!cap.isOpened()) return;`

接下来,可以获取视频的帧宽度、高度、帧率和总帧数等信息:

`int width = cap.get(CV_CAP_PROP_FRAME_WIDTH);` `int height = cap.get(CV_CAP_PROP_FRAME_HEIGHT);` `int frameRate = cap.get(CV_CAP_PROP_FPS);` `int totalFrames = cap.get(CV_CAP_PROP_FRAME_COUNT);`

最后,可以将视频帧读取到矩阵中,并在屏幕上显示视频内容。循环读取每一帧视频画面,并使用 waitKey 方法控制视频播放速度和动画延迟:

`Mat frame;` `while(1)` `{` `cap >> frame;` `if(frame.empty()) break;` `imshow(" video", frame);` `if(waitkey(20) == 0) break;` `}` `cap.release();`

释放视频资源后,结束程序的执行。

二、调用摄像头

在 OpenCV 中调用摄像头或视频源,可以使用 VideoCapture 对象。通过 VideoCapture 对象可以获取实时视频流或静态图像。在这一部分,我们将展示如何使用 VideoCapture 来调用摄像头设备。

打开第一个视频源(通常对应摄像头设备):

`VideoCapture cap;` `cap.open(0);`

与视频文件的方式类似,可以读取视频帧并将其存储在图像矩阵中。但在摄像头调用中,通常会进行实时图像处理或检测:

`while(cap.read())` `{` `// 实现图像处理或检测逻辑` `}` $p> 在实际应用中,可能需要对时间进行记录和计算,以优化算法性能。例如,可以使用 timestamp 来跟踪每帧处理的时间:

`Stopwatch ti;` `while(1)` `{` `cap.read();` `if(frame.empty()) break;` `ti.reset();` `// 用于跟踪处理时间` `// ...` `}`

这样可以通过计算每帧处理时间,来审视算法的运行效率。此外,可以通过打印日志信息,定期显示平均时间和处理速度:

`if(count % 1000 == 0)` `{` `printf("face detection average time = %f.\n", time / count);` `}`

转载地址:http://nlpdz.baihongyu.com/

你可能感兴趣的文章
OpenCV与AI深度学习 | 基于YOLO和EasyOCR从视频中识别车牌
查看>>
OpenCV与AI深度学习 | 基于图像处理的火焰检测算法(颜色+边缘)
查看>>
OpenCV与AI深度学习 | 基于拉普拉斯金字塔实现图像融合(步骤 + 代码)
查看>>
OpenCV与AI深度学习 | 基于机器视觉的磁瓦表面缺陷检测方案
查看>>
OpenCV与AI深度学习 | 基于深度学习的轮胎缺陷检测系统
查看>>
OpenCV与AI深度学习 | 如何使用YOLOv9分割图像中的对象
查看>>
OpenCV与AI深度学习 | 如何使用YOLOv9检测图片和视频中的目标
查看>>
OpenCV与AI深度学习 | 如何在 Docker 容器中使用 GPU
查看>>
OpenCV与AI深度学习 | 实战 | OpenCV中更稳更快的找圆方法--EdgeDrawing使用演示(详细步骤 + 代码)
查看>>
OpenCV与AI深度学习 | 实战 | OpenCV传统方法实现密集圆形分割与计数(详细步骤 + 代码)
查看>>
OpenCV与AI深度学习 | 实战 | OpenCV实现扫描文本矫正应用与实现详解(附源码)
查看>>
OpenCV与AI深度学习 | 实战 | 使用OpenCV和Streamlit搭建虚拟化妆应用程序(附源码)
查看>>
OpenCV与AI深度学习 | 实战 | 使用OpenCV确定对象的方向(附源码)
查看>>
OpenCV与AI深度学习 | 实战 | 使用YOLOv8 Pose实现瑜伽姿势识别
查看>>
OpenCV与AI深度学习 | 实战 | 使用YoloV8实例分割识别猪的姿态(含数据集)
查看>>
OpenCV与AI深度学习 | 实战 | 使用姿态估计算法构建简单的健身训练辅助应用程序
查看>>
OpenCV与AI深度学习 | 实战 | 基于OpenCV和K-Means聚类实现颜色分割(步骤 + 代码)
查看>>
OpenCV与AI深度学习 | 实战 | 基于YoloV5和Mask RCNN实现汽车表面划痕检测(步骤 + 代码)
查看>>
OpenCV与AI深度学习 | 实战 | 基于YOLOv9+SAM实现动态目标检测和分割(步骤 + 代码)
查看>>
OpenCV与AI深度学习 | 实战 | 基于YOLOv9和OpenCV实现车辆跟踪计数(步骤 + 源码)
查看>>