Opencv学习笔记————颜色空间转换

  1. 转换颜色空间
    我们常用的颜色空间转换就两种:BGR->Gray(cv2.COLOR_BGR2GRAY)和BGR->HSV(cv2.COLOR_BGR2HSV),用到的函数是:cv2.cvtColor(imput_image,flag),其中flag为转换类型。
  2. 跟踪特定颜色的物体实例
    我们还需要了解,根据阈值构建掩模函数:mask=cv2.inRange(hsv,lower_blue,upper_blue)。
    这样利用opencv的inRange()函数,制作掩模,再用bitwise_and()函数,提取感兴趣区域。
import numpy as np
import cv2

# 滑动条来进行调节阈值
def Trackbar():
    global thresh_hsv
    H = cv2.getTrackbarPos('H', 'image')
    S = cv2.getTrackbarPos('S', 'image')
    V = cv2.getTrackbarPos('V', 'image')
    thresh_hsv = np.array([H, S, V])

# 常用颜色阈值的字典
thresh = {
    'lower_blue': np.array([100, 43, 46]),
    'upper_blue': np.array([124, 255, 255]),
    'lower_red':  np.array([156, 150, 46]),
    'upper_red': np.array([180, 255, 255]),
    'lower_green': np.array([35, 43, 46]),
    'upper_green': np.array([77, 255, 255])
}

cap = cv2.VideoCapture(1)
cv2.namedWindow('image')
cv2.resizeWindow("image", 640, 480);

cv2.createTrackbar('H', 'image', 0, 255, Trackbar)
cv2.createTrackbar('S', 'image', 0, 255, Trackbar)
cv2.createTrackbar('V', 'image', 0, 255, Trackbar)
while True:

    # 获取每一帧
    ret, frame = cap.read()

    # 转换到HSV
    hsv = cv2.cvtColor(frame, cv2.COLOR_BGR2HSV)
    # 设定蓝色的阈值
    lower_blue = np.array([100, 43, 46])
    upper_blue = np.array([124, 255, 255])
    Trackbar()
    # 根据阈值构建掩模
    mask = cv2.inRange(hsv, thresh_hsv, upper_blue)

    # 对原图像和掩模进行位运算
   res = cv2.bitwise_and(frame, frame, mask=mask)
    # 显示图像
    cv2.imshow('mask', mask)
    cv2.imshow('res', res)
    k = cv2.waitKey(5) & 0xFF
    if k == ord('q'):
        break

cv2.destroyAllWindows()

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值