#include <opencv2\core\core.hpp>//核心组件
#include <opencv2\opencv.hpp>//GUI,包含媒体输入输出,视频捕捉、图形交互界面的接口等
#include <opencv2\highgui\highgui.hpp>//图像上处理
using namespace std;
using namespace cv;

图像容器Mat

不必再手动开辟空间;

不必再不需要时立即将空间释放。

Mat是一个类,有两个数据部分组成:矩阵头(矩阵尺寸,存储方法、存储地址等)和一个指向存储所有像素值得矩阵的指针。

opencv使用了引用计数机制,每个Mat对象有自己的信息头,共享一个矩阵。这通过让矩阵指向同一地址而实现。

拷贝构造函数值复制信息头和矩阵指针,不复制矩阵。

 #include <opencv2\core\core.hpp>//核心组件
#include <opencv2\opencv.hpp>//GUI,包含媒体输入输出,视频捕捉、图形交互界面的接口等
#include <opencv2\highgui\highgui.hpp>//图像上处理
using namespace std;
using namespace cv; int main(int argc, char** argv){//int argc, char* argv[]
Mat A, C;//仅创建信息头部分
A = imread("test.jpg");//为矩阵开辟内存空间
Mat B(A);//使用拷贝构造函数
C = A;//赋值运算符
}

创建ROI,只需要创建包含边界信息的信息头:

 Mat D(A, Rect(, , , ));//使用矩形界定
Mat E = A(Range::all(), Range(, ));//使用行和列界定

复制矩阵本身,使用clone()函数或copyTo函数:

Mat F = A.clone();
Mat G;
A.copyTo(G);

创建Mat对象

Mat运算符<<只对二维矩阵有效。

方法一:Mat()构造函数

Mat M(, , CV_8UC3, Scalar(, , ));
cout << "M=" << endl << M << endl;

(1)2行2列;

(2)存储元素的数据类型及每个矩阵点的通道数;CV_8UC3表示使用8位的unsigned char型,每个像素由三个元素组成三通道。预先定义的通道数可以多达四个。

CV_[位数][带符号与否][类型前缀]C[通道数],大部分设备都是用无符号8位整数CV_8U表示像素亮度。

如果需要更多通道数,可以把通道数放在小括号内,如:Mat M(3,2,CV_8UC(5)),通道数为5

(3)Scalar是个short型向量,指定值初始化矩阵,还可以用于表示颜色。

BGR:(0,0,255)表示全红

输出:

方法二:在C\C++中通过构造函数进行初始化

 int main(int argc, char** argv){//int argc, char* argv[]
int sz[] = { , , };//每个维度的尺寸
Mat L(, sz, CV_8UC, Scalar::all());
system("PAUSE");
return EXIT_SUCCESS;
}

 方法三:为已存在的IPlIMAGE指针创建信息头

 IPlImage* img = cvLoadImage("1.jpg",);
Mat mtx(img);//转换IPlImage* -> Mat

方法四:Create()函数

 M.create(,,CV_8UC());

若create函数指定的参数与之前的参数相同,则不进行实质的内存申请,否则就申请。

方法五:Matlab形式

 Mat E = Mat::eye(,,CV_64F);//单位阵
Mat O = Mat::ones(,,CV_32F);//全1矩阵
Mat Z = Mat::zeros(,3CV_8UC1);//0矩阵

方法六:对小矩阵使用逗号分隔式初始化函数

 Mat C = (Mat_<double>(,) << ,-,,-,,-,,-,);
cout << C << endl;

方法七:为已存在的对象创新信息头

clone函数和copyTo函数。

 int main(int argc, char** argv){//int argc, char* argv[]
Mat C = (Mat_<double>(, ) << , -, , -, , -, , -, );
Mat rowclone = C.row().clone();//把C的第一行赋值给了rowclone这个新的
system("PAUSE");
return EXIT_SUCCESS;
}

格式化输出方法

Mat r = Mat(,,CV_8UC3);
randu(r,Scalar::all(), Scalar::all());//randu产生随机值填充矩阵,给定上下限 cout << r << endl;//opencv默认风格 cout << foramt(r,Formatter::FMT_PYTHON) << endl;//python cout << format(r,Formatter::FMT_CSV) << endl;//逗号分隔风格 cout << format(r,Formatter::FMT_NUMPY) << endl;//numpy风格 cout << format(r,Formatter::FMT_FMT_C) << endl;//c风格

常用数据结构

点:Point类

 Point point;
point.x = ;
point.y = ; //方法二
Point point = Point(,);

Point_<int> == Point2i == Point

Point_<float> == Point2f

颜色表示:Scalar类

Scalar表示具有4个元素的数组,BGR,如果用不到第四个参数,就不需要写出来。

Scalar(a,b,c)

尺寸:Size类

Size(width, height);

矩形:Rect类

Rect rect = Rect(x,y,width,height);//左上角点坐标,宽,高

rect.Size();//返回size
rect.area();//返回矩形面积
rect.contains(Point);//判断点是否在矩形内
rect.inside(Rect);//判断矩形是否在该矩形内 Rect newrect1 = rect1 & rect2;//交集
Rect newrect2 = rect1 | rect2;//并集 Rect newrect3 = rect + point;//平移操作
Rect newrect4 = rect + size;//放缩操作

颜色空间转换:cvtColor函数

void cvtColor(InputArray src, OutputArray dst, int code, int dstCn=);

(1)输入图像;

(2)输出图像

(3)颜色空间转换标识符;

(4)目标图像通道数,默认值0,0表示目标图像取源图像的通道数;

opencv3中的COLOR_式的宏命名前缀取代了opencv2的CV_。

opencv数据结构与基本绘图的更多相关文章

  1. opencv 2 Opencv数据结构与基本绘图

    基础图像容器Mat Mat 是一个类,又两个数据部分组成:矩阵头(包含矩阵尺寸,存储方法,存储地址等信息)和一个指向存储所有像素值的矩阵(根据所选存储方法不同,矩阵可以是不同的维数)的指针.矩阵头的尺 ...

  2. Opencv实现的简易绘图工具

    第一次写博,还是个菜鸟.最近开始学习Opencv,试着写了个简易的绘图工具(目前只写了画线和橡皮擦部分,画其它图形还有待往里添加),也算是记录自己的学习之路. #include "stdaf ...

  3. opencv数据结构总结

    OpenCV里面用到了很多图像相关的数据结构,熟练掌握它们是学习图像的基础. 1.IplImage IplImage IplImage IPL 图像头 typedef struct _IplImage ...

  4. opencv数据结构-MAT结构详解

    1.定义 OpenCV中的C结构体有 CvMat 和 CvMatND,但后续的应用中指出 CvMat 和 CvMatND 弃用了,在C++封装中用 Mat 代替,另外旧版还有一个 IplImage,同 ...

  5. OpenCV学习笔记(四十)——再谈OpenCV数据结构Mat详解

    原文:http://blog.csdn.net/yang_xian521/article/details/7107786 我记得开始接触OpenCV就是因为一个算法里面需要2维动态数组,那时候看cor ...

  6. Opencv step by step - 绘图

    有时候我们需要在图像上写一些字或者画一些简单的几何图案. 祭上代码: #include <cv.h> #include <highgui.h> int main(int arg ...

  7. OpenCV数据结构:CvMat,IplImage,CvArr的应用

    最近看HS算法时,发现在新的OpenCV3.0已经移除了该算法,于是不得不看老版的.这其中涉及到了CvMat,CvArr,IplImage的使用.关于这三个结构与Mat的转换关系,总结如下: (1)派 ...

  8. OpenCV编程入门目录

    第一部分 快速上手OpenCV 第1 章 邂逅OpenCV 图像处理.计算机视觉与OpenCV OpenCV 概述 起源及发展 应用概述 .2OpenCV 基本架构分析 .3OpenCV3 带来了什么 ...

  9. 小强学Python+OpenCV之-1.3绘图

    目标 今天的课程比较轻松,我们来学习一下OpenCV中几个绘图函数: cv2.line cv2.rectangle cv2.circle 画直线 直接经过前面两节的内容.我想直接上代码应该是可以接受的 ...

随机推荐

  1. chrome控制台常用技巧有哪些

    chrome控制台常用技巧有哪些 一.总结 一句话总结:别的里面支持的快捷键,chrome里面几乎都支持,比如sublime中的ctrl+d,其实真是一通百通,都差不多的 1.chrome如何快速切换 ...

  2. nyoj--514--1的个数(贪心)

     1的个数 时间限制:1000 ms  |  内存限制:65535 KB 难度:3 描述 给你两个数a和b,你的任务是计算出1在a和b之间出现的次数,比如说,如果a=1024,b=1032,那么a ...

  3. [jzoj 6087] [GDOI2019模拟2019.3.26] 获取名额 解题报告 (泰勒展开+RMQ+精度)

    题目链接: https://jzoj.net/senior/#main/show/6087 题目: 题解: 只需要统计$\prod_{i=l}^r (1-\frac{a_i}{x})$ =$exp(\ ...

  4. 在Eclipse里连接Tomcat部署到项目(maven项目和web项目都适用)

    不多说,直接上干货! 前提, Tomcat *的下载(绿色版和安装版都适用) Tomcat *的安装和运行(绿色版和安装版都适用) Tomcat的配置文件详解 我这里以,manven项目为例,当然,w ...

  5. POJ-3169 Layout 最短路 差分约束

    题目链接:https://cn.vjudge.net/problem/POJ-3169 题意 Farmer John手下的一些牛有自己喜欢的牛,和讨厌的牛 喜欢的牛之间希望距离在给定距离D之内 讨厌的 ...

  6. [HDU5688]2016"百度之星" - 资格赛 Problem D

    题目大意:给你n个字符串,如果一个字符串可以通过重新排列变成另一个字符串,则认为这两个字符串相等.每输入一个字符串,输出这个字符串和与它相等的之前出现了几次. 解题思路:我们可以用map保存一个字符串 ...

  7. Linux快速入门打开你的学习之道

    Linux快速入门打开你的学习之道 相信看到这篇文章的你一定是想要学习Linux,或者已经在学习Linux的人了,那我们就可以一起探讨一下,学习Linux如何快速入门呢? 首先,希望大家弄清楚自己为什 ...

  8. 洛谷 P1052 过河 (离散化+dp)

    dp非常好想, f[i] = min(f[i-len] + stone[i]) s <= len <= t 然后因为L非常大,所以我就不知道该怎么搞了 我看到m只有100,而L有1e9,我 ...

  9. 紫书 习题 8-16 UVa 1618 (中途相遇法)

    暴力n的四次方, 然而可以用中途相遇法的思想, 分左边两个数和右边两个数来判断, 最后合起来判断. 一边是n平方logn, 合起来是n平方logn(枚举n平方, 二分logn) (1)两种比较方式是相 ...

  10. 【图灵杯 E也即POJ 3368】简单的RMQ

    Description 给定一个数组,其中的元素满足非递减顺序.任意给定一个区间[i,j],求其中某个元素重复出现的最大次数. Input 多组数据输入.每组数据的第一行包含两个整数n和q(1< ...