Mat转换为QImage
时间:2022-05-06
本文章向大家介绍Mat转换为QImage,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
请留意:
opencv为3.0.0版本,Qt为4.8.4版本
1 #include"image1.h"
2 #include<QApplication>
3 #include<QImage>
4 #include<QDebug>
5 #include<opencv2/opencv.hpp>
6
7 int main(int argv , char* argc[] ){
8
9 QApplication a(argv,argc);
10 QImage img;
11 cv::Mat mat = cv::imread("D:\image\4.png",true);
12 if(mat.empty()){
13
14 qDebug()<<"load image fail!";
15 return a.exec();
16 }
17 int chana = mat.channels();
18 //依据通道数不同,改变不同的装换方式
19 if(3 == chana ){
20 //调整通道次序
21 cv::cvtColor(mat,mat,CV_BGR2RGB);
22 img = QImage(static_cast<uchar *>(mat.data),mat.cols,mat.rows,QImage::Format_RGB888);
23 }else if(4 == chana ){
24 //argb
25 img = QImage(static_cast<uchar *>(mat.data),mat.cols,mat.rows,QImage::Format_ARGB32);
26 }else {
27 //单通道,灰度图
28 img = QImage( mat.cols, mat.rows , QImage::Format_Indexed8);
29 uchar * matdata = mat.data;
30 for(int row = 0 ; row <mat.rows ; ++row ){
31 uchar* rowdata = img.scanLine( row );
32 memcpy(rowdata,matdata ,mat.cols);
33 matdata+=mat.cols;
34 }
35 }
36 Image1 w ;
37 w.load(img);
38 w.show();
39 return a.exec();
40 }
效果图:
用Qimage进行缩放:
当然也可以用opencv自带的imshow进行显示
- 从头编写 asp.net core 2.0 web api 基础框架 (4) EF配置
- RavenDb学习(十)附件,存储大对象
- 从头编写 asp.net core 2.0 web api 基础框架 (3)
- Distribute Cached 使用
- RavenDb学习(七) 异步工作以及维度查询
- RavenDb学习(五)结果转换
- sqoop 从sqlserver2008 导入数据到hadoop
- 从头编写 asp.net core 2.0 web api 基础框架 (2)
- hbase源码系列(四)数据模型-表定义和列族定义的具体含义
- RavenDb学习(四)处理文档相关性
- RavenDb学习(二)简单的增删查改
- RavenDb学习(九)高级特性下半部分
- RavenDb学习(三)静态索引
- 从头编写 asp.net core 2.0 web api 基础框架 (1)
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 手摸手带你理解Vue的Watch原理
- rollup环境搭建(es6转es5、压缩、本地服务器、热更新)
- Vue - 解决路由过渡动画抖动问题
- TypeScript - 泛型
- TypeScript - 类型声明、枚举、函数、接口
- Vue - 简单实现一个命令式弹窗组件
- Vue - 组件通信之$attrs、$listeners
- 多线程系列(一)多线程基础
- Python自动化运维之iptables和安全概述
- Python自动化运维之shell终极指南
- SQL 中判断条件的先后顺序,会引起索引失效么?
- Maven工程java -jar时提示xxx-SNAPSHOT.jar中没有主清单属性
- Kotlin 1.4 版本正式发布:新功能一覽
- 聊聊java中的哪些Map:(二)HashMap中的TreeNode
- 用innodb_ruby分析InnoDB的页管理