OpenCV的第三次作业 使用HSV扣图


前言

这次是OpenCV的第三次作业了。

一、作业内容

通过追踪颜色的hsv值,使画面只留下长方形,在进行二值化,并通过对图片几何变换使长方形摆正在这里插入图片描述

二、思路

一步步来,主要是设置好红色的阈(yù)值

1.引入库

代码如下:

import cv2
import numpy as np

2.读入图片

代码如下:

img_path = './img3/findURRectangle.jpg'
img = cv2.imread(img_path)

3.转换到HSV

代码如下:

    # 转换到 HSV
    hsv = cv2.cvtColor(img, cv2.COLOR_BGR2HSV)

4. 设定红色的阈值

对于HSV色域,各种颜色可参考
在这里插入图片描述

代码如下:

    # 设定红色的阈值
    low_H = 156
    upper_H = 180
    low_S = 43
    upper_S = 255
    low_V = 46
    upper_V = 255
    lower_red = np.array([low_H, low_S, low_V])
    upper_red = np.array([upper_H, upper_S, upper_V])

5. 根据阈值构建掩模

代码如下:

    # 根据阈值构建掩模
    mask = cv2.inRange(hsv, lower_red, upper_red)

6. 对原图像和掩模进行位运算

代码如下:

    # 对原图像和掩模进行位运算
    res = cv2.bitwise_and(img, img, mask=mask)

7.显示图像

代码如下:

    # 显示图像
    cv2.imshow('img', img)
    cv2.imshow('mask', mask)
    cv2.imshow('res', res)
    k = cv2.waitKey(5) & 0xFF
    if k == 27:
        break
cv2.destroyAllWindows()

如下图所示:
在这里插入图片描述

8.旋转

使用OpenCV的旋转矩阵进行旋转,需要用到下面形式的公式
在这里插入图片描述

但OpenCV运行你在任意地方旋转,但是旋转矩阵的形式应该修改为

在这里插入图片描述

代码如下:

    # 获取图片的大小
    rows, cols, channels = res.shape
    # 对红色矩形进行旋转
    # 这里的第一个参数为旋转中心,第二个为旋转角度,第三个为旋转后的缩放因子
    # 可以通过设置旋转中心,缩放因子,以及窗口大小来防止旋转后超出边界的问题
    M = cv2.getRotationMatrix2D((cols/2, rows/2), 161, 0.8)
    # 第三个参数是输出图像的尺寸中心
    dst = cv2.warpAffine(res, M, (2*cols, 2*rows))

绕图片中心旋转161°后是这样
在这里插入图片描述
所有代码如下:

import cv2
import numpy as np

img_path = './img3/findURRectangle.jpg'

img = cv2.imread(img_path)


while 1:
    # 转换到 HSV
    hsv = cv2.cvtColor(img, cv2.COLOR_BGR2HSV)

    # 设定红色的阈值
    low_H = 156
    upper_H = 180
    low_S = 43
    upper_S = 255
    low_V = 46
    upper_V = 255
    lower_red = np.array([low_H, low_S, low_V])
    upper_red = np.array([upper_H, upper_S, upper_V])

    # 根据阈值构建掩模
    mask = cv2.inRange(hsv, lower_red, upper_red)

    # 对原图像和掩模进行位运算 取出长方形
    res = cv2.bitwise_and(img, img, mask=mask)

    # 获取图片的大小
    rows, cols, channels = res.shape
    # 对红色矩形进行旋转
    # 这里的第一个参数为旋转中心,第二个为旋转角度,第三个为旋转后的缩放因子
    # 可以通过设置旋转中心,缩放因子,以及窗口大小来防止旋转后超出边界的问题
    M = cv2.getRotationMatrix2D((cols/2, rows/2), 161, 0.8)
    # 第三个参数是输出图像的尺寸中心
    dst = cv2.warpAffine(res, M, (cols, rows))
    # 显示图像
    # cv2.imshow('img', img)
    # cv2.imshow('mask', mask)
    cv2.imshow('img', dst)
    cv2.imshow('res', res)
    k = cv2.waitKey(0) & 0xFF
    if k == 27:
        break
cv2.destroyAllWindows()


总结

以上就是今天要的内容,本文仅仅简单介绍了通过追踪颜色的hsv值,使画面只留下长方形。并进行二值化后再将图片进行几何变换使长方形摆正。
  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值