博客
关于我
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/

你可能感兴趣的文章
npm学习(十一)之package-lock.json
查看>>
npm安装 出现 npm ERR! code ETIMEDOUT npm ERR! syscall connect npm ERR! errno ETIMEDOUT npm ERR! 解决方法
查看>>
npm安装crypto-js 如何安装crypto-js, python爬虫安装加解密插件 找不到模块crypto-js python报错解决丢失crypto-js模块
查看>>
npm安装教程
查看>>
npm报错Cannot find module ‘webpack‘ Require stack
查看>>
npm报错Failed at the node-sass@4.14.1 postinstall script
查看>>
npm报错fatal: Could not read from remote repository
查看>>
npm报错File to import not found or unreadable: @/assets/styles/global.scss.
查看>>
npm报错TypeError: this.getOptions is not a function
查看>>
npm报错unable to access ‘https://github.com/sohee-lee7/Squire.git/‘
查看>>
npm淘宝镜像过期npm ERR! request to https://registry.npm.taobao.org/vuex failed, reason: certificate has ex
查看>>
npm版本过高问题
查看>>
npm的“--force“和“--legacy-peer-deps“参数
查看>>
npm的安装和更新---npm工作笔记002
查看>>
npm的常用操作---npm工作笔记003
查看>>
npm的常用配置项---npm工作笔记004
查看>>
npm的问题:config global `--global`, `--local` are deprecated. Use `--location=global` instead 的解决办法
查看>>
npm编译报错You may need an additional loader to handle the result of these loaders
查看>>
npm设置淘宝镜像、升级等
查看>>
npm设置源地址,npm官方地址
查看>>