色彩空间(OpenCV + Python)

本文介绍使用Python和OpenCV进行颜色空间转换的方法,包括灰度、HSV、YUV和YCrCb等,并演示了如何通过设定HSV阈值来追踪特定颜色对象,同时对比了cv.split()函数与src[:,:,0]=0在通道操作上的差异。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

import cv2 as cv
import numpy as np

def extrace_object_demo():
    capture = cv.VideoCapture(0)
    while(True):
        ret,frame = capture.read()
        if ret == False:
            break
        hsv = cv.cvtColor(frame,cv.COLOR_BGR2HSV)
 #       lower_hsv = np.array([37,43,46])
#        upper_hsv = np.array([77,255,255])
        lower_hsv = np.array([0, 0, 46]) # 灰色这个颜色分别在三个通道范围的最低值
        upper_hsv = np.array([180, 43, 220]) # 灰色这个颜色在三个通道范围的最高值
        mask = cv.inRange(hsv,lowerb = lower_hsv,upperb = upper_hsv)
        cv.imshow("video",frame)
        cv.imshow("mask",mask)
        c = cv.waitKey(40)
        if c == 27:
            break


def color_space_demo(image):
    gray = cv.cvtColor(image,cv.COLOR_BGR2GRAY)
    cv.imshow("gray",gray)
    hsv = cv.cvtColor(image,cv.COLOR_BGR2HSV)
    cv.imshow("hsv",hsv)
    yuv = cv.cvtColor(image,cv.COLOR_BGR2YUV)
    cv.imshow("yuv",yuv)
    Ycrcb = cv.cvtColor(image,cv.COLOR_BGR2YCrCb)
    cv.imshow("ycrcb",Ycrcb)

src = cv.imread(r"C:\pics\beay.png")
cv.namedWindow("input image",cv.WINDOW_AUTOSIZE)
cv.imshow("input image",src)

b, g, r = cv.split(src)      #通道分离
cv.imshow("blue",b)
cv.imshow("green",g)
cv.imshow("red",r)

src[:, :, 2] = 0        #通道合并
src = cv.merge([b,g,r])
cv.imshow("changed image",src)

#extrace_object_demo()
#color_space_demo(src)
cv.waitKey(0)

cv.destoryAllWindows()

cv.split()函数与src[:, :, 0] = 0有区别,前者是分离通道并转换为了一个灰度图像(即像素只由一个数值表达),而后者仍然是三通道RGB图像,只不过表示像素值的三个数某个数被改变(因此仍然是彩色图像)。

HSV 色彩空间分布
在这里插入图片描述

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值