写一个基于opencv的颜色识别代码
时间: 2023-11-27 12:04:48 浏览: 86
好的,以下是基于OpenCV的颜色识别代码。这段代码可以根据输入的图片和颜色参数,识别出图片中符合颜色要求的区域,并标记出来。
```python
import cv2
import numpy as np
# 定义颜色区间
lower_blue = np.array([100, 50, 50])
upper_blue = np.array([130, 255, 255])
# 读入图片
img = cv2.imread('test.jpg', cv2.IMREAD_COLOR)
# 转换颜色空间
hsv = cv2.cvtColor(img, cv2.COLOR_BGR2HSV)
# 根据颜色区间提取图像
mask = cv2.inRange(hsv, lower_blue, upper_blue)
# 进行形态学操作,去除噪点
kernel = np.ones((5, 5), np.uint8)
mask = cv2.morphologyEx(mask, cv2.MORPH_OPEN, kernel)
mask = cv2.morphologyEx(mask, cv2.MORPH_CLOSE, kernel)
# 寻找轮廓并画出边界框
contours, hierarchy = cv2.findContours(mask, cv2.RETR_TREE, cv2.CHAIN_APPROX_SIMPLE)
for cnt in contours:
x, y, w, h = cv2.boundingRect(cnt)
cv2.rectangle(img, (x, y), (x + w, y + h), (0, 255, 0), 2)
# 显示结果
cv2.imshow('img', img)
cv2.waitKey(0)
cv2.destroyAllWindows()
```
在上面的代码中,我们首先定义了颜色区间,然后读入待处理的图片并将其转换为HSV颜色空间。接着,使用`cv2.inRange()`函数提取出符合颜色要求的区域,并对其进行形态学操作,去除噪点。最后,使用`cv2.findContours()`函数找到符合要求的轮廓,并在原图上画出边界框,最后展示结果。
需要注意的是,这里我们只是以蓝色为例进行颜色识别,如果想要识别其他颜色,只需要根据需要修改颜色区间即可。
阅读全文
相关推荐
![-](https://img-home.csdnimg.cn/images/20241231044955.png)
![-](https://img-home.csdnimg.cn/images/20241231045053.png)
![-](https://img-home.csdnimg.cn/images/20241231045053.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![zip](https://img-home.csdnimg.cn/images/20241231045053.png)
![zip](https://img-home.csdnimg.cn/images/20241231045053.png)
![zip](https://img-home.csdnimg.cn/images/20241231045053.png)
![rar](https://img-home.csdnimg.cn/images/20241231044955.png)
![pdf](https://img-home.csdnimg.cn/images/20241231044930.png)
![zip](https://img-home.csdnimg.cn/images/20241231045053.png)
![application/x-rar](https://img-home.csdnimg.cn/images/20210720083606.png)
![rar](https://img-home.csdnimg.cn/images/20241231044955.png)
![zip](https://img-home.csdnimg.cn/images/20241231045053.png)
![application/x-rar](https://img-home.csdnimg.cn/images/20210720083606.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)