Opencv 读取灰度图像会识别为3通道问题

最近初接触图像cv,一切都是从零开始因此遇到了许多问题,故在此记录遇到的问题方便提醒自己也方便后来人不再困惑。


场景:

我们都知道灰度图或者红外图都是单通道图片,而彩色图片是三通道图片。但是当我们用img.shape读取灰度图/红外图片的时候返回的却是三通道结果:

import cv2

img_path = r'灰度图'
img = cv2.imread(img_path)
print(img.shape) 

# 如果我将图片灰度处理
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
print(gray.shape)

"""
img.shape返回的结果:
(201, 190, 3)
gray.shape返回的结果:
(201, 190)
"""

问题在于我们直接用opencv 读取图片时似乎都是三通道图片,只有在灰度处理后才回显示单通道。针对这一问题我查了些资料:

opencv在默认情况下会读取3个通道的图像,如果是灰度图/红外图片则会将其图层复制三次(BGR缺省,B==G==R),因此读出来的图片是三通道。


解决:

如果我们想一开始就按照单通道读取灰度图片/红外图片的话,可以在imread()函数中加入相关参数(cv2.IMREAD_GRAYSCALE):

import cv2

img_path = r'灰度图'
img = cv2.imread(img_path, cv2.IMREAD_GRAYSCALE)
print(img.shape)

"""
img.shape返回的结果:
(201, 190)
"""

 这样就会直接按照单通道的方式读取。


需求:

现有一堆彩色图与灰度图混合文件,要求将其分类。

 

// 借助PIL库, mode为L时即为8位灰度图
Image.mode == 'L' 

"""
拓展 
1.  mode==1: 位图,像素1位
2.  mode=='L': 灰度图,像素8位
3.  mode=='I': 像素Int32
4.  mode=='F': 像素float32
5.  mode=='P': 8位,映射为其他模式
6.  mode=='RGB': 真色彩,3通道
7.  mode=='RGBA': 4通道,加透明度
8.  mode=='CMYK': 印刷,4通道
9.  mode=='YCbCr': 亮色分离,3通道

"""

在不考虑效率的情况下,我用这种方式处理:

// 不推荐这个方法,推荐用上面的方法。这里感谢评论区“SNOWsama”的指教。
def handle_img(file_path):
    for img_path in sorted(glob.glob(file_path + "/*.jpg")):
        print("正在处理:" , img_path)
        img = Image.open(img_path)
        pix = img.convert('RGB')
        width = img.size[0]
        height = img.size[1]
        ir = 0
        hd = 0
        for x in range(width):
            for y in range(height):
                r,g,b = pix.getpixel((x,y))
                r = int(r)
                g = int(g)
                b = int(b)
                if r==g==b:
                    ir += 1
                else:
                    hd += 1
        if ir > hd:
            # 此图片为灰度图
        else:
            # 此图片为彩色图

注: 此小脚本在我的场景下实现了图片分类,但是尚未大范围测试。该方法只是起到抛砖引玉的作用启发观看者。

  • 18
    点赞
  • 55
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
### 回答1: OpenCvSharp是一个基于OpenCV的C#编程库,它提供了许多图像处理和计算机视觉功能。其中,图像灰度是一种非常基本的处理方法。 图像灰度是指将彩色图像转换为灰度图像的过程。在图像灰度处理中,每个像素的RGB值被替换为一个单一的亮度值,这个值表示像素的加权平均值,其中不同颜色的加权系数可能不同。 例如,当一个像素的原始RGB值为(120,150,200),并且所选的加权系数为0.299,0.587和0.114(这些系数与人眼感知的亮度有关),该像素的灰度值为(0.299*120+0.587*150+0.114*200)=157.7。 在OpenCvSharp中进行图像灰度处理非常简单,只需使用以下代码: Mat src = Cv2.ImRead("image.jpg"); Mat gray = new Mat(); Cv2.CvtColor(src, gray, ColorConversionCodes.BGR2GRAY); Cv2.ImShow("Gray image", gray); Cv2.WaitKey(0); 以上代码从文件读取图像,将其转换为灰度图像,并将其显示在窗口中。Cv2.CvtColor函数用于将图像从BGR颜色空间转换为灰度颜色空间。 总之,OpenCvSharp提供了简便易行的方法来进行图像灰度处理,使得使用OpenCV进行图像处理变得更加方便。 ### 回答2: OpenCVSharp是一个基于C#开发的计算机视觉库。该库可以对图像进行各种操作,包括灰度化处理。 在数字图像处理的领域中,灰度化是最常用的一种预处理方式。灰度化是将彩色图像转换为灰度图像的过程。在灰度图像中,每个像素点的灰度值只有一个数值,它代表了该像素点的亮度值。 在OpenCVSharp中,要进行灰度化处理,首先需要对图像进行读取。可以借助Mat类实现图像读取功能。 然后,可以使用CV方法中的CvtColor()函数将彩色图像转换为灰度图像。其中,需要指定转换的代码,即从BGR色彩空间到灰度色彩空间的转换方法。 以下是一个简单的示例代码,可以将彩色图像转换为灰度图像: ```C# using (Mat src = Cv2.ImRead("lena.jpg", ImreadModes.Color)) { Mat gray = new Mat(); Cv2.CvtColor(src, gray, ColorConversionCodes.BGR2GRAY); Cv2.ImWrite("lena_gray.jpg", gray); } ``` 同时,需要注意的是,灰度化处理只是数字图像处理的起始步骤,在实际应用中还需要进行更多的图像处理和分析操作。 ### 回答3: OpenCVSharp 是一款基于 OpenCV 库的 C# 开源图像处理库,可以实现图像的灰度化操作。图像灰度化是指将图像转化为只有黑白两种颜色的灰度图像,也称为黑白转换。 在 OpenCVSharp 中,可以使用 cvtColor() 函数进行图像的颜色空间转换,从而实现图像的灰度化。该函数的调用方法如下: Cv2.CvtColor(src, dst, ColorConversionCodes.BGR2GRAY); 其中,src 表示源图像,dst 表示转换后的目标图像,BGR2GRAY 表示将 BGR 格式的彩色图像转换为灰度图像。 经过灰度化处理后,图像中的每个像素只有一个灰度值,该值表示该点的亮度。灰度化操作可以降低图像数据的维度,同时能够去除图像中的颜色信息,使得图像更便于处理和分析。 在实际应用中,灰度化操作常常用于图像处理中的前置步骤,例如在图像识别和目标检测中,灰度化操作可以减少计算量,提高算法效率。此外,灰度化操作也适用于图像压缩、美化和增强等领域。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值