本文译自: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. Asp.Net MVC webAPI Token based authentication

    1. 需要安装的nuget <package id="Microsoft.AspNet.Identity.Core" version="2.2.1" ta ...

  2. BitArray编写埃拉托斯特尼筛法(原书错误,学习更正)

    刚开始代码无法运行,修改后原书代码可以运行了,可是书本的思想还是错的. 虽然接下来的都是讲错误的思想下的“错误”的修改. 原书缺了窗体控件的代码,虽然在VS下不需要手动写窗体的代码,但是刚开始确实也不 ...

  3. MySQL性能指标计算方式

    -- 生成报告文件到/tmp目录中 tee /tmp/mysql_performance_stat.txt -- 统计性能指标前先开启下列参数,该参数使用IS数据库来存放数据库信息,由于使用PS库存放 ...

  4. PRML-Chapter3 Linear Models for Regression

    Example: Polynomial Curve Fitting The goal of regression is to predict the value of one or more cont ...

  5. CF1083A The Fair Nut and the Best Path

    CF1083A The Fair Nut and the Best Path 先把边权搞成点权(其实也可以不用),那么就是询问树上路径的最大权值. 任意时刻权值非负的限制可以不用管,因为若走路径 \( ...

  6. BZOJ1085 SCOI2005 骑士精神【IDA* 启发式迭代加深】

    BZOJ1085 SCOI2005 骑士精神 Description 在一个5×5的棋盘上有12个白色的骑士和12个黑色的骑士, 且有一个空位.在任何时候一个骑士都能按照骑士的走法(它可以走到和它横坐 ...

  7. 利用 ReSharper 自定义代码中的错误模式,在代码审查之前就发现并修改错误

    多人协作开发的项目总会遇到代码编写风格上的差异.一般工具都能帮我们将常见的差异统一起来——例如 if 的换行:但也有一些不那么通用,但项目中却经常会出现的写法也需要统一. 例如将单元测试中的 Asse ...

  8. LG1343 地震逃生

    题意 汶川地震发生时,四川**中学正在上课,一看地震发生,老师们立刻带领x名学生逃跑,整个学校可以抽象地看成一个有向图,图中有n个点,m条边.1号点为教室,n号点为安全地带,每条边都只能容纳一定量的学 ...

  9. mix deps HEX_HTTP_CONCURRENCY=1 HEX_HTTP_TIMEOUT=120 timeout

    mix  deps.get  timeout 问题: If this happens consistently, adjust your concurrency and timeout setting ...

  10. npm 可执行模块的开发&&私服发布

    备注:    大家日常在使用npm 安装依赖的时候有一些是命令行工具,比如vue-cli,具体的开发比较简单,同时 可以基于此开发一些脚手架,方便开发. 1. 项目初始化 npm init 备注:按照 ...