转自:原文链接,以下代码、图片、内容有点改动,只为转载不降低博客内容的可阅性,版权归原作者所有。

OpenCV中强大的Mat类型大家已经比较熟悉了。这里梳理一些在工程中其他经常用到的几种基本数据类型。包括:

  • Vec
  • Scalar
  • Point
  • Size
  • Rect
  • RotatedRect

1. Vec类

1.1 基本概念

Vec是一个模板类,主要用于存储数值向量。

1.2 用法

(1)可用它来定义任意类型的向量

Vec<double, > myVector; // 定义一个存放8个double型变量的向量  

(2)使用[ ]访问Vec向量成员

myVector[]=;  

(3)可使用以下预定义的类型

typedef Vec<uchar, > Vec2b;
typedef Vec<uchar, > Vec3b;
typedef Vec<uchar, > Vec4b;
typedef Vec<short, > Vec2s;
typedef Vec<short, > Vec3s;
typedef Vec<short, > Vec4s;
typedef Vec<int, > Vec2i;
typedef Vec<int, > Vec3i;
typedef Vec<int, > Vec4i;
typedef Vec<float, > Vec2f;
typedef Vec<float, > Vec3f;
typedef Vec<float, > Vec4f;
typedef Vec<float, > Vec6f;
typedef Vec<double, > Vec2d;
typedef Vec<double, > Vec3d;
typedef Vec<double, > Vec4d;
typedef Vec<double, > Vec6d;
//可以直接运用
Vec3b mychar;
mychar[2]='cat';
Vec6d mydata;
for(int i=0; i<mydata.rows;i++)
mydata[i] = 20.3+18*i;
cout<<"mydata="<<mydata<<endl;

(4)Vec支持的运算如下:

v1 = v2 + v3
v1 = v2 - v3
v1 = v2 * scale
v1 = scale * v2
v1 = -v2
v1 += v2
v1 == v2, v1 != v2
norm(v1) (euclidean norm)//欧几里得范数
//求mydata的欧几里得范数
norm(mydata);

1.3 示例代码

(1)向量定义与元素的访问

// Vec
cv::Vec<double, > myVector;
for(int i=; i<myVector.rows;i++)
myVector[i] = i;
cout<<"myVector= "<<myVector<<endl;
cout<<"myVector[0]= "<<myVector[]<<endl;
cout<<"myVector[3]= "<<myVector[]<<endl;

(2)基本运算

cv::Vec<int, > v1,v2,v3;
for(int i=; i<v2.rows;i++){ //v2.rows返回向量v2的行数
v2[i] = i;
v3[i] = i+;
} v1 = v2 + v3;
cout<<"v2 = "<<v2<<endl;
cout<<"v3 = "<<v3<<endl;
cout<<"v1=v2+v3= "<<v1<<endl;
cout<<"v1=v2*2 = "<<v2*<<endl;
cout<<"v1=-v2 = "<<-v2<<endl;
cout<<"v1==v2 = "<<(v1==v2)<<endl;
cout<<"v1!=v2 = "<<(v1!=v2)<<endl;
cout<<"norm(v2)= "<<norm(v2)<<endl;

2. Scalar类

2.1 基本概念

Scalar是一个从Vec类引出的模板类,是一个可存放4个元素的向量,广泛用于传递和读取图像中的像素值。

2.2 用法

可使用[]访问Scalar值。或使用如下方式定义BGR三个通道的值。

cv:: Scalar( B, G, R ) 

2.3 示例代码

(1)cv::Scalar结构

cv::Scalar myScalar;
myScalar = cv::Scalar(,,);
cout<<"myScalar = "<<myScalar<<endl;
system("pause");

(2)读取彩色图像像素值

彩色图像的每个像素对应三个部分:RGB三个通道。因此包含彩色图像的cv::Mat类会返回一个向量,向量中包含三个8位的数值。OpenCV为这样的短向量定义了一种类型,即我们上述的cv::Vec3b。这个向量包含三个无符号字符(unsigned character)类型的数据。

OpenCV存储通道次序为:蓝色、绿色、红色即BGR。
因此,访问彩色像素中元素的方法如下:

cv::Mat pImg = cv::imread("1.jpg",);
if(!pImg.data)
return ;
int x = , y = ;
cv::Scalar pixel=pImg.at<Vec3b>(x,y);
cout<<"B chanel of pixel is = "<<pixel.val[]<<endl;
cout<<"G chanel of pixel is = "<<pixel.val[]<<endl;
cout<<"R chanel of pixel is = "<<pixel.val[]<<endl;
system("pause");

3. Point类

3.1 基本概念

常用于表示2维坐标(x,y)。

3.2 用法

(1)图像坐标

对图像而言,我们可以这样定义:

cv::Point pt;
pt.x = ;
pt.y = ;

或者:

Point pt = Point(,);
Point pt(10,8);

(2)或使用如下预定义:

typedef Point_<int> Point2i;
typedef Point2i Point; //上面使用Point
typedef Point_<float> Point2f;
typedef Point_<double> Point2d;

可见Point_<int>、Point2i、Point互相等价,Point_<float>和Point2f互相等价,Point_<double>和Point2d互相等价。

(3)基本运算

pt1 = pt2 + pt3;
pt1 = pt2 - pt3;
pt1 = pt2 * a;
pt1 = a * pt2;
pt1 += pt2;
pt1 -= pt2;
pt1 *= a;
double value = norm(pt); // L2 norm
pt1 == pt2;
pt1 != pt2;

3.3 示例代码

(1)设置坐标点

// Point
Point pt;
pt.x = ;
pt.y = ;
//或者
//Point pt (300,498);
Scalar pix = pImg.at<Vec3b>(pt);
cout<<"pix("<<pt.x<<","<<pt.y<<") = "<<pix<<endl;

(2)各类运算

cv::Point pt1(,);
cv::Point pt2(,);
cout<<"pt1 = "<<pt1<<endl;
cout<<"pt2 = "<<pt2<<endl;
cout<<"pt1+pt2 = "<<pt1+pt2<<endl;
cout<<"pt1+=pt2= "<<(pt1+=pt2)<<endl;
cout<<"pt1-pt2 = "<<pt1-pt2<<endl;
cout<<"pt2*2 = "<<pt2*<<endl;

4. Size类

4.1 基本概念

模板类Size可表示一幅图像或一个矩形的大小。它包含宽、高2个成员:width , height还有一个有用的面积函数area()。

4.2 用法

cv::Size size(int w, int h);
//或者
cv::Size size;
size.width = w;
size.height = h;

4.3 示例代码

// Size
cv::Size size1(,);
cv::Size size2;
size2.width = ;
size2.height = ;
cv::Mat mat1(size1,CV_8UC1,cv::Scalar());
cv::Mat mat2(size2,CV_8UC3,cv::Scalar(,,));
cout<<"mat1 = "<<endl<<mat1<<endl;
cout<<endl<<"mat2 = "<<endl<<mat2<<endl;
system("pause");

5. Rect类

5.1 基本概念

Rect是另一个用于定义2维矩形的模板类。它由两个参数定义:

  • 矩形左上角坐标: (x,y)
  • 矩形的宽和高: width, height

Rect可以用来定义图像的ROI区域。

5.2 用法

cv::Rect rect(x, y, width, height); 

5.3 示例代码

// Rect
cv::Mat pImg = imread("Lena.jpg",);
cv::Rect rect(,,,);//(x,y)=(180,200),w=200,height=200
cv::Mat roi = cv::Mat(pImg, rect);
cv::Mat pImgRect = pImg.clone();
cv::rectangle(pImgRect,rect,cv::Scalar(,,),);
cv::imshow("original image with rectangle",pImgRect);
cv::imshow("roi",roi);
cv::waitKey();

6. RotatedRect类

6.1 基本概念

最后一个基本数据类是一种特殊的矩形称为RotatedRect。这个类通过中心点,宽度和高度和旋转角度来表示一个旋转的矩形。

6.2 用法

旋转矩形类的构造函数:

RotatedRect(const Point2f& center, const Size2f& size, float angle);  

参数:

  • center:中心点坐标Point2f类型
  • size:矩形的宽度和高度,Size2f类型
  • angle:顺时针方向的旋转角度(单位°),float类型

6.3 示例代码

cv::Point2f center(100, 100);
cv::Size2f size(100, 50);
float bn = 10;
float angle[3];
for (int i = 0; i < 3; i++)
angle[i] = bn+i*20;//angle=10,30,50
for (int i = 0; i < 3; i++)
{
RotatedRect rRect(center, size, angle[i]);
cv::Mat image(200, 200, CV_8UC3, cv::Scalar(0));
Point2f vertices[4];
rRect.points(vertices);
for (int i = 0; i < 4; i++)
line(image, vertices[i], vertices[(i + 1) % 4], Scalar(0, 255, 0));
Rect brect = rRect.boundingRect();
rectangle(image, brect, Scalar(255, 0, 0));
ostringstream oss;
oss << "rectangles" << i << endl;
imshow(oss.str(), image);
} waitKey(0); //system("pause")亦可

opencv的基本数据结构(二)(转)的更多相关文章

  1. 学习javascript数据结构(二)——链表

    前言 人生总是直向前行走,从不留下什么. 原文地址:学习javascript数据结构(二)--链表 博主博客地址:Damonare的个人博客 正文 链表简介 上一篇博客-学习javascript数据结 ...

  2. opencv学习笔记(二)寻找轮廓

    opencv学习笔记(二)寻找轮廓 opencv中使用findContours函数来查找轮廓,这个函数的原型为: void findContours(InputOutputArray image, O ...

  3. OpenCV中Mat与二维数组之间的转换

    ---恢复内容开始--- 在OpenCV中将Mat(二维)与二维数组相对应,即将Mat中的每个像素值赋给一个二维数组. 全部代码如下: #include <iostream> #inclu ...

  4. 基于Opencv识别,矫正二维码(C++)

    参考链接 [ 基于opencv 识别.定位二维码 (c++版) ](https://www.cnblogs.com/yuanchenhui/p/opencv_qr.html) OpenCV4.0.0二 ...

  5. opencv基本的数据结构(转)

    DataType : 将C++数据类型转换为对应的opencv数据类型 enum { CV_8U=0, CV_8S=1, CV_16U=2, CV_16S=3, CV_32S=4, CV_32F=5, ...

  6. POJ 2010 - Moo University - Financial Aid 初探数据结构 二叉堆

    考虑到数据结构短板严重,从计算几何换换口味= = 二叉堆 简介 堆总保持每个节点小于(大于)父亲节点.这样的堆被称作大根堆(小根堆). 顾名思义,大根堆的数根是堆内的最大元素. 堆的意义在于能快速O( ...

  7. 【OpenCV入门教程之二】 一览众山小:OpenCV 2.4.8组件结构全解析

    转自: http://blog.csdn.net/poem_qianmo/article/details/19925819 本系列文章由zhmxy555(毛星云)编写,转载请注明出处. 文章链接:ht ...

  8. OpenCV(2)-Mat数据结构及访问Mat中像素

    Mat数据结构 一开始OpenCV是基于C语言的,在比较早的教材例如<学习OpenCV>中,讲解的存储图像的数据结构还是IplImage,这样需要手动管理内存.现在存储图像的基本数据结构是 ...

  9. OpenCV使用FindContours进行二维码定位

    我使用过FindContours,而且知道有能够直接寻找联通区域的函数.但是我使用的大多只是"最大轮廓"或者"轮廓数目"这些数据.其实轮廓还有另一个很重要的性质 ...

随机推荐

  1. HTTP压力测试工具wrk的安装及测试

    本次在VMware虚拟机的CentOS6.3系统中进行安装wrk压测工具,具体如下: 一.预先安装需求项 为了安装顺利,不受权限的限制,首先可以把用户切换为root用户# su + 输入root用户对 ...

  2. Print Nodes in Top View of Binary Tree

    Top view of a binary tree is the set of nodes visible when the tree is viewed from the top. Given a ...

  3. linux c 判断文件存在,遍历文件,随机修改文件内容

    #include<stdio.h> #include<stdlib.h> #include<time.h> #include<assert.h> #in ...

  4. docker中间件安装记录

    rabbitmq docker pull rabbitmq docker run --restart=on-failure: --name rabbitmq -d -p : -p : docker.i ...

  5. 第220天:Angular---路由

    内容介绍,为什么要使用前端路由? 在2005左右,兴起了一种叫做ajax的技术,有了ajax之后,我们向服务端提交数据的时候就不再需要使用from表单去提交了,因为from表单之间的提交会导致页面之间 ...

  6. BZOJ5104 Fib数列(二次剩余+BSGS)

    5在1e9+9下有二次剩余,那么fib的通项公式就有用了. 已知Fn,求n.注意到[(1+√5)/2]·[(1-√5)/2]=-1,于是换元,设t=[(1+√5)/2]n,原式变为√5·Fn=t-(- ...

  7. selenium+python定位元素的方法及使用

    selenium的八种定位方法 By.ID 通过id定位 By.CLASS_NAME 通过className定位 By.CSS_SELECTOR 通过CSS定位 By.LINK_TEXT 通过link ...

  8. 转:机器学习中的算法(2)-支持向量机(SVM)基础

    机器学习中的算法(2)-支持向量机(SVM)基础 转:http://www.cnblogs.com/LeftNotEasy/archive/2011/05/02/basic-of-svm.html 版 ...

  9. 谷歌钦定的编程语言Kotlin大揭秘

    第一时间关注程序猿(媛)身边的故事 谷歌钦定的编程语言Kotlin大揭秘 语法+高级特性+实现原理:移动开发者升职加薪宝典! 谷歌作为世界级的科技公司巨头,强悍的技术研发与创新能力使其一直是业界的楷模 ...

  10. BZOJ 3166: [Heoi2013]Alo

    3166: [Heoi2013]Alo Time Limit: 20 Sec  Memory Limit: 256 MBSubmit: 923  Solved: 437[Submit][Status] ...