如何区别一幅图像是否是黑白图像

简介:

这篇文章的思路是很清晰的,但是个人觉得这样判断太耗时,在实际做工程的时候完全可以多判断一些样本点来节约时间


其实按理说这并不是一件困难的工作,但是由于种种原因,在OpenCV中读取的黑白图像并不是我们想像的只有一个通道,而是3通道的。但是当我们使用Mat image = imread("D:/picture/images/baboon2.jpg",0);之后,不论是彩色图像还是黑白图像都会转换为单通道。明白了这个之后,我们的程序就简单了:

[cpp]  view plain copy
  1. #include <opencv2/core/core.hpp>  
  2. #include <opencv2/highgui/highgui.hpp>  
  3. #include <iostream>  
  4. using namespace cv;  
  5. int main()  
  6. {  
  7.     //Mat image = imread("D:/picture/images/baboon2.jpg",0);  
  8.     //Mat image = imread("D:/picture/images/baboon2.jpg");  
  9.     //Mat image = imread("D:/picture/images/binary.bmp");  
  10.     Mat image = imread("D:/picture/image.png");  
  11.   
  12.   
  13.     if(!image.data)  
  14.         return -1;  
  15.       
  16.     int row = image.rows;  
  17.     int col = image.cols;  
  18.     int cnt= 0;  
  19.     for(int i = 0; i < row;i++)  
  20.     {  
  21.         for(int j = 0; j<col;j++)  
  22.         {  
  23.             if(image.channels() ==3)  
  24.             {  
  25.   
  26.                   
  27.                 if( (int)(image.at<Vec3b>(i,j)[0]) != 0 &&  (int)(image.at<Vec3b>(i,j)[0]) != 255 &&   
  28.                     (int)(image.at<Vec3b>(i,j)[1]) != 0 &&  (int)(image.at<Vec3b>(i,j)[1]) != 255 &&   
  29.                     (int)(image.at<Vec3b>(i,j)[2]) != 0 &&  (int)(image.at<Vec3b>(i,j)[2]) != 255)  
  30.                 {  
  31.                     cnt++;  
  32.                 }  
  33.                   
  34.             }  
  35.             else if(image.channels() ==1)  
  36.             {  
  37.                 if((int)(image.at<uchar>(i,j)) != 0 &&  (int)(image.at<uchar>(i,j)) != 255)  
  38.                 {  
  39.                     cnt++;  
  40.                 }  
  41.             }  
  42.         }  
  43.     }  
  44.     if(cnt == 0)  
  45.     {  
  46.         std::cout<<"这是黑白图像"<<std::endl;  
  47.     }  
  48.     else  
  49.     {  
  50.         std::cout<<"这是不是黑白图像"<<std::endl;  
  51.     }  
  52.       
  53.     //显示图像以验证结果  
  54.     imshow("图像",image);  
  55.     waitKey(0);  
  56.     return 0;  
  57. }  


只需要判断每个像素值是否为0或者255就行了,如果都不是,那么就不是黑白图像。

相关文章
|
9月前
|
存储 算法 计算机视觉
【OpenCV图像处理8】图像轮廓
【OpenCV图像处理8】图像轮廓
214 0
|
5月前
|
计算机视觉
[Halcon&图像] 彩色图转灰度图处理
[Halcon&图像] 彩色图转灰度图处理
46 1
|
5月前
[Halcon&图像] 图像、区域和轮廓相互转化
[Halcon&图像] 图像、区域和轮廓相互转化
94 1
|
10月前
|
机器学习/深度学习 存储 编解码
|
10月前
|
机器学习/深度学习 存储 编解码
|
10月前
|
机器学习/深度学习 存储 编解码
底层视觉与黑白图像上色
底层视觉(即视觉增强)是计算机视觉中的一个分支,它专注于提高图像整体的观看体验。如果 “中高层视觉” 关注的是如何让计算机理解图像中的内容,那么底层视觉则致力于解决图像的清晰度、色彩、时序等各类画质问题。这些问题的出现与拍摄环境、设备等因素有关,而视觉增强技术则旨在修复这些问题,提供更好的视觉观看体验。
|
11月前
图像的点运算1
图像的点运算1
|
前端开发 数据可视化
【视觉基础篇】13 # 如何给简单的图案添加纹理和复杂滤镜?
【视觉基础篇】13 # 如何给简单的图案添加纹理和复杂滤镜?
65 0
【视觉基础篇】13 # 如何给简单的图案添加纹理和复杂滤镜?
|
C#
c#实现图片二值化例子(黑白效果)
C#将图片2值化示例代码,原图及二值化后的图片如下: 原图: 二值化后的图像: 实现代码: ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 2...
1871 0
|
算法 C#
图像滤镜艺术---图像光照效果滤镜
原文:图像滤镜艺术---图像光照效果滤镜     图像光照滤镜     图像光照提滤镜主要是模拟阳光照射下的图像效果,通常使用在暗光环境下拍摄的照片中,或者是没有太阳的日景照片中。
1088 0