本文译自:http://www.robot-home.it/blog/en/software/tutorial-opencv-qt-opengl-widget-per-visualizzare-immagini-da-opencv-in-una-gui-con-qt-seconda-parte/


在第一部分教程之后,我们建立了一个Qt Widget在GUI中显示OpenCV图像,接下来我们要看看如何使用它。

现在我们建立一个简单的应用来绘制从网络摄像头中获取的流媒体视频,这是每一个OpenCV应用的基础。

本教程需要Qt Creator和Qt的基础知识,如果你觉得哪一步不清楚或是没有被充分的说明,请不要犹豫,立刻通过email联系我(原作者)

让我们从打开Qt Creator开始。Qt也能在其他工作环境下使用( Eclipse, Visual Studio, ...) ,但是说实话我更喜欢在原汁原味的环境下使用它,为Qt专门设计的环境能更好的利用Qt的所有特性。

首先新建一个工程,选择 “Qt Widget Project” -> “Qt GUI Application”。

译者注:类名QtGLWebcamDemo,基类选择QMainWindow。

然后将第一部分教程建立的文件拷贝到工程文件夹中。

在工程中“添加现有文件”,“cqtopencvviewergl.h” 和 “cqtopencvviewergl.cpp”。

之后向我们的GUI中添加一个OpenGL-OpenCV 的部件。

  • 打开界面文件
  • 从左侧“Containers”中拖入一个标准的Widget
  • 将这个widget命名为“openCVviewer”
  • 选中这个widget,之后右键选择“提升为” (“Promote to”)
  • 在“提升的类名称”中输入“CQtOpenCVViewerGl”
  • 在窗体上右键,选择“布局”中的“栅格布局”,使得widget布满可用区域

基本的接口就准备好了,现在我们需要配置工程文件让其可以使用OpenCV:

  • 打开“pro”文件,添加:INCLUDEPATH += 你的OpenCV目录 (对于Linux: INCLUDEPATH += /usr/local/opencv2/)
  • 再添加 LIBS += -lopencv_core -lopencv_highgui

译者注:如果你是按照译者之前关于Qt&OpenCV的博客中配置的开发环境,可按如下格式修改pro文件:

INCLUDEPATH += D:\opencv_mingw\install\include

LIBS += "D:\opencv_mingw\bin\libopencv_*.dll"

现在这个程序已经准备好应用OpenCV了,我们可以开始写代码来显示摄像头的图像了。

在窗体中的菜单栏中插入一个“Start”项:

  • 选择菜单栏,点击“在这里输入”,输入“Camera”
  • 选择“Camera”,在下拉菜单中的“在这里输入”中,输入“Start”

在“Action Editor”栏中的“actionStart” 项上右键,选择“转到槽”->”triggered()”。

Qt Creator 会自动生成一个函数,当用户点击 “Camera”中的”Start”时就会调用这个函数。

在这里,我们的函数很简单:

void QtGLWebcamDemo::on_actionStart_triggered()
{
if( !mCapture.isOpened() )
if( !mCapture.open( 0 ) )
return; startTimer(50);
}

mCapture 是我们的GUI中的一个私有变量:

cv::VideoCapture mCapture;

要记住,为了使用VideoCapture ,必须在程序中包含OpenCV的 “HighGUI” 模块。

#include <opencv2/highgui/highgui.hpp>

这个应用要使用定时器,我们每一个50ms获取新的摄像头图像,并且将图像传递给我们的OpenGL widget。

在主要的类中添加定时器函数。

protected:
void timerEvent(QTimerEvent *event);

它包含了如下的简单代码:

void QtGLWebcamDemo::timerEvent(QTimerEvent *event)
{
cv::Mat image;
mCapture >> image; // Show the image
ui->openCVviewer->showImage( image );
}

这个使用了Qt、OpenCV、OpenGL来显示摄像头图像的简单应用就准备好了,你只需要编译运行就可以看看效果了。

完整代码可在Github上获取:

https://github.com/Myzhar/QtOpenCVViewerGl

[OpenCV Qt教程] 在Qt图形界面中显示OpenCV图像的OpenGL Widget(第二部分)的更多相关文章

  1. [OpenCV Qt教程] 在Qt图形界面中显示OpenCV图像的OpenGL Widget (第一部分)

    本文译自:http://www.robot-home.it/blog/en/software/tutorial-opencv-qt-opengl-widget-per-visualizzare-imm ...

  2. 【OpenCV新手教程之十五】水漫金山:OpenCV漫水填充算法(Floodfill)

    本系列文章由@浅墨_毛星云 出品,转载请注明出处.    文章链接: http://blog.csdn.net/poem_qianmo/article/details/28261997 作者:毛星云( ...

  3. 布局(layout)文件图形界面不能显示:An error has occurred. See error log for more details. java.lang.NullPointe

    #问题解析# Android工程中Layout文件夹下的布局文件图形界面无法显示,一般发生这种情况在导入工程操作后极易出现,因为可能eclipse使用的sdk版本不同,target类型不同,所用And ...

  4. mysql数据库导出模型到powerdesigner,PDM图形窗口中显示数据列的中文注释

    1,mysql数据库导出模型到powerdesigner 2,CRL+Shift+X 3,复制以下内容,执行 '******************************************** ...

  5. 转 在PowerDesigner的PDM图形窗口中显示数据列的中文注释

    Name是名称(字段描述),Code是字段名称,Comment是注释名称,ER图中显示的是Name.一般设计时,Name跟comment都设计成描述, 而设计时候常把comment写成中文,name保 ...

  6. PyQt(Python+Qt)实现的GUI图形界面应用程序的事件捕获方法大全及对比分析

    一. 概述 PyQt的图形界面应用中,事件处理类似于Windows系统的消息处理.一个带图形界面的应用程序启动后,事件处理就是应用的主循环,事件处理负责接收事件.分发事件.接收应用处理事件的返回结果, ...

  7. OpenCV - Linux(Ubuntu 16.04)中安装OpenCV + OpenCV_Contrib

    近两个月来接触了Linux系统,在老板的建议下翻了Ubuntu的牌子,我安装的版本是16.04,用习惯之后感觉蛮好的,比Windows要强.好啦,废话不说啦,下面开始说在Ubuntu中安装OpemCV ...

  8. 将图片在指定窗口中显示-OpenCV应用学习笔记一

    1.OpenCV模块划分 OpenCV其实就是一堆用C和C++语言来实现计算机视觉算法的源代码文件:例如C接口函数cvCany()实现了Canny边缘提取算法,我们可以直接将这些源代码添加到自己的软件 ...

  9. 关于web2py外网访问,图形界面不显示等问题的解决办法

    首先系统版本是ubuntu 15.04,系统默认安装了两个版本的python, sudo python web2py.py 默认会调用python2.7版本来执行 会提示 pydo@planpls:/ ...

随机推荐

  1. java中高级面试题整理及参考答案

    面试问题: 一.Java基础方面: 1.Java面相对象的思想的理解(主要是多态): http://blog.csdn.net/zhaojw_420/article/details/70477636 ...

  2. openssl之aes加密(源码分析 AES_encrypt 与 AES_cbc_encrypt ,加密模式)

    首先要了解AES加密是什么,以及几种加密模式的区别.之后才是编程.具体的编程案例,在下面的链接. openssl之aes加密(AES_cbc_encrypt 与 AES_encrypt 的编程案例) ...

  3. 【javascript】利用jquery ajaxPrefilter防止ajax重复提交

    利用jquery ajaxPrefilter中断请求 var pendingRequests = {}; $.ajaxPrefilter(function( options, originalOpti ...

  4. linux中的网络基础

    ifconfig -a 查看所有网口ifconfig eth 查看具体网口 ifup ethoifdown etho 网卡配置文件/etc/sysconfig/networkk-scripts/ifc ...

  5. NOI 模拟赛

    T1 Article 给 $m$ 个好串,定义一个字符串分割方案是好的当且仅当它分割出来的子串中"是好串的子串"的串长占原串串长超过 85%,定义一个好的分割方案的权值为这种分割方 ...

  6. sql语句中charindex的用法

    假如你写过很多程序,你可能偶尔会碰到要确定字符或字符窜串否包含在一段文字中,在这篇文章中,我将讨论使用CHARINDEX和PATINDEX函数来 搜索文字列和字符串.我将告诉你这两个函数是如何运转的, ...

  7. EXCEL某列长度超过255个字符导入SQL SERVER2005的处理方法

    将注册表中 Jet引擎. HKEY_LOCAL_MACHINE/SOFTWARE/Microsoft/Jet/4.0/Engines/Excel 如果是:ACE引擎. HKEY_LOCAL_MACHI ...

  8. python3.x 类和对象

    python同样支持类和对象.在python3.x中没有了经典类,只有新式类,默认创建的就是新式类.具体的新式类与经典类的不同在python3.x中已经没有意义了. 类的定义和实例化 python定义 ...

  9. chrome安装vue-devtools

    安装方法1: 需正常打开chrome商店,搜索vuejs devtools 安装.chrome://extensions/ 开发者工具-扩展程序下启用: 方法2: github下载插件,npm包安装依 ...

  10. 连电子硬件行业都在开始使用 Git 了你还在等什么?

    连电子硬件行业都在开始使用 Git 了你还在等什么? 无论二进制还是文本 Git 都可以管理. 相对于电子行业传统的复制粘贴式的版本管理, git 的版本管理先进太多太多了,没有理由不用. 虽然做不到 ...