图像处理---《Mat对象 与 IplImage对象》
图像处理---《认识 Mat对象》
Mat对象 与 IplImage对象
(1)Mat对象:OpenCV2.0之后引进的图像数据结构、自动分配内存、不存在内存泄漏的问题,是面向对象的数据结构。分了两个部分,头部与数据部分。
(2)IplImage对象:从2001年OpenCV发布之后就一直存在,是C语言风格的数据结构,需要开发者自己分配与管理内存,对大的程序使用它容易导致内存泄漏问题。
Mat对象的使用
(1)部分复制:一般情况下只复制Mat对象的头和指针部分,不会复制数据部分。
Mat A= imread(imgFilePath);
Mat B(A) // 只复制
(2)完全复制:若想把Mat对象的头部和数据部分一起复制,可以通过如下两个API实现。
Mat F = A.clone(); 或 Mat G; A.copyTo(G);
Mat对象使用-四个要点
(1)输出图像的内存是自动分配的。
(2)使用OpenCV的C++接口,不需要考虑内存分配问题。
(3) 赋值操作和拷贝构造函数只会复制头部分。
(4)使用clone与copyTo两个函数实现数据完全复制。
Mat对象创建
(1)cv::Mat::Mat构造函数
Mat M(2,2,CV_8UC3, Scalar(0,0,255))
其中前两个参数分别表示行(row)跟列(column)、第三个CV_8UC3中的8表示每个通道占8位、U表示无符号、C表示Char类型、3表示通道数目是3,第四个参数是向量表示初始化每个像素值是多少,向量长度对应通道数目一致。
(2)创建多维数组cv::Mat::create
int sz[3] = {2,2,2};
Mat L(3,sz, CV_8UC1, Scalar::all(0));
举例cv::Mat::create实现
Mat M;
M.create(4, 3, CV_8UC2);
M = Scalar(127,127);
cout << "M = " << endl << " " << M << endl << endl;
uchar* firstRow = M.ptr<uchar>(0);
printf("%d", *firstRow);
定义小数组
Mat C = (Mat_<double>(3,3) << 0, -1, 0, -1, 5, -1, 0, -1, 0); //比如,掩膜的矩阵
cout << "C = " << endl << " " << C << endl << endl;

/***************************************************************************************
作者:@WP20190612
环境:VS2010 + OpenCV2.4.3
功能:认识 OpenCV中的Mat对象
***************************************************************************************/
//-------------------------------功能:认识 Mat对象------------------------------
#include <opencv2/opencv.hpp>
#include <iostream>
#include <math.h> using namespace cv;
using namespace std; int main (int argc, char** argv) //argumentss 参数;argc命令行参数个数;
{
Mat src;
src = imread("D:\\003_test_img\\test001.png");
if (src.empty())
{
cout << "could not load image ...\n" << endl;
return -; //return 0 成功完成本函数;return -1 未能完成本函数
}
namedWindow("input image", CV_WINDOW_AUTOSIZE);
imshow("input image", src); //----------------------------开始处理图像--------------------------------------- /*//方式一 初始化成想要的图像矩阵
Mat dst;
dst = Mat(src.size(), src.type());
dst = Scalar(127, 0, 255);
namedWindow("output", CV_WINDOW_AUTOSIZE);
imshow("output", dst);*/ /*//方式二 克隆图像
Mat dst = src.clone();
namedWindow("output", CV_WINDOW_AUTOSIZE);
imshow("output",dst);*/ /*//方式三 克隆图像
Mat dst;
src.copyTo(dst);
namedWindow("output", CV_WINDOW_AUTOSIZE);
imshow("output",dst);*/ /*//方式四 转换颜色空间
Mat dst;
namedWindow("输出图像", CV_WINDOW_AUTOSIZE);
cvtColor(src, dst, CV_BGR2GRAY); //转成灰度图
printf("输入图像的通道数: %d\n", src.channels());
printf("灰度图像的通道数: %d\n", dst.channels()); int cols = dst.cols; //获取输出图像矩阵的列数---图像的宽度
int rows = dst.rows; //获取输出图像矩阵的函数---图像的高度
int channelNum=dst.channels();//获取图像的通道数目---彩色3,灰度1 printf("rows: %d cols: %d \n", cols, rows);
printf("channelsNum: %d \n", channelNum);
const uchar* firstRow = dst.ptr<uchar>(0);
printf("图像的第一个像素值: %d \n", *firstRow);
imshow("输出图像",dst);*/ /*//用途:通过小图,观察大图,以验证算法的可行性
Mat M(3, 3, CV_8UC3, Scalar(0, 0, 255));//建立一个红色的小图
cout << "M=" << endl << M << endl;
imshow("输出图像",M);*/ /*//定义一个m1图像矩阵
Mat m1;
m1.create(src.size(), src.type());
m1 = Scalar(0, 0, 255);
imshow("m1", m1);*/ /*//定义一个小数组
Mat csrc;
//Mat kernel = (Mat_<char>(3, 3) << 0,-1,0, -1,5,-1, 0,-1,0);
Mat kernel = (Mat_<float>(3, 3) << 0,-1,0, -1,5,-1, 0,-1,0);
filter2D(src, csrc, -1, kernel);
imshow("csrc",csrc);*/ /*//小技巧-001,opencv类似matlab的地方
Mat m2 = Mat::zeros(src.size(), src.type()); //全0像素的图像是黑色图像
imshow("m2",m2);*/ //小技巧-002,opencv类似matlab的地方
Mat m3 = Mat::zeros(, , CV_8UC1); //全0像素的图像是黑色图像
cout << "m3=" << endl << m3 << endl;
imshow("m3",m3); //小技巧-003,opencv类似matlab的地方
Mat m4 = Mat::eye(, , CV_8UC1);
cout << "m4=" << endl << m4 << endl;
imshow("m4",m4);
//----------------------------结束处理图像--------------------------------------- waitKey(); //防止DOS一闪而过
return ;
}
图像处理---《Mat对象 与 IplImage对象》的更多相关文章
- 图像处理---《在图片上打印文字 windows+GDI+TrueType字体》
图像处理---<在图片上打印文字 windows+GDI+TrueType字体> 刚开始使用的是putText()函数做,缺陷是只能显示非中文: 接着,看大多数推荐Freetype库来做 ...
- 图像处理---《在图片上打印文字 FreeType库》
图像处理---<在图片上打印文字 FreeType库> 目的:想在处理之后的图像上打印输出结果.方法: (1)只在图像上打印 数字.字母的话: 1.Mat格式 ...
- 图像处理---《在图片上打印文字 putText()》
图像处理---<在图片上打印文字 putText()> 目的:想在处理之后的图像上打印输出结果. 方法: (1)只在图像上打印 数字.字母的话: 1.Mat ...
- C#图像处理(1):在图片上加文字和改变文字的方向
C#在图片上加文字,代码如下: /// <summary> /// 图片上方加文字,文字将会被180度反转 /// </summary> /// <param name= ...
- Python3.x:如何识别图片上的文字
Python3.x:如何识别图片上的文字 安装pytesseract库,必须先安装其依赖的PIL及tesseract-ocr,其中PIL为图像处理库,而后面的tesseract-ocr则为google ...
- C#实现图片叠加,图片上嵌入文字,文字生成图片的方法
/// <summary> /// 图片叠加 /// </summary> /// <param name="sender"& ...
- python 图片上添加文字
import PIL from PIL import ImageFont from PIL import Image from PIL import ImageDraw #设置字体,如果没有,也可以不 ...
- 使用Qpaint在图片上写文字
开发过程中需要实现在图片上叠加文字,可以采用Qpaint在图片上写文字,然后将图片显示在上面.再将Qlabel加到Qwidget中.效果如下 //创建对象,加载图片 QPixmap pix; pix. ...
- 函数putText()在图片上写文字
#include <iostream> #include <opencv2/opencv.hpp> using namespace std; using namespace c ...
- 把图片上的文字转换成word文字?
转换后的文字不是很如意,但是免费方便. 1.打开Office办公软件自带的OneNote工具.随便新建一个笔记页面,以方便我们接下来的操作. 2.插入图片.在菜单栏里点击[插入],选择插入[图片],找 ...
随机推荐
- Jmeter综合运用 之 接口测试
Jmeter用的最多的就是做接口和性能测试了,着实比较好用,今天给大家分享下如何利用Jmeter做接口测试. 在做接口测试之前,我们起码需要了解: 1.接口涉及的业务 2.接口的基本信息:访问地址.传 ...
- 6种php加密解密方法
<?php function encryptDecrypt($key, $string, $decrypt){ if($decrypt){ $decrypted = rtrim(mcrypt_d ...
- vscode使用Chrome浏览器调试不好用,解决方法!!
1.如果你是刚下载vscode,那么你需要下载两个插件. 1. open in browser(在浏览器中查看,支持五大主流浏览器),下载并启用. 2. view-in-browser (在浏览器中查 ...
- ES 数据类型
官网数据类型网址 有价值的参考博客 本文 Elasticsearch 版本为 7.2 1. 核心数据类型 (1)字符串类型: text, keyword (2)数字类型:long, integer, ...
- 第一周--------带标签的 continue
- Java没有引用传递机制,C#有。
Java没有引用传递机制,C#有: public class Obj { private Integer myValue; public Integer getMyValue() { return m ...
- Laravel框架与ThinkPHP框架的不同
作为一个PHP菜鸟初学Laravel框架 在学习过程中我发现了其与TP框架的不同点,由于时间问题和认识还不够完善我先写出其中几点,有错误的地方希望各位大牛斧正... 1.渲染模版方式的不同:在Lara ...
- Spring Boot环境的安装
Eclipse 使用springboot框架 环境的安装 1.下载java1.8 ,安装并配置环境变量 环境变量增加java 的安装目录到环境变量中path中增加 %JAVA_HOME%/bin增加变 ...
- Wannafly挑战赛23
B. 游戏 大意: $n$堆石子, 第$i$堆初始$a_i$, 每次只能选一堆, 假设一堆个数$x$, 只能取$x$的约数, 求先手第一步必胜取法. SG入门题, 预处理出所有$SG$值. 先手要必胜 ...
- php 处理数字为金钱格式
number_format(需要转换的数字,保留小数个数,小数点符号,每三位的分隔符) echo number_format("1000000")."<br> ...