图像处理之图像灰度化

目录

[1 图像灰度化简介](#1 图像灰度化简介)

[2 图像灰度化处理方法](#2 图像灰度化处理方法)

[2.1 均值灰度化](#2.1 均值灰度化)

[2.2 经典灰度化](#2.2 经典灰度化)

[2.3 Photoshop灰度化](#2.3 Photoshop灰度化)

[2.4 C语言代码实现](#2.4 C语言代码实现)

[3 演示Demo](#3 演示Demo)

[3.1 开发环境](#3.1 开发环境)

[3.2 功能介绍](#3.2 功能介绍)

[3.3 下载地址](#3.3 下载地址)

参考


1 图像灰度化简介

对于24位的RGB图像而言,每个像素用3字节表示,分别对应R、G、B三个分量。如果R、G、B三个分量的值不相同,那么表现出来就是彩色图像;如果三者的值相同,那么表现出来就是灰度图像。而一张彩色图像转换为灰度图像,就叫做图像灰度化。

灰度图像每个像素只需一个字节存放灰度值(又称强度值、亮度值),灰度范围为0-255,当灰度为255的时候,表示最亮(纯白);当灰度为0的时候,表示最暗(纯黑)。

灰度化的好处是:相较于彩色图像灰度图像占内存更小,运行速度更快;灰度图像后可以在视觉上增加对比,突出目标区域。

2 图像灰度化处理方法

图像灰度化处理有三种常用方法:均值灰度化、经典灰度化、Photoshop灰度化。

2.1 均值灰度化

均值灰度化,每个像素的灰度值为 R、G、B 分量的均值,也叫作明度灰度化。

Gray = ( R + G + B )/ 3

2.2 经典灰度化

经典灰度化,结合人眼对颜色的感应度,得到的一组比较适合的参数。

Gray = 0.299*R + 0.587*G + 0.114*B

2.3 Photoshop灰度化

Photoshop灰度化,即PS中的"去色"命令,是一种基于最大值和最小值的灰度化计算。

Gray =( max(R,G,B) + min(R,G,B) )/ 2

2.4 C语言代码实现

cpp 复制代码
/*************************************************
功    能:图像灰度化
参    数:srcData -  [输入/输出] 原始图像,格式为32位BGRA格式,执行后修为结果图像
         width    - [输入] 原始图像宽度
         height   - [输入] 原始图像高度
         stride   - [输入] 原始图像的Stride(也就是行字节数width*4)
         mode     - [输入] 0-均值灰度化,1-经典灰度化,2-PS灰度化
返    回:0-成功,其他-失败.
*************************************************/
int gray(unsigned char *srcData, int width, int height, int stride, int mode)
{
        int ret = 0;
        int i, j, gray, offset;
        offset = stride - width * 4;
        unsigned char* pSrc = srcData;
        switch (mode)
        {
        case 0://mean gray method
                for (j = 0; j < height; j++)
                {
                        for (i = 0; i < width; i++)
                        {
                                gray = (pSrc[0] + pSrc[1] + pSrc[2]) / 3;
                                pSrc[0] = gray;
                                pSrc[1] = gray;
                                pSrc[2] = gray;
                                pSrc += 4;
                        }
                        pSrc += offset;
                }
                break;
        case 1://classic gray method
                for (j = 0; j < height; j++)
                {
                        for (i = 0; i < width; i++)
                        {
                                gray = (299 * pSrc[2] + 587 * pSrc[1] + 114 * pSrc[0]) / 1000;
                                pSrc[0] = gray;
                                pSrc[1] = gray;
                                pSrc[2] = gray;
                                pSrc += 4;
                        }
                        pSrc += offset;
                }
                break;
        case 2://photoshop gray method
                for (j = 0; j < height; j++)
                {
                        for (i = 0; i < width; i++)
                        {
                                gray = (MAX2(pSrc[0], MAX2(pSrc[1], pSrc[2])) + MIN2(pSrc[0], MIN2(pSrc[1], pSrc[2]))) / 2;
                                pSrc[0] = gray;
                                pSrc[1] = gray;
                                pSrc[2] = gray;
                                pSrc += 4;
                        }
                        pSrc += offset;
                }
                break;
        default:
                break;
        }
        return ret;
};

3 演示Demo

3.1 开发环境

  • Windows 10 Pro x64

  • Visual Studio 2015

3.2 功能介绍

演示程序主界面如下图所示,具有图像读取、显示、保存、显示RGBA值、HSV调整、提取YUV分量、灰度化等功能。

原图

经典灰度化

3.3 下载地址

开发环境:

  • Windows 10 pro x64

  • Visual Studio 2015

下载地址:图像处理之图像灰度化Demo

参考

图像视频滤镜与人像美颜美妆算法详解. 胡耀武、谭娟、李云夕. 电子工业出版社、2020-07

相关推荐
Coding茶水间20 小时前
基于深度学习的无人机视角检测系统演示与介绍(YOLOv12/v11/v8/v5模型+Pyqt5界面+训练代码+数据集)
图像处理·人工智能·深度学习·yolo·目标检测·计算机视觉
程序员鱼皮1 天前
干掉 Draw.io,这个程序员画图神器杀疯了!
图像处理·计算机·程序员·软件开发·编程经验
民乐团扒谱机1 天前
【微实验】直方图均衡化:让光影重获新生的魔法,在明暗之间编织细节的诗篇
图像处理·opencv·计算机视觉
却相迎1 天前
2004-基于空间约束的模糊 C 均值聚类(FCM_S2)算法的图像分割
图像处理·聚类
c#上位机2 天前
halcon获取区域中心坐标以及面积——area_center
图像处理·计算机视觉·c#·halcon
Coding茶水间2 天前
基于深度学习的遥感地面物体检测系统演示与介绍(YOLOv12/v11/v8/v5模型+Pyqt5界面+训练代码+数据集)
图像处理·人工智能·深度学习·yolo·目标检测·计算机视觉
CoookeCola2 天前
离线视频水印清除工具:手动选定位置(ROI)与强制修复功能详解,支持命令行ROI定位
网络·图像处理·opencv·计算机视觉·开源·github·音视频
AI即插即用2 天前
即插即用系列 | CVPR 2024 FADC:频域自适应空洞卷积,完美解决语义分割“网格效应”
图像处理·人工智能·深度学习·目标检测·计算机视觉·视觉检测
song5012 天前
鸿蒙 Flutter 图像编辑:原生图像处理与滤镜开发
图像处理·人工智能·分布式·flutter·华为·交互
这张生成的图像能检测吗2 天前
(论文速读)基于高阶自适应曲线的视觉失衡缺陷多模态无监督图像增强方法CLIP-AE
图像处理·人工智能·计算机视觉·卷积神经网络·低照度图像增强