cvtColor()学习

1 CvtColor
2 Void cv::cvtColor(InputArray src,
3                         OutputArray dst,
4                         INT code,
5                         INT dstCn =0
6                         )
7     

将图像从一个颜色空间转换为另一个。

该函数将输入图像从一个颜色空间转换为另一个颜色空间。在从RGB颜色空间转换的情况下,应明确指定通道的顺序(RGB或BGR)。请注意,OpenCV中的默认颜色格式通常称为RGB,但实际上是BGR(字节相反)。因此,标准(24位)彩色图像中的第一个字节将为8位蓝色分量,第二个字节为绿色,第三个字节为红色。第四,第五和第六个字节将是第二个像素(蓝色,然后是绿色,然后是红色),依此类推。

R,G和B通道值的常规范围是:

  • 0到255为CV_8U图像
  • 0到65535的CV_16U图像
  • 0到1用于CV_32F图像

在线性变换的情况下,范围无关紧要。但是在非线性变换的情况下,输入RGB图像应该被归一化到适当的值范围,以获得正确的结果,例如RGB →L * u * v *转换。例如,如果您有一个32位浮点图像直接从8位图像转换而不进行任何缩放,那么它将具有0..255的值范围而不是该函数假定的0..1。所以,在调用cvtColor之前,您需要先将图像缩小:

1 img * = 1./255;
2 cvtColor(img,img,COLOR_BGR2Luv);

如果您使用cvtColor与8位图像,转换将有一些信息丢失。对于许多应用程序,这并不会引人注目,但建议在需要全部颜色的应用程序中使用32位图像,或者在操作之前转换图像然后转换。

如果转换添加了Alpha通道,其值将设置为相应通道范围的最大值:CV_8U为255,CV_16U为65535,CV_32F为1。

参数


SRC


输入图像:8位无符号,16位无符号(CV_16UC ...)或单精度浮点。


DST


输出与src相同大小和深度的图像。


code


颜色空间转换代码(见cv :: ColorConversionCodes)。


dstCn


目的地图像中的频道数; 如果参数为0,则从src和代码自动导出通道数。

也可以看看

Color conversions

例子:

camshiftdemo.cppedge.cppfacedetect.cppffilldemo.cpphoughcircles.cpphoughlines.cpplkdemo.cppwatershed.cpp

转换模式

RGB ? GRAY

RGB模式增加移除alpha通道、改变通道顺序、和16位RGB色彩模式(R5:G6:B5 或者 R5:G5:B5)的图像之间的转换、和灰度图之间的转换:

RGB[A] to Gray:Y←0.299?R+0.587?G+0.114?B

Gray to RGB[A]:R←Y,G←Y,B←Y,A←max(ChannelRange)

示例:

1 cvtColor(src, bwsrc, cv::COLOR_RGB2GRAY);

高级用法见cv::mixChannels

或者

cv::COLOR_BGR2GRAYcv::COLOR_RGB2GRAYcv::COLOR_GRAY2BGRcv::COLOR_GRAY2RGB

RGB ? CIE XYZ.Rec 709 with D65 white point

X, Y and Z cover the whole value range (in case of floating-point images, Z may exceed 1).what’s the meaning of this sentence?

用法见:

cv::COLOR_BGR2XYZcv::COLOR_RGB2XYZcv::COLOR_XYZ2BGRcv::COLOR_XYZ2RGB

RGB ? YCrCb JPEG (or YCC)

其中

Y, Cr, and Cb cover the whole value range.

用法见:

cv::COLOR_BGR2YCrCbcv::COLOR_RGB2YCrCbcv::COLOR_YCrCb2BGRcv::COLOR_YCrCb2RGB

RGB ? HSV

在8位和16位图像的情况下,R,G和B将转换为浮点格式并缩放以适合0到1的范围。

用法见:

cv::COLOR_BGR2HSVcv::COLOR_RGB2HSVcv::COLOR_HSV2BGRcv::COLOR_HSV2RGB

RGB ? HLS

In case of 8-bit and 16-bit images, R, G, and B are converted to the floating-point format and scaled to fit the 0 to 1 range.

用法见:

cv::COLOR_BGR2HLScv::COLOR_RGB2HLScv::COLOR_HLS2BGRcv::COLOR_HLS2RGB

RGB ? CIE L*a*b*

In case of 8-bit and 16-bit images, R, G, and B are converted to the floating-point format and scaled to fit the 0 to 1 range.

用法见:

cv::COLOR_BGR2Labcv::COLOR_RGB2Labcv::COLOR_Lab2BGRcv::COLOR_Lab2RGB

RGB ? CIE L*u*v*

In case of 8-bit and 16-bit images, R, G, and B are converted to the floating-point format and scaled to fit 0 to 1 range.

The above formulae for converting RGB to/from various color spaces have been taken from multiple sources on the web, primarily from the Charles Poynton site http://www.poynton.com/ColorFAQ.html

用法见:

cv::COLOR_BGR2Luvcv::COLOR_RGB2Luvcv::COLOR_Luv2BGRcv::COLOR_Luv2RGB

Bayer → RGB

The Bayer pattern is widely used in CCD and CMOS cameras. It enables you to get color pictures from a single plane where R,G, and B pixels (sensors of a particular component) are interleaved as follows:

The output RGB components of a pixel are interpolated from 1, 2, or 4 neighbors of the pixel having the same color. There are several modifications of the above pattern that can be achieved by shifting the pattern one pixel left and/or one pixel up. The two letters C and C in the conversion constants CV_Bayer C1C2 2BGR and CV_Bayer C1C2 2RGB indicate the particular pattern type. These are components from the second row, second and third columns, respectively. For example, the above pattern has a very popular "BG" type.

用法见:

cv::COLOR_BayerBG2BGRcv::COLOR_BayerGB2BGRcv::COLOR_BayerRG2BGRcv::COLOR_BayerGR2BGR,

cv::COLOR_BayerBG2RGBcv::COLOR_BayerGB2RGBcv::COLOR_BayerRG2RGBcv::COLOR_BayerGR2RGB

时间: 2024-10-18 05:21:40

cvtColor()学习的相关文章

OpenCV之Python学习笔记

OpenCV之Python学习笔记 直都在用Python+OpenCV做一些算法的原型.本来想留下发布一些文章的,可是整理一下就有点无奈了,都是写零散不成系统的小片段.现在看 到一本国外的新书<OpenCV Computer Vision with Python>,于是就看一遍,顺便把自己掌握的东西整合一下,写成学习笔记了.更需要的朋友参考. 阅读须知: 本文不是纯粹的译文,只是比较贴近原文的笔记:         请设法购买到出版社出版的书,支持正版. 从书名就能看出来本书是介绍在Pytho

卷积神经网络(CNN)学习算法之----基于LeNet网络的中文验证码识别

由于公司需要进行了中文验证码的图片识别开发,最近一段时间刚忙完上线,好不容易闲下来就继上篇<基于Windows10 x64+visual Studio2013+Python2.7.12环境下的Caffe配置学习 >文章,记录下利用caffe进行中文验证码图片识别的开发过程.由于这里主要介绍开发和实现过程,CNN理论性的东西这里作为介绍的重点,遇到相关的概念和术语请自行研究.目前从我们训练出来的模型来看,单字识别率接近96%,所以一个四字验证码的准确率大概80%,效果还不错,完全能满足使用,如果

Dlib+OpenCV深度学习人脸识别

目录(?)[+] DlibOpenCV深度学习人脸识别 前言 人脸数据库导入 人脸检测 人脸识别 异常处理 Dlib+OpenCV深度学习人脸识别 前言 人脸识别在LWF(Labeled Faces in the Wild)数据集上人脸识别率现在已经99.7%以上,这个识别率确实非常高了,但是真实的环境中的准确率有多少呢?我没有这方面的数据,但是可以确信的是真实环境中的识别率并没有那么乐观.现在虽然有一些商业应用如员工人脸识别管理系统.海关身份验证系统.甚至是银行人脸识别功能,但是我们可以仔细想

学习 opencv---(11)OpenC 边缘检测:Canny算子,Sobel算子,Laplace算子,Scharr滤波器

本篇文章中,我们将一起学习OpenCV中边缘检测的各种算子和滤波器--Canny算子,Sobel算子,Laplace算子以及Scharr滤波器.文章中包含了五个浅墨为大家准备的详细注释的博文配套源代码.在介绍四块知识点的时候分别一个,以及最后的综合示例中的一个.文章末尾提供配套源代码的下载. **** 给大家分享一个OpenCv中写代码是节约时间的小常识.其实OpenCv中,不用nameWindow,直接imshow就可以显示出窗口.大家看下文的示例代码就可以发现,浅墨在写代码的时候并没有用na

OpenCV中feature2D学习——FAST特征点检测

在前面的文章<OpenCV中feature2D学习--SURF和SIFT算子实现特征点检测>中讲了利用SIFT和SURF算子进行特征点检测,这里尝试使用FAST算子来进行特征点检测. FAST的全名是:Features from Accelerated Segment Test,主要特点值计算速度快,比已知的其他特征点检测算法要快很多倍,可用于计算机视觉应用的实时场景.目前以其高计算效率(computational performance).高可重复性(highrepeatability)成为

OpenCV2学习笔记(一):图像的基本操作

一直没有一个系统的时间来深入学习OpenCV,鉴于项目需要,记录一下一些要点以供日后查阅. OpenCV是一个基于(开源)发行的跨平台计算机视觉库,可以运行在Linux.Windows和Mac OS操作系统上.其1.0版本于2006年面世,而在2009年又发布了重要的版本:OpenCV2,带来了新的C++接口:现在,OpenCV3也发布了,据说其Python接口大大增强.并且加入了Python 3.x的支持,还带来了许多新的提升,不过这并不在这里的讨论范围之内.这里使用的是:OpenCV2.4.

学习Opencv 2.4.9 (一)---Opencv + vs2012环境配置

作者:咕唧咕唧liukun321 来自:http://blog.csdn.net/liukun321 首先获得最新的Opencv 2.4.9源码:opencv源码下载 一.Opencv环境变量配置 1.将源码安装到制定目录: 2.为Opencv 添加环境变量:计算机-->属性 点击高级系统设置 3.出来系统属性对话框后,点击环境变量. 4.弹出如下对话框:选中PATH 单击新建 5.点击新建添加环境变量 6.将opencv2.4.9变量包含到PATH中去 二.然后再看VS2012 的配置. 1.

Opencv学习之路—Opencv下基于HOG特征的KNN算法分类训练

在计算机视觉研究当中,HOG算法和LBP算法算是基础算法,但是却十分重要.后期很多图像特征提取的算法都是基于HOG和LBP,所以了解和掌握HOG,是学习计算机视觉的前提和基础. HOG算法的原理很多资料都可以查到,简单来说,就是将图像分成一个cell,通过对每个cell的像素进行梯度处理,进而根据梯度方向和梯度幅度来得到cell的图像特征.随后,将每个cell的图像特征连接起来,得到一个BLock的特征,进而得到一张图片的特征.Opencv当中自带HOG算法,可以直接调用,进行图像的特征提取.但

目标跟踪学习笔记1

首先提供几篇关于粒子滤波算法的博客:http://www.cnblogs.com/yangyangcv/archive/2010/05/23/1742263.html 这篇博客比较通俗易懂,简单的介绍了粒子滤波的基本工作思想和步骤.http://www.cnblogs.com/lwbaptx/archive/2011/10/20/2218419.html这篇博客用的是opencv1.0,实现的功能是用粒子滤波跟踪鼠标轨迹,有视频演示,效果还不错.http://blog.csdn.net/yang