opencv返回图中的饮料瓶个数,选出容量少的那一瓶饮料,用绿色填充液体部分代码
时间: 2024-02-11 09:03:55 浏览: 72
好的,下面是一份大致的实现代码,供你参考:
```python
import cv2
import numpy as np
# 读取图像
img = cv2.imread('bottles.jpg')
# 将图像转换为灰度图
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
# 对灰度图进行二值化处理
ret, thresh = cv2.threshold(gray, 127, 255, cv2.THRESH_BINARY)
# 使用形态学运算进行处理
kernel = np.ones((5, 5), np.uint8)
morph = cv2.morphologyEx(thresh, cv2.MORPH_CLOSE, kernel)
# 找到所有轮廓
contours, hierarchy = cv2.findContours(morph, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)
# 绘制所有轮廓
cv2.drawContours(img, contours, -1, (0, 0, 255), 2)
# 计算瓶身数量,并选出容量小的那一瓶饮料
bottle_cnt = 0
bottle_min_area = float('inf')
for cnt in contours:
area = cv2.contourArea(cnt)
if area > 1000: # 过滤掉面积过小的轮廓
bottle_cnt += 1
if area < bottle_min_area:
bottle_min_area = area
bottle_min_cnt = cnt
# 选中的瓶身轮廓进行颜色填充,使用绿色填充液体部分
cv2.drawContours(img, [bottle_min_cnt], 0, (0, 255, 0), -1)
# 显示结果
cv2.imshow('img', img)
cv2.waitKey(0)
cv2.destroyAllWindows()
print("瓶身数量: ", bottle_cnt)
```
需要注意的是,这份代码可能需要根据具体的图像情况进行一些参数的调整,同时还需要进行一些异常情况的处理,比如没有检测到瓶身轮廓等。
相关推荐
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![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)
![](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)
![](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)
![](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)