【OpenCV 例程200篇】209. HSV 颜色空间的图像分割

OpenCV 例程200篇 总目录


【youcans 的 OpenCV 例程200篇】209. HSV 颜色空间的彩色图像分割

5.1 HSV 颜色空间的彩色图像分割

HSV 模型是针对用户观感的一种颜色模型。

HSV 颜色空间的各通道分别表示色调(Hue)、饱和度(Saturation)和明度(Value),可以直观地表达色彩的明暗、色调及鲜艳程度。

HSV 颜色空间可以用一个圆锥空间模型来描述。圆锥的顶点处 V=0,H 和 S 无定义,代表黑色;圆锥的顶面中心处V=max,S=0,H 无定义,代表白色。

当 S=1, V=1 时,H 所代表的任何颜色被称为纯色;当 S=0 时,饱和度为 0,颜色最浅,最浅被描述为灰色,灰色的亮度由 V 决定,此时 H 无意义;当 V=0 时,颜色最暗,最暗被描述为黑色,此时 H 和 S 均无意义,无论如何取值均为黑色。

在这里插入图片描述

色调是色彩的基本属性,表示不同的颜色 ,可以用于描述和识别某种颜色。例如,绿色在 HSV 空间中的范围是 H=35~77,而在 RGB 空间很难用表达式描述。因此常用 HSV 色彩空间进行某种颜色的识别和不同颜色的对比。

HSV 模型在对指定颜色分割时非常有效。用 H 和 S 分量表示颜色距离,颜色距离指代表两种颜色之间的数值差异。对于不同的彩色区域,混合 H 与 S 变量,划定阈值,就可以进行简单的分割。


函数原型

函数 inRange () 可以实现按颜色区域 [lowerb,upperb] 对图像进行二值分割 。

cv.inRange(src, lowerb, upperb[, dst]) → dst

函数 inRange() 检查数组元素是否在设定区间内,通常用于在 HSV 空间检查设定的颜色区域范围。如果图像的某个像素值在 [lowerb,upperb] 之间,则输出像素值置 255,否则置 0。

参数说明:

  • src:输入图像,nparray 数组,允许单通道或多通道图像
  • lowerb:下边界阈值,标量(src为单通道)或数组(src为多通道)
  • upperb:上边界阈值,标量(src为单通道)或数组(src为多通道)
  • dst:输出图像,单通道的二值图像,大小与 src 相同,深度为 CV_8U

注意事项:

  1. 输入图像可以是单通道的灰度图像,也可以是多通道的彩色图像。
  2. 不论输入图像是单通道还是多通道图像,输出图像都是单通道二值图像,相当于输入图像的黑白遮罩 mask。
  3. 输入图像是单通道的灰度图像时,lower、upper 为标量;输入图像是多通道的彩色图像时,lower, upper 为数组,数组长度与通道数相同,分别表示各通道的边界阈值。
  4. 输入图像为多通道时,仅当像素各通道的值都在 [lowerb(i),upperb(i)] 之间时输出才为 255:

KaTeX parse error: Undefined control sequence: \and at position 39: …I_0) \lt u_0] \̲a̲n̲d̲ ̲[l_1 \lt src(I_…


颜色阈值:

色调表示不同的颜色 ,各种颜色具有特定的色调值。

OpenCV 中 HSV 颜色空间的范围是:H [0,180],S [0,255],V [0,255]。

常用颜色的色调值范围,也即边界阈值,如下表所示。

在这里插入图片描述


例程 14.17:HSI 颜色空间图像分割

    # 14.17 HSI 颜色空间图像分割
    # 在HSV空间对绿屏色彩区域进行阈值处理,生成遮罩进行抠图
    img = cv.imread("../images/lady983Green.png", flags=1)  # 读取彩色图像
    hsv = cv.cvtColor(img, cv.COLOR_BGR2HSV)  # 将图片转换到 HSV 色彩空间

    # 使用 cv.inrange 函数在 HSV 空间检查设定的颜色区域范围,转换为二值图像,生成遮罩
    lowerColor = np.array([35, 43, 46])  # (下限: 绿色33/43/46)
    upperColor = np.array([77, 255, 255])  # (上限: 绿色77/255/255)
    binary = cv.inRange(hsv, lowerColor, upperColor)  # 生成二值遮罩,指定背景颜色区域白色
    binaryInv = cv.bitwise_not(binary)  # 生成逆遮罩,前景区域白色开窗,背景区域黑色
    matting = cv.bitwise_and(img, img, mask=binaryInv)  # 生成抠图图像 (前景保留,背景黑色)

    # 将背景颜色更换为红色: 修改逆遮罩 (抠图以外区域黑色)
    imgReplace = img.copy()
    imgReplace[binaryInv==0] = [0,0,255]  # 黑色背景区域(0/0/0) 修改为红色 (BGR:0/0/255)

    plt.figure(figsize=(9, 6))
    plt.subplot(221),plt.title("origin"), plt.axis('off')
    plt.imshow(cv.cvtColor(img, cv.COLOR_BGR2RGB))
    plt.subplot(222), plt.title("binary mask"), plt.axis('off')
    plt.imshow(binary, cmap='gray')
    plt.subplot(223), plt.title("invert mask"), plt.axis('off')
    plt.imshow(binaryInv, cmap='gray')
    plt.subplot(224), plt.title("matting"), plt.axis('off')
    plt.imshow(cv.cvtColor(matting, cv.COLOR_BGR2RGB))
    plt.tight_layout()
    plt.show()

在这里插入图片描述




【本节完】

版权声明:
参考文献: Use the Photoshop Levels adjustment (adobe.com)
youcans@xupt 原创作品,转载必须标注原文链接:(https://blog.csdn.net/youcans/article/details/125389684)
Copyright 2022 youcans, XUPT
Crated:2022-6-20
欢迎关注 『youcans 的 OpenCV 例程 200 篇』 系列,持续更新中
欢迎关注 『youcans 的 OpenCV学习课』 系列,持续更新中

201. 图像的颜色空间转换
202. 查表快速替换(cv.LUT)
203. 伪彩色图像处理
204. 图像的色彩风格滤镜
205. 调节色彩平衡/饱和度/明度
206. Photoshop 色阶调整算法
207. Photoshop 色阶自动调整算法
208. Photoshop 对比度自动调整算法
209. HSV 颜色空间的彩色图像分割

猜你喜欢

转载自blog.csdn.net/youcans/article/details/125414033