opencv图像灰化_Opencv——彩色图像灰度化的三种算法

为了加快处理速度在图像处理算法中,往往需要把彩色图像转换为灰度图像。24为彩色图像每个像素用3个字节表示,每个字节对应着RGB分量的亮度。

当RGB分量值不同时,表现为彩色图像;当RGB分量相同时,变现为灰度图像:

一般来说,转换公式有3中。

(1)Gray(i,j)=[R(i,j)+G(i,j)+B(i,j)]/3;

(2)Gray(i,j)=0.299*R(i,j)+0.587*G(i,j)+0.144*B(i,j);

(3)Gray(i,j)=G(i,j);//从2可以看出G的分量比较大所以可以直接用它代替

下面是代码:

#include

#include

using namespace cv;

using namespace std;

int main()

{

IplImage *img=cvLoadImage("D:\\Opencv\\Images\\lena.jpg");

IplImage* dest=cvCreateImage(cvGetSize(img),img->depth,);

cvNamedWindow("SourceImage");

cvNamedWindow("destinationImage");

uchar* data=(uchar*)img->imageData;

int step = img->widthStep/sizeof(uchar); //step即为上图的widthstep

int channels = img->nChannels; // 这个图片为3通道的

uchar b=,g=,r=;

for(int i=;iheight;i++)

for(int j=;jwidth;j++){

b=data[i*step+j*channels+]; // 此时可以通过更改bgr的值达到访问效果。

g=data[i*step+j*channels+];

r=data[i*step+j*channels+];

// ((char*)(dest->imageData + j*dest->widthStep))[i] =(b+r+g)/3;//(1)

//((char*)(dest->imageData + j*dest->widthStep))[i] =r*0.299+g*0.587+0.144*b;//(2)

((char*)(dest->imageData + j*dest->widthStep))[i] =g;//(3)

}

cvShowImage("SourceImage",img);

cvShowImage("destinationImage",dest);

cvWaitKey();

cvDestroyAllWindows();

cvReleaseImage(&img);

cvReleaseImage(&dest);

//i*step 当i=0 即为上图的第一行 为1就是第二行

//j*chanels+0 j*通道数当j=0为第一列的第0个通道->b

//j*channels+1 当j=1为第二列的第1个通道->g

}

原图片:

opencv图像灰化_Opencv——彩色图像灰度化的三种算法_第1张图片

算法1生成的灰度图:

opencv图像灰化_Opencv——彩色图像灰度化的三种算法_第2张图片

算法2生成的灰度图:

opencv图像灰化_Opencv——彩色图像灰度化的三种算法_第3张图片

算法3生成的灰度图:

opencv图像灰化_Opencv——彩色图像灰度化的三种算法_第4张图片

最短路问题的三种算法&;模板

最短路算法&模板 最短路问题是图论的基础问题.本篇随笔就图论中最短路问题进行剖析,讲解常用的三种最短路算法:Floyd算法.Dijkstra算法及SPFA算法,并给出三种算法的模板.流畅阅读本 ...

c语言求回文数的三种算法的描述

c语言求回文数的三种算法的描述 题目描述 注意:(这些回文数都没有前导0) 1位的回文数有0,1,2,3,4,5,6,7,8,9 共10个: 2位的回文数有11,22,33,44,55,66,77,8 ...

Java利用DES/3DES/AES这三种算法分别实现对称加密

转载地址:http://blog.csdn.net/smartbetter/article/details/54017759 有两句话是这么说的: 1)算法和数据结构就是编程的一个重要部分,你若失掉了 ...

c#数字图像处理(二)彩色图像灰度化,灰度图像二值化

为加快处理速度,在图像处理算法中,往往需要把彩色图像转换为灰度图像,在灰度图像上得到验证的算法,很容易移植到彩色图像上.24位彩色图像每个像素用3个字节表示,每个字节对应着R.G.B分量的亮度(红.绿 ...

内存分配---FF、BF、WF三种算法

动态分区分配是根据进程的实际需要,动态的为之分配内存空间.而在实现可变分区分配时,将涉及到分区分配中 所用的数据结构.分区分配算法和分区的分配与内存回收的过程. 分区分配中的数据结构:(1)描述空闲块 ...

RGB转灰度图的几种算法

https://blog.csdn.net/cool1949/article/details/6649429 方法一:    对于彩色转灰度,有一个很著名的心理学公式: Gray = R*0.299 ...

常见算法:C语言求最小公倍数和最大公约数三种算法

最小公倍数:数论中的一种概念,两个整数公有的倍数成为他们的公倍数,当中一个最小的公倍数是他们的最小公倍数,相同地,若干个整数公有的倍数中最小的正整数称为它们的最小公倍数,维基百科:定义点击打开链接 求 ...

C语言求最小公倍数和最大公约数三种算法(经典)

把以前写的一些经验总结汇个总,方便给未来的学弟学妹们做个参考! --------------------------永远爱你们的:Sakura 最小公倍数:数论中的一种概念,两个整数公有的倍数成为他们 ...

opencv 访问图像像素的三种方式

访问图像中的像素 访问图像像素有三种可行的方法方法一:指针访问指针访问访问的速度最快,Mat类可以通过ptr函数得到图像任意一行的首地址,同时,Mat类的一些属性也可以用到公有属性 rows和cols ...

随机推荐

ajax实现jsonp跨域接口

HTML页面代码:

Leetcode 270. Closest Binary Search Tree Value

Given a non-empty binary search tree and a target value, find the value in the BST that is closest t ...

Android_ViewPager

view1源代码及xml资源文件:

个人学习笔记--MyBatis官方推荐DAO开发方案

1.导入Jar包 2.编写全局配置文件configuration.xml

js 中创建对象

对象是什么 从JavaScript定义上讲对象是无序属性的集合,其属性可以包含基本值.对象或函数.也就是说对象是一组没有特定顺序的属性,每个属性会映射到一个值上,是一组键值对,值可以是数据或对象. 最 ...

c++动态内存管理

一.内存的简要了解 说到内存,很多人应该都多多少少有点了解了,我们在这再稍微多说几句: 一般我们可以把内存理解为三个部分:静态区,栈,堆.有些朋友搞不清到底什么是栈什么是堆,堆栈有多人会认为是堆和栈, ...

数据分析之Matplotlib和机器学习基础

一.Matplotlib基础知识 Matplotlib 是一个 Python 的 2D绘图库,它以各种硬拷贝格式和跨平台的交互式环境生成出版质量级别的图形. 通过 Matplotlib,开发者可以仅需 ...

Builder搭建外置服务器

如何利用HBuilder快速设置外部web服务器来测试移动web     HBuilder 关于HBuilder工具的简介:HBuilder是DCloud(数字天堂)推出的一款支持HTML5的Web开 ...

selenium case报错重新执行

在做web ui自动化的过程中,经常发现这样一种情况,执行时case报错啦,再重新执行一遍又成功了. 如果不解决这个问题,脚本稳定性就会变差,很让人蛋疼,怎么解决呢: 思路: 写一个装饰器,装饰在ca ...

学以致用十九-----shell脚本之引号

shell脚本中引号也是有讲究的. 可以分为单引号‘ ’,双引号“ ”和 反引号 ` ` 具体区别来看一个例子 输出结果 可得出结论 1. 单引号括起来的字符都作为普通字符出现,如第4,7,10,13 ...

你可能感兴趣的:(opencv图像灰化)