1:包含在cxcore/include/cxtypes.h头文件中。

2:CvPoint系列   -----(x,y)

CvPoint:表示图像中的点

CvPoint2D32f:二维空间中的点

CvPoint3D32f:三维空间中的点

3:CvSize系列-----宽度和高度

CvSize:图像的尺寸

CvSize2D32f: 如果想用浮点型

4:CvRect-----(x, y, width, height)

可以用来表示图像的部分区域

5:CvScalar

包含四个double成员,可以用来表示B,G,R,alpha----alpha是用来表示图像的透明度

有三个构造函数

cvScalar(double val0, double val1=0,double val2=0, double val3=0),

cvRealScalar(double val0),----只初始化第一个 其它都为0

cvScalarAll(double val0123),把四个都赋值为val0123

6:CvArr

虽然opencv1.0大部分是由C语言完成,但是它的结构也是遵循面向对象的思想,CvMat和IplImage的关系就如同C++中的继承关系,IplImage可以视为从CvMat派生的,CvArr可以视为抽象类。这样使得接口类型更通用些。

7:CvMat

(1)CvMat 结构

typedef struct CvMat
{
int type; /* 矩阵类型的数据类型 通道数 维度(x,y就是二维)----可惜的是是经过计算后的一串数字*/
int step; /* 以字节为单位的行数据长度---一行所占有的字节数*/
int* refcount; /* 数据引用计数 ---内部使用 不用管*/
union //c语言中的联合体--里面的几个数据类型是等价的 不同的数据类型用不同的来表示,看你是如何定义的
{
uchar* ptr;
short* s;
int* i;
float* fl;
double* db;
} data; /* data 指针 */
#ifdef __cplusplus //如果是c++的环境 这里的rows就可以写成height
union
{
int rows;
int height;
};
union
{
int cols;
int width;
};
#else
int rows; /* 行数 */
int cols; /* 列数*/
#endif
} CvMat;

(2)创建一个矩阵

方式一:cvCreateMat(int rows, int cols, int type)返回CvMat*类型

Type是任何预定义的类似。写法为CV_<bit_depth>(S|U|F)C<channels>

代码:

CvMat *pmat1;
pmat1 = cvCreateMat(4, 3, CV_8UC1);

方式二:cvCreateMatHeader()函数创建CvMat结构,不分配数据内存

cvCreateData() 函数分配数据需要的内存

代码:

    CvMat *pmat2;
pmat2 = cvCreateMatHeader(4,3,CV_8UC1);
cvCreateData(pmat2);

方式三:

cvInitMatHeader(CvMat*mat,int rows, int cols, int type,void* data=NULL, int step=CV_AUTOSTEP );

代码:

CvMatmat;  // 注意这里不能用*mat ,,因为用*mat,此时它指向一个空指针,可以在createMatHeader之后使用  mat是一个结构体而*mat是一个指针
floata[]={3,4,5,6};
cvInitMatHeader(&mat,2,2,CV_32FC1, a);

-------这里是通过数组数据来创建CvMat

注意这里a和mat是同一个内存空间,a是在堆栈中因此会自动释放

方式四:克隆矩阵cvCloneMat(),该函数依据现有矩阵克隆一个矩阵,分配了独立的空间,需要使用cvReleaseMat()释放

注意:这里是克隆 所以不是同一个内存空间,所以要手动释放<包括方式一二>

(3)获取矩阵的相关属性

获取矩阵的数据类型:cvGetElemType

获取矩阵的维度(几维坐标):cvGetDims

获取矩阵在某一个坐标上的大小:cvGetDimSize

二维矩阵获取矩阵大小:cvGetSize

代码:

  int type = cvGetElemType(t); //得到CV_8U等
intsize[10];
//int dims =cvGetDims(t,size);
int dims =cvGetDims(t); // 得到维度
int x =cvGetDimSize(t,0); // 得到x维的大小
int y =cvGetDimSize(t,1);
CvSize size1 = cvGetSize(t); // 得到矩阵的大小

8:矩阵的维度和通道

我们通常用的矩阵维度都是2维的,而通道指BGR及alpha通道

(1)CvGet*D, CvSet*D----访问矩阵数据

cvGetReal*D,主要针对单通道

cvGet*D, 针对多通道

cvSet*D,也有相应的函数系列,不过这些函数的缺点是 效率低---有入栈出栈的操作

代码:

#include <iostream>
#include "cv.h"
#include <iostream>
#include "cv.h"
#include "cxcore.h"
#include "highgui.h"
using namespace std;
int main()
{
float a[18] = {
30,60,45,56,70,78,
90,80,94,89,87,91,
78,76,56,43,21,10
};
CvMatpmat;
cvInitMatHeader(&pmat,3, 2, CV_32FC3, a);
for(int y = 0; y <pmat.rows; y++)
{
for(int x = 0; x <pmat.cols; x++)
{
CvScalarvalue = cvGet2D(&pmat, y, x);
cout<< "(" << value.val[0]<< "," << value.val[1]<< "," << value.val[2]<< ")" << " ";
}
cout<< endl;
}
}

(2)使用指针来访问矩阵数据  ---效率较高

代码:----针对双通道

#include "cxcore.h"
#include "highgui.h"
using namespace std;
int main()
{
float a[18] = {
30,60,45,56,70,78,
90,80,94,89,87,91,
78,76,56,43,21,10
};
CvMatpmat;
cvInitMatHeader(&pmat,3, 3, CV_32FC2, a);
int nChannels = 2;
for(int y = 0; y <pmat.rows; y++)
{
float *p_float = (float*)(pmat.data.ptr + y * pmat.step);
for(int x = 0; x <pmat.cols; x++)
{
//float value = p_float[x]; /// 单通道矩阵的访问
float value[2];
value[0]= *(p_float + x * nChannels);
value[1]= *(p_float + x * nChannels + 1);
cout<< "(" << value[0]<< "," << value[1]<< ")" << " ";
}
cout<< endl;
} return 0;
}

作者:小村长  出处:http://blog.csdn.net/lu597203933
 欢迎转载或分享,但请务必声明文章出处。 (新浪微博:小村长zack, 欢迎交流!)

opencv学习_4(opencv基础数据结构 CvPoint & CvSize & CvRect & CvScalar & CvArr & CvMat)的更多相关文章

  1. opencv的基本数据类型CvPoint,CvSize,CvRect,CvScalar

    转自http://blog.csdn.net/gdut2015go/article/details/46301821 opencv的基本数据类型CvPoint,CvSize,CvRect,CvScal ...

  2. OpenCV学习(22) opencv中使用kmeans算法

    kmeans算法的原理参考:http://www.cnblogs.com/mikewolf2002/p/3368118.html 下面学习一下opencv中kmeans函数的使用.      首先我们 ...

  3. OpenCV学习笔记——OpenCV安装

    关于OpenCV安装 1.下载和安装OpenCV SDK 在官网:http://opencv.org/上找到OpenCV windows版下载 . 后得到一个 opencv-2.X.X.exe的文件, ...

  4. OpenCV学习(39) OpenCV中的LBP图像

    本章我们学习LBP图像的原理和使用,因为接下来教程我们要使用LBP图像的直方图来进行脸部识别. 参考资料: http://docs.opencv.org/modules/contrib/doc/fac ...

  5. OpenCV学习:OpenCV文件一览

    了解一些OpenCV代码整体的模块结构后,再重点学习自己感兴趣的部分,会有一种一览众山小的感觉~ Come on! C:\OpenCV\opencv\build\include文件夹下包含两个文件夹: ...

  6. OpenCV学习(3) OpenCV框架

          OpenCV是一个开源的视觉库,其中包括很多计算机视觉的算法实现.在版本2.2以后,OpenCV采用C++特征的API,在1.x版本中,OpenCV函数都是传统的C语言形式.       ...

  7. OpenCV学习(1) OpenCV的安装

    前沿 准备了好几天,终于开始了,不管怎样,接下来的这个月一定把这本书很好的啃下来.当然OpenCV可以在很多的IDE下安装与配置,我这里就只在VS2010和VC6.0下安装配置了,当然这篇博文主要讲在 ...

  8. OpenCV学习(35) OpenCV中的PCA算法

    PCA算法的基本原理可以参考:http://www.cnblogs.com/mikewolf2002/p/3429711.html     对一副宽p.高q的二维灰度图,要完整表示该图像,需要m = ...

  9. OpenCV学习:OpenCV源码编译(vc9)

    安装后的OpenCV程序下的build文件夹中,只找到了vc10.vc11和vc12三种编译版本的dll和lib文件,需要VS2010及以上的IDE版本,而没有我们常用的VS2008版本. 于是,需要 ...

随机推荐

  1. linux一些基本常识(三)

    acl:对本身权限的扩展    打包:zip 111.zip a.txt b.txt.....    zip -r /etc/sysconfig/* (样才能第归所有内容0)    解宝:uzip 1 ...

  2. WebDriverException: Message: f.QueryInterface is not a function

    WebDriverException: Message: f.QueryInterface is not a function 使用webdriver打开c.highpin.cn,结果报错,见下图: ...

  3. MATLAB安装libsvm无法使用解决办法(转)

    buaasuozi  这是原作者: 安装libsvm 不成功有可能是你的MATLAB版本或者是编译文件版本的问题,但是不要急着换其他版本....说不定就有别的解决办法呢 首先感谢Lin教授及其实验室提 ...

  4. 归并排序/合并排序c++实现

    #include <iostream>#include<string.h> using namespace std;class merges{public:void merge ...

  5. [leetcode]179. Largest Number最大数

    Given a list of non negative integers, arrange them such that they form the largest number. Input: [ ...

  6. Java中的NIO及IO

    1.概述 Java NIO(New IO) 是从Java 1.4版本开始引入的一个新的IO API,可以替代标准的Java IO API.NIO与原来的IO有同样的作用和目的,但是使用的方式完全不同, ...

  7. Paxos Made Simple

    Paxos一致性算法——分布式系统中的经典算法,论文本身也有一段有趣的故事.一致性问题是分布式系统的根本问题之一,在论文中,作者一步步的加强最初一致性问题(2.1节提出的问题)的约束条件,最终导出了一 ...

  8. struts2框架值栈的概述之问题一:什么是值栈?

    1. 问题一:什么是值栈? * 值栈就相当于Struts2框架的数据的中转站,向值栈存入一些数据.从值栈中获取到数据. * ValueStack 是 struts2 提供一个接口,实现类 OgnlVa ...

  9. 演示Spring框架的JDBC模板的简单操作

    1. 步骤一:创建数据库的表结构 create database spring_day03; use spring_day03; create table t_account( id int prim ...

  10. Electronic Trading[z]

    This article is to discuss the operation model between Fund Managers(Client) and Broker Firms. They ...