http://guoming.me/opencv-config  这篇文章有讲解opencv的安装与配置

一些常用库

  1. opencv_core249d.lib
  2. opencv_imgproc249d.lib
  3. opencv_highgui249d.lib
  4. opencv_ml249d.lib
  5. opencv_video249d.lib
  6. opencv_features2d249d.lib
  7. opencv_calib3d249d.lib
  8. opencv_contrib249d.lib
  9. opencv_legacy249d.lib
  10. opencv_flann249d.lib
  11. opencv_gpu249d.lib

一个测试程序

  1. <strong>#include <opencv2/core/core.hpp>
  2. #include <opencv2/highgui/highgui.hpp>
  3. #include <iostream>
  4.  
  5. using namespace cv;
  6. using namespace std;
  7.  
  8. </strong>int main()
  9. {
  10. Mat image;
  11. image = imread("D:\\lenargb.jpg", -1); // Read the file
  12.  
  13. if (!image.data) // Check for invalid input
  14. {
  15. cout << "Could not open or find the image" << std::endl;
  16. return -1;
  17. }
  18.  
  19. namedWindow("Display window", WINDOW_AUTOSIZE); // Create a window for display.
  20. imshow("Display window", image); // Show our image inside it.
  21.  
  22. waitKey(0); // Wait for a keystroke in the window
  23. return 0;
  24. }

Mat 类的一些属性

  1. //矩阵的维数,取值应该大于或等于 2
  2.  
  3. int dims;
  4.  
  5. //矩阵的行数和列数,如果矩阵超过 2 维,这两个变量的值都为-1
  6.  
  7. int rows, cols;
  8.  
  9. //指向数据的指针
  10.  
  11. uchar* data;<strong>
  12. </strong>

Mat 构造方法

  1. Mat M(3,2, CV_8UC3, Scalar(0,0,255));
  2.  
  3. cout << "M = " << endl << " " << M << endl;<strong>
  4. </strong>

第一行代码创建一个行数(高度)为 3,列数(宽度)为 2 的图像,图像元素是 8 位无符号整数类型,且有三个通道。图像的所有像素值被初始化为(0,  0,255)。由于 OpenCV 中默认的颜色顺序为 BGR,因此这是一个全红色的图像。

第二行代码是输出 Mat 类的实例 M 的所有像素值。 Mat 重定义了<<操作符,使用这个操作符,可以方便地输出所有像素值,而不需要使用 for 循环逐个像素输出

opencv中图像的通道数

基本上,描述一个像素点,如果是灰度,那么只需要一个数值来描述它,就是单通道。

如果一个像素点,有RGB三种颜色来描述它,就是三通道

windows的bmp有时候是一个四通道图像,R、G、B加上一个A通道,表示透明度。

最后这个,一般叫做alpha通道,表示透明度的。

初学只要知道单通道和三通道就好;

创建图像对象

Mat常用的构造函数:

Mat(int rows,int cols,int type,const scalar &s);

其中 rows 表示行数,cols表示列数,两者可以结合为Size size;

Type 可以是 CV_8UC1, CV_16SC1, …,CV_64FC4 等。里面的 8U 表示 8 位无符号整数,16S 表示 16 位有符号整数,64F表示 64 位浮点数(即 double 类型);C 后面的数表示通道数,例如 C1 表示一个通道的图像,C4 表示 4 个通道的图像,以此类推。

如果你需要更多的通道数,需要用宏 CV_8UC(n),例如:Mat M(3,2, CV_8UC(5));//创建行数为 3,列数为 2,通道数为 5 的图像

Scalar 可以设置通道里的像素值;可有可无。可以使用 Mat 类的 create()函数创建图像。

  1. #include <opencv2/core/core.hpp>
  2. #include <opencv2/highgui/highgui.hpp>
  3. #include <iostream>
  4.  
  5. using namespace cv;
  6. using namespace std;
  7.  
  8. int _tmain(int argc, _TCHAR* argv[])
  9. {
  10. Mat img(3, 2, CV_8UC3, Scalar(100, 100, 200));
  11. cout << "M=" << endl << " " << img << endl;
  12. img.create(3, 2, CV_8UC1);
  13. cout << "M=" << endl <<" "<< img << endl;
  14.  
  15. //imshow("嘿嘿", img);
  16. //waitKey();
  17. system("pause");
  18. return 0;
  19. }

遍历像素

(1)    at()函数  是个模版函数;需要指明元素类型

  1. #include <time.h>
  2. #include <iostream>
  3. #include "opencv2/opencv.hpp"
  4. //一般用这个头文件就可以,只不过可能会把大部分用不到的头文件引入进来;
  5. using namespace std;
  6. using namespace cv;
  7. int main(int argc, char* argv[])
  8. {
  9. srand(time(NULL));
  10. Mat grayim(600, 800, CV_8UC1);//600*800的灰度图;
  11. Mat colorim(600, 800, CV_8UC3);//600*800的彩色图;
  12. //遍历所有像素,并设置像素值;
  13. for (int i = 0; i < grayim.rows; ++i)//Mat的rows和cols属性是public的;
  14. for (int j = 0; j < grayim.cols; ++j)
  15. grayim.at<uchar>(i, j) = (i + j) % 255;
  16. //遍历所有像素,并设置像素值;
  17. for (int i = 0; i < colorim.rows; ++i)
  18. for (int j = 0; j < colorim.cols; ++j)
  19. {
  20. Vec3b pixel;//
  21. pixel[0] = i % 255; //Blue
  22. pixel[1] = j % 255; //Green
  23. pixel[2] = 0; //Red
  24. colorim.at<Vec3b>(i, j) = pixel;
  25. }
  26. //显示结果
  27. imshow("grayim", grayim);
  28. imshow("colorim", colorim);
  29.  
  30. waitKey(0);
  31. return 0;
  32. }

OpenCV 中有模板类 Vec,可以表示一个向量,用来表示彩色图像的一个像素;例如 8U 类型的 RGB 彩色图像可以使用 Vec3b,3 通道 float 类型的矩阵可以使用 Vec3f

  1. Vec3b color; //用 color 变量描述一种 RGB 颜色
  2.  
  3. color[0]=255; //B 分量
  4.  
  5. color[1]=0; //G 分量
  6.  
  7. color[2]=0; //R 分量

2)    使用STL库里的迭代器,

  1. <span style="font-size:14px;">#include <time.h>
  2. #include <iostream>
  3. #include "opencv2/opencv.hpp"
  4. //一般用这个头文件就可以,只不过可能会把大部分用不到的头文件引入进来;
  5. using namespace std;
  6. using namespace cv;
  7. int main(int argc, char* argv[])
  8. {
  9. srand(time(NULL));
  10. Mat grayim(600, 800, CV_8UC1);//600*800的灰度图;
  11. Mat colorim(600, 800, CV_8UC3);//600*800的彩色图;
  12. //遍历所有像素,并设置像素值;
  13. MatIterator_<uchar> graim_it, graim_end;
  14. MatIterator_<Vec3b> color_it, color_end;
  15. for (graim_it=grayim.begin<uchar>(),graim_end=grayim.end<uchar>(); graim_it!=graim_end; ++graim_it)
  16. {
  17. *graim_it = rand() % 255;
  18. }
  19. for (color_it = colorim.begin<Vec3b>(), color_end = colorim.end<Vec3b>(); color_it != color_end; color_it++)
  20. {
  21. (*color_it)[0] = rand() % 255;
  22. (*color_it)[1] = rand() % 255;
  23. (*color_it)[2] = 0;
  24.  
  25. }
  26. //显示结果
  27. imshow("grayim", grayim);
  28. imshow("colorim", colorim);
  29. waitKey(0);
  30. return 0;
  31. }</span>

如果想看全部内容 请移步我的博客园 http://www.cnblogs.com/dragonfive/p/4480224.html

opencv初体验的更多相关文章

  1. Swift与C++混编 OpenCV初体验 图片打码~

    OpenCV初体验,给图片打码 提到OpenCV,相信大多数人都听说过,应用领域非常广泛,使用C++开发,天生具有跨平台的优势,我们学习一次,就可以在各个平台使用,这个还是很具有诱惑力的.本文主要记录 ...

  2. OpenCV 初体验

    个人博客原文链接 个人掘金链接 本文简单地介绍计算机图形处理的一些基本概念,以及一些有趣的例子和对应的Open CV的代码操作. 顺便说一句,恭喜IG夺冠! 一.图片存储原理 1.颜色空间RGB (1 ...

  3. 痞子衡嵌入式:走进二维码(QR Code)的世界(2)- 初体验(PyQt5.11+MyQR2.3+ZXing+OpenCV4.2.0)

    大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家分享的是走进二维码(QR Code)的世界专题之初体验. 接上篇 <走进二维码(QR Code)的世界(1)- 引言> 继续更文,在 ...

  4. .NET平台开源项目速览(15)文档数据库RavenDB-介绍与初体验

    不知不觉,“.NET平台开源项目速览“系列文章已经15篇了,每一篇都非常受欢迎,可能技术水平不高,但足够入门了.虽然工作很忙,但还是会抽空把自己知道的,已经平时遇到的好的开源项目分享出来.今天就给大家 ...

  5. Xamarin+Prism开发详解四:简单Mac OS 虚拟机安装方法与Visual Studio for Mac 初体验

    Mac OS 虚拟机安装方法 最近把自己的电脑升级了一下SSD固态硬盘,总算是有容量安装Mac 虚拟机了!经过心碎的安装探索,尝试了国内外的各种安装方法,最后在youtube上找到了一个好方法. 简单 ...

  6. Spring之初体验

                                     Spring之初体验 Spring是一个轻量级的Java Web开发框架,以IoC(Inverse of Control 控制反转)和 ...

  7. Xamarin.iOS开发初体验

    aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAAKwAAAA+CAIAAAA5/WfHAAAJrklEQVR4nO2c/VdTRxrH+wfdU84pW0

  8. 【腾讯Bugly干货分享】基于 Webpack & Vue & Vue-Router 的 SPA 初体验

    本文来自于腾讯bugly开发者社区,非经作者同意,请勿转载,原文地址:http://dev.qq.com/topic/57d13a57132ff21c38110186 导语 最近这几年的前端圈子,由于 ...

  9. 【Knockout.js 学习体验之旅】(1)ko初体验

    前言 什么,你现在还在看knockout.js?这货都已经落后主流一千年了!赶紧去学Angular.React啊,再不赶紧的话,他们也要变out了哦.身旁的90后小伙伴,嘴里还塞着山东的狗不理大蒜包, ...

随机推荐

  1. 2013年arcgis培训

    关于开展“GIS空间分析及应用案例解析”培训班的通知   各企事业单位: 随着信息技术的发展,地理信息系统(简称GIS)产业异军突起,在国民经济各个行业中的应用日益广泛,物联网.智慧地球.3S技术等等 ...

  2. 【Linux/Ubuntu学习 13】ubuntu上好用的pdf软件okular

    step 1: 安装 sudo apt-get install okular step 2: 注释 按 F6 快捷方式打开注释功能,你会发现太神奇了. step 3: 中文配置 如果安装完成后中文显示 ...

  3. 重构2-Move Method(方法移动)

    重构同样非常简单,以至于人们并不认为这是一个有价值的重构.迁移方法(Move Method),顾名思义就是将方法迁移到合适的位置.在开始重构前,我们先看看一下代码: ) ) return 0.03; ...

  4. 表数据转换为insert语句

    /* 对象:导出物理表数据为Insert语句 描述:可以传递条件精确导出sql 加条件的前提是只知道相应的字段名及类型 */ from sysobjects where name ='proc_ins ...

  5. jsonp跨越请求百度搜索api 实现下拉列表提示

    题目来源: 最近在做百度IFE前端技术学院的题,然后有一题就是模拟百度搜索智能提示.题目是开源的,稍后给出地址. 因为博主没学过后端啊,欲哭无泪,所以不能实现后端模糊搜索,那如果前端ajax纯粹请求一 ...

  6. 面对一个“丢失了与用户“签订”的协议的修改”时进行的思考。

    对于上图中的gauge,将value与label之间的比例值调整了,调整为1:1.2.这意味着,在新系统中打开老报表,老报表中的这个gauge的value可能会比以前大,二者可能是用户厌恶的效果. 严 ...

  7. Part 2 Creating, altering and dropping a database

    A SQL Server database can be created, altered and dropped1. Graphically using SQL Server Management ...

  8. Part 8 Coalesce function in sql server

  9. Javascript之数据执行原理探究

    Javascript在Web服务器端执行原理: 1.客户端请求数据,即我们在上网时在地址栏中输入某个网址,浏览器接收到数据之后,向远程web服务器发送请求报文. 2.web服务器响应请求,web服务器 ...

  10. JS验证框架(exValidation)

    exValidation是一个前台校验框架 能够校验前台的常用的输入错误. 例如,必须输入,用户输入长度...... ----------------------------------------- ...