博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
在Qt5.9.6中使用OpenCv VideoCapture类 + Qtimer定时器 简单实现摄像头调用.
阅读量:4212 次
发布时间:2019-05-26

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

 目前在进行Qt+OpenCv的学习,今天做了一个简单的结合OpenCv VideoCapture类 +和Qtimer定时器调用电脑摄像头并实现实时预览的功能.

Qt5.9.6 + OpenCv 3.2.0;  Qt与OpenCv的链接配置 详见: 

这里Qt中使用定时器的方法使用Qtimer类:

Qt的Qtimer官方使用文档给出了详细的使用说明 

大致思路为: 新建定时器,关联,开启定时器,调用超时处理函数

videotimer = new QTimer(this); //新建定时器

connect(videotimer ,SIGNAL(timeout()),this,SLOT(videotimerupdate()));//关联定时器和槽函数

videotimer ->start(20);

有了这个思路,开始进行具体的代码编写.

1.首先进行界面的搭建,一个lable,两个button.

2..h文件

class MainWindow : public QMainWindow{          Q_OBJECTpublic:  explicit MainWindow(QWidget *parent = 0);    ~MainWindow(); private slots:  void on_pushButton_open_clicked();void on_pushButton_close_clicked(); QImage MattoQImage(Mat img);      void capcamtimerUpDate();private:    Ui::MainWindow *ui;    QTimer *videotimer;    VideoCapture capture1;}

3..cpp文件

MainWindow::MainWindow(QWidget *parent) :    QMainWindow(parent),    ui(new Ui::MainWindow){      ui->setupUi(this);   videotimer = new QTimer(this); //新建定时器connect(videotimer ,SIGNAL(timeout()),this,SLOT(videotimerupdate()));//关联定时器和槽函数}void MainWindow::on_pushButton_open_clicked()//打开摄像头按钮{  capture1.open(0); //选择打开摄像头的id,笔记本电脑只有一个摄像头的话 填0; //cv::VideoCapture capture(int device );  device 设备id videotimer ->start(20);}void MainWindow::on_closecam_pushButton_clicked()//关闭摄像头按钮{    videotimer ->stop();    capture1.release(); //VideoCapture::release  关闭视频文件或摄像头}void MainWindow::videotimerupdate(){    Mat smg;    capture1>> smg;  //读取到Mat矩阵中 有两种办法 这里采用">>"方法             QImage image = Mat2QImage(smg);           ui->label->setPixmap(QPixmap::fromImage(image));}QImage MainWindow::MattoQImage(Mat img)  //将Mat类型转换为QImage类型{网上很多方法,可自行查找,这里给出2个参考:https://blog.csdn.net/liji_digital/article/details/55001396        https://blog.csdn.net/wr132/article/details/54428144}

 

4.运行结果

到此为止 就全部完成啦!

你可能感兴趣的文章
清理SQL Server 2008数据库日志
查看>>
索引记录数据的基本格式
查看>>
SQL SERVER性能优化--分区表
查看>>
SQL SERVER 2005数据加密
查看>>
SQL SERVER性能分析--死锁检测数据库阻塞语句
查看>>
时间格式转换函数
查看>>
高效SQL查询之Graphical Execution Plans
查看>>
sql server性能分析--DMV之(sys.dm_exec_query_stats )
查看>>
高效SQL查询之索引覆盖(index coverage)
查看>>
高效SQL查询之索引(VI)
查看>>
高效SQL查询之索引(II)
查看>>
高效SQL查询之索引(I)
查看>>
高效SQL查询之索引(III)
查看>>
清空压缩数据表
查看>>
MSSQL添加字段说明
查看>>
SQL查表名、字段名、表说明、字段说明
查看>>
在SqlServer中用自定义函数返回动态表内容
查看>>
CONTAINS和FREETEXT
查看>>
深入探讨Truncate Table
查看>>
SQL Server 2008 下的备份和日志收缩
查看>>