參考文章:http://www.cnblogs.com/tornadomeet/archive/2012/07/19/2599376.html

实验说明: (引用)

  本文主要讲一些opencv 2.0版本号后出现的Mat矩形类,主要是參考opencv自带doc目录下的tutiol教材。通过这次实验认为用Mat的话以下几点须要特别注意(在代码中能够体现出来):

1. 利用create函数又一次改变Mat数据在内存中的布局。

2. 注意多通道数据在Mat中事实上也是占一个元素的位置的。 
3. 学会多维Mat的创建方法。
4. 当Mat矩阵比較小时。学会直接赋值的方法,即用Mat_。
5. 掌握Mat矩阵内容输出到终端时的几种常见格式。

6. 注意假设vector是单独一维的话须要转换成Mat才干输出。多维的能够直接输出,比如vector里面存放的是点的话。
#include <iostream>
#include <opencv2/core/core.hpp>
#include <opencv2/highgui/highgui.hpp>
#include <opencv2/imgproc/imgproc.hpp> using namespace std;
using namespace cv; int demo_Mat()
{
int next_num = 1;
char tmp;
while(next_num<7)
{
cout<<"-------- "<<next_num<<" --------"<<endl;
waitKey(0); switch (next_num)
{
case 1:
{
Mat M( 2, 2, CV_8UC3, Scalar(0,255,0) );//事实上是2*6的矩阵,由于每一个元素有3个通道。 cout<<"create by using the constructor..."<<endl;
cout<<"M = \n "<<M<<endl; M.create( 4, 4, CV_8UC(2));//括号中面的2表示2通道
cout<< "create by using create function..."<<endl;
cout<<"M = \n "<<M<<endl;
break;
}//当case语句里面变量定义时,须要用括号括起来,否则会报错
case 2:
{
int sz[3] = {2, 2, 2};
Mat L( 3, sz, CV_8UC(1), Scalar::all(0) );
cout<< "create multidimensional matrix..."<<endl;
// cout<<"L = "<<L<<endl;此处不能打印出来,由于那仅仅适应二维数组
break;
}
case 3:
{
Mat E = Mat::eye(4, 4, CV_64F);
Mat O = Mat::ones(2, 3, CV_32F);
Mat Z = Mat::zeros(3, 3, CV_8UC1);
cout<< "using matlab stytle..."<<endl;
cout<<"E = \n "<<E<<endl;
cout<<"O = \n "<<O<<endl;
cout<<"Z = \n "<<Z<<endl;
break;
}
case 4:
{
Mat C =(Mat_<double>(3,3)<<0,-1,0,-1,5,-1,0,-1,0);//直接赋初始值的方法
Mat row_clone = C.row(1).clone();
cout<< "create 3*3 double-precision identity matrix..."<<endl;
cout<<"C = \n "<<C<<endl;
cout<<"row_clone = "<<row_clone<<endl;
break;
}
case 5:
{
Mat R = Mat( 3, 2, CV_8UC3 );
randu( R, Scalar::all(0), Scalar::all(255) );
cout<< "fill a matrix with rand numbers..."<<endl;
cout<<"R (default) = "<<R<<endl;
cout<< "demonstrate the output formating options..."<<endl;
cout<<"R (python) = \n "<<format(R, "python")<<endl;
cout<<"R (numpy) = \n "<<format(R, "numpy")<<endl;//numpy是一个用python实现的科学计算包
cout<<"R (csv) = \n "<<format(R, "csv")<<endl;//csv,逗号分隔符
cout<<"R (c) = \n " <<format(R, "C")<<endl;
break;
}
case 6:
{
cout<< "the point format output..."<<endl; Point2f P1(5, 1);
cout<<"Point (2D) = "<<P1<<endl; Point3f P2(4, 5, 6);
cout<<"Point (3D) = "<<P2<<endl; vector<float>v;
v.push_back( (float)CV_PI);
v.push_back( 2 );//push_back为在其尾部增加一个数据
v.push_back( 3.01f );
cout<<"vector of float: = "<<Mat(v)<<endl;//vector数据是没法单独输出的,因此能够借助mat输出 int N = 20;
vector<Point2f>vPoints(N);//vector能够用变量定义其长度。比数组好用
for( size_t E = 0; E < vPoints.size(); ++E ) //size_t事实上就是一个unsigned int类型
vPoints[E] = Point2f((float)(E*5), (float)(E%7));
cout<<"vPoints[] = \n"<<vPoints<<endl;//可是vector点确实能够直接输出的。由于这时候的vector本身就是
//一个多维(至少2维)Mat了
break;
}
default:
break;
}
next_num++;
}
return 0;
}

执行结果:

OpenCV基本图像容器Mat的几种创建方法的更多相关文章

  1. pandas-01 Series()的几种创建方法

    pandas-01 Series()的几种创建方法 pandas.Series()的几种创建方法. import numpy as np import pandas as pd # 使用一个列表生成一 ...

  2. RealSense开发-Session和SenseManager的几种创建方法

    从Intel RealSense 的SDK文档对其架构(如图1所示)的始描述可知,Session是SDK应用的主控模块,必须在所有模块操作之前创建,并且在所有模块注销后最后注销.SenseManage ...

  3. OpenCV中图像以Mat类型保存时各通道数据在内存中的组织形式及python代码访问各通道数据的简要方式

    以最简单的4 x 5三通道图像为例,其在内存中Mat类型的数据组织形式如下: 每一行的每一列像素的三个通道数据组成一个一维数组,一行像素组成一个二维数组,整幅图像组成一个三维数组,即: Mat.dat ...

  4. Java 数组的三种创建方法

    public static void main(String[] args) { //创建数组的第一种方法 int[] arr=new int[6]; int intValue=arr[5]; //S ...

  5. Java 数组的三种创建方法,数组拷贝方法

    public static void main(String[] args) {//创建数组的第一种方法int[] arr=new int[6];int intValue=arr[5];//Syste ...

  6. JavaScript 对象的几种创建方法

    /** * Created by 2016 on 2016/6/4. */ function Box(){ var obj = new obj(); obj.name = "Lee" ...

  7. OpenCV MAT基本图像容器

    参考博客: OpenCv中cv::Mat和IplImage,CvMat之间的转换 Mat - 基本图像容器 Mat类型较CvMat和IplImage有更强的矩阵运算能力,支持常见的矩阵运算(参照Mat ...

  8. Js基础知识4-函数的三种创建、四种调用(及关于new function()的解释)

    在js中,函数本身属于对象的一种,因此可以定义.赋值,作为对象的属性或者成为其他函数的参数.函数名只是函数这个对象类的引用. 函数定义 // 函数的三种创建方法(定义方式) function one( ...

  9. 几种创建XMLHttpRequest对象的方法

    XMLHttpRequest对象,也就是Ajax交互的核心对象. 这里列举三种创建Ajax对象的方法. 第一种: <!DOCTYPE html> <html> <head ...

随机推荐

  1. 如何用 CSS 创作一个立体滑动 toggle 交互控件

    效果预览 在线演示 按下右侧的"点击预览"按钮在当前页面预览,点击链接全屏预览. https://codepen.io/zhang-ou/pen/zjoOgX 可交互视频教程 此视 ...

  2. Nginx Location和Rewrite总结

    Nginx 版本:nginx/1.10.3 (Ubuntu) Location 部分: 第一步:创建Nginx 虚拟主机 Nginx 安装成功安装并且可以运行之后,在 /etc/nginx 目录下创建 ...

  3. 使用SqlParameter.SqlDbType和SqlParameter.Size时需要注意的地方

    1.DbParameter类是SqlParameter和OracleParameter类的父类.DbParameter.Size用来获取或设置列中数据的最大尺寸(只对文本数据有用). 2.数据类型Ch ...

  4. hdu 2295 dlx重复覆盖+二分答案

    题目大意: 有一堆雷达工作站,安放至多k个人在这些工作站中,找到一个最小的雷达监控半径可以使k个工作人所在的雷达工作站覆盖所有城市 二分半径的答案,每次利用dlx的重复覆盖来判断这个答案是否正确 #i ...

  5. POJ 2553 The Bottom of a Graph 【scc tarjan】

    图论之强连通复习开始- - 题目大意:给你一个有向图,要你求出这样的点集:从这个点出发能到达的点,一定能回到这个点 思路:强连通分量里的显然都可以互相到达 那就一起考虑,缩点后如果一个点有出边,一定不 ...

  6. bzoj 1703 [Usaco2007 奶牛排名 传递闭包

    [Usaco2007 Mar]Ranking the Cows 奶牛排名 Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 504  Solved: 343[ ...

  7. CodeForces - 750B New Year and North Pole

    http://codeforces.com/problemset/problem/750/B 模拟题 审题 在南极点 只能向北走(不能向 南 东 西) 所以也就不存在走过南极点的情况 北极点同样 然后 ...

  8. Borg Maze-POJ3026(bfs+最小生成树)

    http://poj.org/problem?id=3026 如果一个一个普通搜处理不好的话会超时  可以连到一块搜 我觉得这个方法特别好 #include<stdio.h> #inclu ...

  9. POJ 1724 【存在附加约束的最短路问题】【优先队列】

    题意:给K个权值.给含有N个点,R条单向边的图. 每条边都有两个权值,其中一个路长,另外一个是附加权值. 要求路的附加权值之和不超过K的情况下求最短路. 思路: 自己的思路太狭隘,这题还是看了大牛的思 ...

  10. 寒武纪camp Day3

    补题进度:9/10 A(多项式) 题意: 在一个长度为n=262144的环上,一个人站在0点上,每一秒钟有$\frac{1}{2}$的概率待在原地不动,有$\frac{1}{4}$的概率向前走一步,有 ...