视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
pythonopencv检测并提取目标颜色
2020-11-27 14:13:02 责编:小采
文档
这次给大家带来python opencv检测并提取目标颜色,python opencv检测并提取目标颜色的注意事项有哪些,下面就是实战案例,一起来看一下。

实例如下所示:

# -*- coding:utf-8 -*-
author = 'kingking'
version = '1.0'
date = '14/07/2017'
import cv2
import numpy as np
import time
if name == 'main':
 Img = cv2.imread('example.png')#读入一幅图像
 kernel_2 = np.ones((2,2),np.uint8)#2x2的卷积核
 kernel_3 = np.ones((3,3),np.uint8)#3x3的卷积核
 kernel_4 = np.ones((4,4),np.uint8)#4x4的卷积核
 if Img is not None:#判断图片是否读入
 HSV = cv2.cvtColor(Img, cv2.COLOR_BGR2HSV)#把BGR图像转换为HSV格式
 '''
 HSV模型中颜色的参数分别是:色调(H),饱和度(S),明度(V)
 下面两个值是要识别的颜色范围
 '''
 Lower = np.array([20, 20, 20])#要识别颜色的下限
 Upper = np.array([30, 255, 255])#要识别的颜色的上限
 #mask是把HSV图片中在颜色范围内的区域变成白色,其他区域变成黑色
 mask = cv2.inRange(HSV, Lower, Upper)
 #下面四行是用卷积进行滤波
 erosion = cv2.erode(mask,kernel_4,iterations = 1)
 erosion = cv2.erode(erosion,kernel_4,iterations = 1)
 dilation = cv2.dilate(erosion,kernel_4,iterations = 1)
 dilation = cv2.dilate(dilation,kernel_4,iterations = 1)
 #target是把原图中的非目标颜色区域去掉剩下的图像
 target = cv2.bitwise_and(Img, Img, mask=dilation)
 #将滤波后的图像变成二值图像放在binary中
 ret, binary = cv2.threshold(dilation,127,255,cv2.THRESH_BINARY) 
 #在binary中发现轮廓,轮廓按照面积从小到大排列
 contours, hierarchy = cv2.findContours(binary,cv2.RETR_EXTERNAL,cv2.CHAIN_APPROX_SIMPLE) 
 p=0
 for i in contours:#遍历所有的轮廓
 x,y,w,h = cv2.boundingRect(i)#将轮廓分解为识别对象的左上角坐标和宽、高
 #在图像上画上矩形(图片、左上角坐标、右下角坐标、颜色、线条宽度)
 cv2.rectangle(Img,(x,y),(x+w,y+h),(0,255,),3)
 #给识别对象写上标号
 font=cv2.FONT_HERSHEY_SIMPLEX
 cv2.putText(Img,str(p),(x-10,y+10), font, 1,(0,0,255),2)#加减10是调整字符位置
 p +=1
 print '黄色方块的数量是',p,'个'#终端
输出目标数量 cv2.imshow('target', target) cv2.imshow('Mask', mask) cv2.imshow("prod", dilation) cv2.imshow('Img', Img) cv2.imwrite('Img.png', Img)#将画上矩形的图形保存到当前目录 while True: Key = chr(cv2.waitKey(15) & 255) if Key == 'q': cv2.destroyAllWindows() break

原始图像

处理之后保存的图像

相信看了本文案例你已经掌握了方法,更多精彩请关注Gxl网其它相关文章!

推荐阅读:

python批量读取图片且存入数据库的实现

在Window10中Python3.5怎么安装opencv

下载本文
显示全文
专题