opencv判断灰化情况

目的

先说说理论:

在图像处理中,用RGB三个分量(R:Red,G:Green,B:Blue),即红、绿、蓝三原色来表示真彩色,R分量,G分量,B分量的取值范围均为0~255,比如电脑屏幕上的一个红色的像素点的三个分量的值分别为:255,0,0。

那么什么叫图片的灰度化呢?其实很简单,就是让像素点矩阵中的每一个像素点都满足下面的关系:R=G=B(就是红色变量的值,绿色变量的值,和蓝色变量的值,这三个值相等,"="的意思不是程序语言中的赋值,是数学中的相等),此时的这个值叫做灰度值。

这是理论,实际在Opencv中,灰度化就是单通道图了,因为RGB都一样了,没必要都存储了。

再说说具体目的:

目的就是判断一个图片是否灰化了。

网上,包括,AI上很多方法都不行。

分析

先把一张简单的图片进行灰化操作:

cpp 复制代码
void productGrayImage()
{
    cv::Mat image(10, 10, CV_8UC3);
    // 遍历图像的每个像素
    for (int x = 0; x < image.rows; ++x) {
        for (int y = 0; y < image.cols; ++y) {
            // 获取像素的指针
            cv::Vec3b& pixel = image.at<cv::Vec3b>(x, y);
            // 为BGR通道分别赋值
            pixel[0] = 255; // 蓝色通道 (B)
            pixel[1] = 9; // 绿色通道 (G)
            pixel[2] = 10;   // 红色通道 (R)
        }
    }
    image.at<cv::Vec3b>(0, 0)[0] = 255;
    image.at<cv::Vec3b>(0, 0)[1] = 255;
    image.at<cv::Vec3b>(0, 0)[2] = 255;
    printf("image.type=%d\n", image.type());
    // 显示图像
    cv::imshow("Colored Image", image);
    cv::cvtColor(image, image, cv::COLOR_BGR2GRAY);
    printf("image.type=%d\n", image.type());
    for (int x = 0; x < image.rows; ++x)
    {
        for (int y = 0; y < image.cols; ++y)
        {
            // 获取像素的指针
           int pixel = image.at<uchar>(x, y);
           printf("%d ",pixel);
        }
        printf("\n");
    }
//    cv::imwrite("gray.jpg", image);
    cv::imshow("gray Image", image);
    cv::imwrite("gray.bmp", image);
}

运行情况:

生成gray.bmp的情况:

下面判断是否灰化:

cpp 复制代码
void judgeGrayImageInfo(QString imagePath)
{
    //cv::Mat image = cv::imread(imagePath.toStdString(), cv::IMREAD_GRAYSCALE); // 加载图像
    QImage image = QImage(imagePath);
    qDebug()<<"image.colorCount="<<image.colorCount();
    qDebug()<<"image.format="<<image.format();
    cv::Mat mat = cv::imread(imagePath.toStdString()); // 加载图像
    qDebug()<<"mat.type="<<mat.type();
    for (int i = 0; i < mat.rows; i++)
    {
        for (int j = 0; j < mat.cols; j++)
        {
            if(mat.type() == 16)
            {
                cv::Vec3b pixel = mat.at<cv::Vec3b>(i, j);
                printf("%d,%d,%d ", pixel[0], pixel[1], pixel[2]);
            }
            else
            {
                int pixel = mat.at<uchar>(i, j);
                printf("%d ", pixel);
            }
        }
        printf("\n");
    }
    if (isGrayImage(mat)) {
        std::cout << "The image is grayscale." << std::endl;
    } else {
        std::cout << "The image is not grayscale." << std::endl;
    }
    cv::imshow("gray Image", mat);
    cv::Mat mats[3];
    split(mat,mats);
    cv::imshow("gray gray Image", mat);
    mat = mats[0];
    int uniqueColors = cv::countNonZero(mat);
     qDebug()<<"uniqueColors="<<uniqueColors;
     qDebug()<<"mat.type="<<mat.type();
     if(mat.type() == 0)
     {
         mat.at<uchar>(0, 1) = 255;
         mat.at<uchar>(0, 2) = 255;
     }
     for (int i = 0; i < mat.rows; i++)
     {
         for (int j = 0; j < mat.cols; j++)
         {
             if(mat.type() == 16)
             {
                 cv::Vec3b pixel = mat.at<cv::Vec3b>(i, j);
                 printf("%d,%d,%d ", pixel[0], pixel[1], pixel[2]);
             }
             else
             {
                 int pixel = mat.at<uchar>(i, j);
                 printf("%d ", pixel);
             }
         }
         printf("\n");
     }
}

运行情况:


可以见得,能正确判断是否灰化

总结

灰化是怎么判断的呢?

灰化图在opencv中是单通道图,但保存时,会转化成RGB模式的图。

所以,再加载,通过通道数,判断是否是灰度图,这样是不对的。

解决方法:

首先,一个图片在保存时,其实是以RGB模式保存的,这也是操作系统默认的保存方式。

那一个灰化图在保存时,会默认转化为RGB模式,怎么转化,其就是把一个灰化值重复为三份,分别对应RGB,这样就可以了。

如图所示:

知道这个情况了:

就知道如何判断一个图是否灰化了:

那就是:R=G=B就可以了。

具体代码见:

https://download.csdn.net/download/maokexu123/88862864

相关推荐
阿里云云原生4 分钟前
Qoder 全新「上下文压缩」功能正式上线,省 Credits !
人工智能
我星期八休息18 分钟前
深入理解跳表(Skip List):原理、实现与应用
开发语言·数据结构·人工智能·python·算法·list
蒋星熠27 分钟前
如何在Anaconda中配置你的CUDA & Pytorch & cuNN环境(2025最新教程)
开发语言·人工智能·pytorch·python·深度学习·机器学习·ai
Hcoco_me41 分钟前
什么是机器学习?
人工智能·机器学习
Code_流苏42 分钟前
AI热点周报(9.7~9.13):阿里Qwen3-Next震撼发布、Claude 增强记忆与服务抖动、OpenAI 聚焦模型规范化...
人工智能·gpt·ai·openai·claude·qwen3-next·架构创新
合作小小程序员小小店42 分钟前
机器学习介绍
人工智能·python·机器学习·scikit-learn·安全威胁分析
这张生成的图像能检测吗1 小时前
(综述)视觉任务的视觉语言模型
人工智能·计算机视觉·语言模型·自然语言处理·视觉语言模型
聚客AI1 小时前
🚫万能Agent兜底:当规划缺失工具时,AI如何自救
人工智能·llm·agent
Juchecar1 小时前
一文讲清 nn.Module 中 forward 函数被调用时机
人工智能
七牛云行业应用2 小时前
深度解析强化学习(RL):原理、算法与金融应用
人工智能·算法·金融