做图像处理的时候经常使需要用到opencv的,这应该是免费的图像处理库中用得最广泛而且最好用的库了吧。然后有时候想用界面来展示点东西的时候,我们就需要编写个界面,编写界面的方法千千万,弱水三千我只取一瓢饮,所以我用Qt来写界面,这个时候,就会想,如果我用OpenCV处理后的图像不会还要用OpenCV的GUI来显示吧,虽然完全可以这么做,但是既然都有个界面了,为啥我们还要用两个窗口来显示呢,于是就有了让OpenCV处理后的图像在Qt写的的界面上显示。

最简单粗暴无脑的方法就是把OpenCV处理后的图像保存到本地,然后用Qt加载进来,简单粗暴(23333...T_T!!!)。所以后来我找到一些别人的方法,然后我自己再修改一下,就成了我现在一直在用的方法,感觉上还可以,所以就直接上代码吧...等等,还是说一下Mat和QImage都有哪些格式吧。

首先是cv::Mat,cv::Mat是OpenCV的图像数据类型,是一个类,具体的内容可以参考OpenCV的关于cv::Mat的API,这里要注意几个地方:

1、指向图像数据的指针:

uchar* cv::Mat::data

2、图像的行跟列:

int cv::Mat::rows
int cv::Mat::cols

3、数据类型,这个比较重要,在转为QImage的时候需要用到它来辨别数据格式。

int cv::Mat::type() const

OpenCV的图像数据格式如下:

typedef uint32_t     	uint 
typedef signed char  schar
typedef unsigned char  uchar
typedef unsigned short  ushort
typedef int64_t  int64
typedef uint64_t  uint64
#define  CV_BIG_INT(n)   n##LL
#define  CV_BIG_UINT(n)   n##ULL
#define  CV_CN_MAX   512
#define  CV_CN_SHIFT   3
#define  CV_DEPTH_MAX   (1 << CV_CN_SHIFT)
#define  CV_8U   0
#define  CV_8S   1
#define  CV_16U   2
#define  CV_16S   3
#define  CV_32S   4
#define  CV_32F   5
#define  CV_64F   6
#define  CV_USRTYPE1   7
#define  CV_MAT_DEPTH_MASK   (CV_DEPTH_MAX - 1)
#define  CV_MAT_DEPTH(flags)   ((flags) & CV_MAT_DEPTH_MASK)
#define  CV_MAKETYPE(depth, cn) (CV_MAT_DEPTH(depth) + (((cn)-1) << CV_CN_SHIFT))
#define  CV_MAKE_TYPE   CV_MAKETYPE
#define  CV_8UC1   CV_MAKETYPE(CV_8U,1)
#define  CV_8UC2   CV_MAKETYPE(CV_8U,2)
#define  CV_8UC3   CV_MAKETYPE(CV_8U,3)
#define  CV_8UC4   CV_MAKETYPE(CV_8U,4)
#define  CV_8UC(n)   CV_MAKETYPE(CV_8U,(n))
#define  CV_8SC1   CV_MAKETYPE(CV_8S,1)
#define  CV_8SC2   CV_MAKETYPE(CV_8S,2)
#define  CV_8SC3   CV_MAKETYPE(CV_8S,3)
#define  CV_8SC4   CV_MAKETYPE(CV_8S,4)
#define  CV_8SC(n)   CV_MAKETYPE(CV_8S,(n))
#define  CV_16UC1   CV_MAKETYPE(CV_16U,1)
#define  CV_16UC2   CV_MAKETYPE(CV_16U,2)
#define  CV_16UC3   CV_MAKETYPE(CV_16U,3)
#define  CV_16UC4   CV_MAKETYPE(CV_16U,4)
#define  CV_16UC(n)   CV_MAKETYPE(CV_16U,(n))
#define  CV_16SC1   CV_MAKETYPE(CV_16S,1)
#define  CV_16SC2   CV_MAKETYPE(CV_16S,2)
#define  CV_16SC3   CV_MAKETYPE(CV_16S,3)
#define  CV_16SC4   CV_MAKETYPE(CV_16S,4)
#define  CV_16SC(n)   CV_MAKETYPE(CV_16S,(n))
#define  CV_32SC1   CV_MAKETYPE(CV_32S,1)
#define  CV_32SC2   CV_MAKETYPE(CV_32S,2)
#define  CV_32SC3   CV_MAKETYPE(CV_32S,3)
#define  CV_32SC4   CV_MAKETYPE(CV_32S,4)
#define  CV_32SC(n)   CV_MAKETYPE(CV_32S,(n))
#define  CV_32FC1   CV_MAKETYPE(CV_32F,1)
#define  CV_32FC2   CV_MAKETYPE(CV_32F,2)
#define  CV_32FC3   CV_MAKETYPE(CV_32F,3)
#define  CV_32FC4   CV_MAKETYPE(CV_32F,4)
#define  CV_32FC(n)   CV_MAKETYPE(CV_32F,(n))
#define  CV_64FC1   CV_MAKETYPE(CV_64F,1)
#define  CV_64FC2   CV_MAKETYPE(CV_64F,2)
#define  CV_64FC3   CV_MAKETYPE(CV_64F,3)
#define  CV_64FC4   CV_MAKETYPE(CV_64F,4)
#define  CV_64FC(n)   CV_MAKETYPE(CV_64F,(n))

这里最最常见和默认的应该是:

#define     CV_8U   0    
#define     CV_8UC1   CV_MAKETYPE(CV_8U,1)
#define     CV_8UC3   CV_MAKETYPE(CV_8U,3)

然后因为有时候要用到浮点型数据,所以,可能我会用到:

#define    CV_32F    5 
#define    CV_64F    6
#define    CV_32FC1    CV_MAKETYPE(CV_32F,1)
#define    CV_32FC3    CV_MAKETYPE(CV_32F,3)
#define    CV_64FC1    CV_MAKETYPE(CV_64F,1)
#define    CV_64FC3    CV_MAKETYPE(CV_64F,3)

然后是QImage是Qt提供的图像类型之一,其数据类型有:

但是,对应上面cv::Mat的类型如下:

//单通道灰度图

CV_8UC1 == QImage::Format_Grayscale8

CV_8U == QImage::Format_Grayscale8

//三通道图

CV_8UC3 == QImage::Format_RGB888

基本上,有这几个类型的转换就够了的,好了,类型说完了,该上代码了:

QImage mat2qimage(const cv::Mat &mat)
{
if (mat.type() == CV_8UC1 || mat.type() == CV_8U)
{
    // Copy input Mat
    const uchar *pSrc = (const uchar*)mat.data;
    // Create QImage with same dimensions as input Mat
    QImage image(pSrc, mat.cols, mat.rows, mat.step, QImage::Format_Grayscale8);
    return image;
}
// 8-bits unsigned, NO. OF CHANNELS = 3  
else if (mat.type() == CV_8UC3)
{
    // Copy input Mat
    const uchar *pSrc = (const uchar*)mat.data;
    // Create QImage with same dimensions as input Mat
    QImage image(pSrc, mat.cols, mat.rows, mat.step, QImage::Format_RGB888);
    // Because of the BGR order in opencv, 
    // here the rgbSwapped() function is needed.
    return image.rgbSwapped();
}
}

如果要显示的是float或者fouble型的呢...那就转一下吧,应该,上面这两种会更常见一点吧。其实还有QImage转cv::Mat的方法的,但是我觉得...好像不是很有必要,毕竟我更倾向于用Open'CV做图像处理,然后用Qt带来显示。

草在结它的种子 

风在摇它的叶子 

我们站着,不说话

就十分美好

  -- 顾城

  

OpenCV和Qt的图像格式互转的更多相关文章

  1. Opencv与Qt (一)之运行测试读取图片

    刚刚在vs上装好了QT和Opencv,试一下效果把. 我简单的创建了一个label,然后使用Opencv导入图像,因为Opencv导入图像是MAT格式的,在使用Qt的时候我们要把导入的图像转换成Qim ...

  2. OpenCV与QT联合开发示例

    1.OpenCV及QT开发环境搭建 windows基于vs2017的opencv安装 windows下安装QT并与visual studio 2017搭建开发环境 2.工程创建 1.导入Qt项目 选择 ...

  3. OpenCV支持Qt用户界面

    在运行opencv程序的时候报下面的错误: ... The library is compiled without QT support in function ... 原因是在使用cmake安装op ...

  4. 使用opencv在Qt控件上播放mp4文件

    文章目录 简介 核心代码 运行结果 简介 opencv是一个开源计算机视觉库,功能非常多,这里简单介绍一下OpenCV解码播放Mp4文件,并将图像显示到Qt的QLabel上面. 核心代码 头文件 #i ...

  5. ubuntu 安装 OpenCv 及其Qt的开发环境配置

    ubuntu安装opencv (1)安装编译opencv的环境 sudo apt-get -y install build-essential cmake pkg-config (2)安装Image ...

  6. [OpenCV] Install openCV in Qt Creator

    Learn openCV.pdf qmake: link with opencv (Key Point) QT += core gui greaterThan(QT_MAJOR_VERSION, 4) ...

  7. ubuntu下opencv在Qt中的使用

    1. 编译安装OpenCV2.4.9  本博已有文章描述 2. 安装Qt和QtCreator 从qt-project.org 下载Qt安装文件 qt-opensource-linux-x64-5.4. ...

  8. OpenCV与QT联合编译 分类: Eye_Detection ZedBoard OpenCV shell ubuntu 2014-11-08 18:54 143人阅读 评论(0) 收藏

    问题1:首先参考rainysky的博客,发现qmake时发生找不到目录,文件的错误,又找不到 qmake.conf 文件的写法.所以开始按照网上的程序修改 XXX.pro 文件. 问题2:使用QT C ...

  9. (GO_GTD_2)基于OpenCV和QT,建立Android图像处理程序

    一.综述     如何采集图片?在windows环境下,我们可以使用dshow,在linux下,也有ffmpeg等基础类库,再不济,opencv自带的videocapture也是提供了基础的支撑.那么 ...

随机推荐

  1. 2018年Android面试题含答案--适合中高级(下)(转)

    这里是我整理出来的 面试题,答案我花了很久的时间.加上我自己的理解整理出来的,作者不易,请谅解.有答案的的:https://xiaozhuanlan.com/topic/6132940875   1. ...

  2. css快速浏览

    meta <meta charset="utf-8" /> <meta name="keywords" content="key1, ...

  3. css选择器权重、样式继承、默认样式

    学过css的小伙伴都是指css选择器的权重 !important Infinity 行间样式 1000 id   100 class|属性|伪类 10 标签|伪元素 1 通配符 0 权重相同 相同cs ...

  4. SPOJ_DSUBSEQ Distinct Subsequences

    统计一个只由大写字母构成的字符串的,子串数目,这里指的是子串不是子序列,可以不连续,请注意 然后我按照计数DP的思想,dp[i][j]表示长度为i的子串,最后一个字母为j 然后为了去重,每一次dp的时 ...

  5. HDU 1542 线段树离散化+扫描线 平面面积计算

    也是很久之前的题目,一直没做 做完之后觉得基本的离散化和扫描线还是不难的,由于本题要离散x点的坐标,最后要计算被覆盖的x轴上的长度,所以不能用普通的建树法,建树建到r-l==1的时候就停止,表示某段而 ...

  6. ORM——Mybatis

    引言 ORM 是 blablabla…… Mybatis知识点

  7. Windows2008R2安装DNS和SQLServer200r2服务 (9.18第七天)

    原文网址:https://www.cnblogs.com/yankaohaitaiwei/p/11538205.html 二.IIS搭建web服务器 1.格式化D盘,一定要选择NTFS!!!不然后面添 ...

  8. P 1029 旧键盘

    转跳点:

  9. UVA - 12563 Jin Ge Jin Qu hao(劲歌金曲)(0-1背包+滚动数组)

    题意:在KTV唱歌剩下的t秒时间内,决定选最爱的n首歌中的一部分歌,在时间结束之前唱一首时长678秒的<劲歌金曲>,使得唱的总曲目尽量多(包括<劲歌金曲>),在此前提下尽量晚的 ...

  10. python虚拟环境配置(下)

    前言 嘿,各位小伙伴们,晚上好呀,新年快乐,注意预防流感哈,就不要出去浪了,万一中奖了,嗯...,还是当个宅男,宅男无敌,哈哈哈, 过年了,村都被封了,哎,出都出不去,想着干点啥,就把以前没完善的继续 ...