Opencv图像处理:判断图片里某个颜色值占的比例

简介: Opencv图像处理:判断图片里某个颜色值占的比例

一、功能

这里的需求是,判断摄像头有没有被物体遮挡。这里只考虑用手遮挡---->判断黑色颜色的范围。

二、使用OpenCV的Mat格式图片遍历图片

下面代码里,传入的图片的尺寸是640*480,判断黑色范围。

/*
在图片里查找指定颜色的比例
*/
int Widget::Mat_color_Find(QImage qimage)
{
     Mat image = QImage2cvMat(qimage);//将图片加载进来
     int num = 0;//记录颜色的像素点
     float rate;//要计算的百分率
     //遍历图片的每一个像素点
     for(int i = 0; i < image.rows;i++) //行数
     {
         for(int j = 0; j <image.cols;j++)   //列数
         {
             //对该像素是否为指定颜色进行判断 BGR 像素点
             //OpenCV 中 MAT类的默认三原色通道顺序BGR
             /*
            动态地址访问像素语法:image.at<Vec3b>(i,j)[0]、image.at<uchar>(i, j)
            访问三通道图像的单个像素:
            int b = image.at<Vec3b>(i, j)[0];
            int g = image.at<Vec3b>(i, j)[1];
            int r = image.at<Vec3b>(i, j)[2];
            对于三通道图像,每个像素存储了三个值,分别为蓝色、绿色、红色通道上的数值。
            int gray_data = image.at<uchar>(i, j);
            用来访问灰度图像的单个像素。对于灰度图像,每个像素只存储一个值
            */
             if((image.at<Vec3b>(i, j)[0] <= 120 &&
                 image.at<Vec3b>(i, j)[1] <= 120 &&
                 image.at<Vec3b>(i, j)[2] <= 120))
             {
                 num++;
             }
         }
     }
     rate = (float)num / (float)(image.rows * image.cols);
     //阀值为 0.249255 表示为全黑
     if(rate>0.20)
     {
           qDebug()<<":Mat:故意遮挡摄像头";
     }
     qDebug()<<"Mat:比例"<<rate;
     return 0;
}
Mat Widget::QImage2cvMat(QImage image)
{
    Mat mat;
    switch(image.format())
    {
    case QImage::Format_ARGB32:
    case QImage::Format_RGB32:
    case QImage::Format_ARGB32_Premultiplied:
        mat = Mat(image.height(), image.width(), CV_8UC4, (void*)image.constBits(), image.bytesPerLine());
        break;
    case QImage::Format_RGB888:
        mat = Mat(image.height(), image.width(), CV_8UC3, (void*)image.constBits(), image.bytesPerLine());
        cvtColor(mat, mat, CV_BGR2RGB);
        break;
    case QImage::Format_Indexed8:
        mat = Mat(image.height(), image.width(), CV_8UC1, (void*)image.constBits(), image.bytesPerLine());
        break;
    }
    return mat;
}

三、使用QImage遍历像素点

/*
在图片里查找指定颜色的比例
*/
int Widget::qimage_color_Find(QImage qimage)
{
    int num = 0;//记录颜色的像素点
    float rate;//要计算的百分率
    quint8 r,g,b;
    //遍历图片的每一个像素点
    for(int i = 0; i < qimage.height();i++) //行数
    {
        for(int j = 0; j <qimage.width();j++)   //列数
        {
            QRgb rgb=qimage.pixel(j,i);
            r=qRed(rgb);
            g=qGreen(rgb);
            b=qBlue(rgb);
            if((r <= 120 && g <= 120 && b <= 120))
            {
                num++;
            }
        }
    }
    rate = (float)num / (float)(qimage.height() * qimage.width());
    //阀值为 0.99777 表示为全黑
    if(rate>0.60)
    {
          //qDebug()<<"qimage:故意遮挡摄像头";
    }
    qDebug()<<"qimage:比例:"<<rate;
    return 0;
}

目录
相关文章
|
1月前
|
计算机视觉
Opencv学习笔记(十二):图片腐蚀和膨胀操作
这篇文章介绍了图像腐蚀和膨胀的原理、作用以及使用OpenCV实现这些操作的代码示例,并深入解析了开运算和闭运算的概念及其在图像形态学处理中的应用。
109 1
Opencv学习笔记(十二):图片腐蚀和膨胀操作
|
2月前
|
算法 计算机视觉
基于qt的opencv实时图像处理框架FastCvLearn实战
本文介绍了一个基于Qt的OpenCV实时图像处理框架FastCvLearn,通过手撕代码的方式详细讲解了如何实现实时人脸马赛克等功能,并提供了结果展示和基础知识回顾。
104 7
基于qt的opencv实时图像处理框架FastCvLearn实战
|
1月前
|
计算机视觉 Python
Opencv学习笔记(二):如何将整个文件下的彩色图片全部转换为灰度图
使用OpenCV库将一个文件夹内的所有彩色图片批量转换为灰度图,并提供了相应的Python代码示例。
31 0
Opencv学习笔记(二):如何将整个文件下的彩色图片全部转换为灰度图
|
1月前
|
计算机视觉 Python
Opencv学习笔记(一):如何将得到的图片保存在指定目录以及如何将文件夹里所有图片以数组形式输出
这篇博客介绍了如何使用OpenCV库在Python中将图片保存到指定目录,以及如何将文件夹中的所有图片读取并以数组形式输出。
132 0
Opencv学习笔记(一):如何将得到的图片保存在指定目录以及如何将文件夹里所有图片以数组形式输出
|
1月前
|
计算机视觉
Opencv错误笔记(一):通过cv2保存图片采用中文命名出现乱码
在使用OpenCV的cv2模块保存带有中文命名的图片时,直接使用cv2.imwrite()会导致乱码问题,可以通过改用cv2.imencode()方法来解决。
126 0
Opencv错误笔记(一):通过cv2保存图片采用中文命名出现乱码
|
3月前
|
计算机视觉 Windows Python
windows下使用python + opencv读取含有中文路径的图片 和 把图片数据保存到含有中文的路径下
在Windows系统中,直接使用`cv2.imread()`和`cv2.imwrite()`处理含中文路径的图像文件时会遇到问题。读取时会返回空数据,保存时则无法正确保存至目标目录。为解决这些问题,可以使用`cv2.imdecode()`结合`np.fromfile()`来读取图像,并使用`cv2.imencode()`结合`tofile()`方法来保存图像至含中文的路径。这种方法有效避免了路径编码问题,确保图像处理流程顺畅进行。
321 1
|
4月前
|
计算机视觉 Python
opencv识别颜色
opencv识别颜色
|
1月前
|
Serverless 计算机视觉
语义分割笔记(三):通过opencv对mask图片来画分割对象的外接椭圆
这篇文章介绍了如何使用OpenCV库通过mask图像绘制分割对象的外接椭圆。首先,需要加载mask图像,然后使用`cv2.findContours()`寻找轮廓,接着用`cv2.fitEllipse()`拟合外接椭圆,最后用`cv2.ellipse()`绘制椭圆。文章提供了详细的代码示例,展示了从读取图像到显示结果的完整过程。
45 0
语义分割笔记(三):通过opencv对mask图片来画分割对象的外接椭圆
|
1月前
|
机器学习/深度学习 算法 计算机视觉
【Python篇】Python + OpenCV 全面实战:解锁图像处理与视觉智能的核心技能
【Python篇】Python + OpenCV 全面实战:解锁图像处理与视觉智能的核心技能
68 2
|
3月前
|
计算机视觉 C++
基于VS2019和Opencv4,对hsv颜色空间的图像分割原理以及实现
这篇文章介绍了基于HSV颜色空间的图像分割原理,包括HSV模型的基本概念和如何在OpenCV中通过设置HSV的色彩范围来实现图像中特定颜色的物体分割,并通过示例代码展示了在静态图像和视频流中进行颜色分割的方法。
基于VS2019和Opencv4,对hsv颜色空间的图像分割原理以及实现