事先准备

使用工具Python3.5
使用包cv2,numpy

涉及函数

cv2.cvtColor()
cv2.inRange()

任务1:转换颜色空间

  在 OpenCV 中有 超过150 种进行颜色空间转换的方法。但是你以后就会发现我们经常用到的也就两种:BGR↔Gray 和 BGR↔HSV。
我们用到的函数是:

cv2.cvtColor(input_image,flag),其中flag就是转换类型,第一个参数就是要改变的图片。

  对于BGR↔Gray的转换,我们使用的flag就是cv2.COLOR_BGR2GRAY。
  同样对于BGR↔HSV的转换我们用的flag就是cv2.COLOR_BGR2HSV。
  (多数情况下,用这两个就够了)
  你可以下的命令得到所有可用的 flag。

import cv2
flags=[i for in dir(cv2) if i startswith('COLOR_')]
print (flags)

  在 OpenCV 的 HSV 格式中,H(色彩/色度)的取值范围是 [0,179], S(饱和度)的取值范围 [0,255],V(亮度)的取值范围 [0,255]。但是不同的软件使用的值可能不同。所以当你拿 OpenCV 的 HSV 值与其他软件的 HSV 值对比时,一定要记得归一化。

任务2:物体跟踪

  现在我们知怎样将一幅图像从 BGR 换到 HSV 了,我们可以利用 一点来提取带有某个特定色的物体。在 HSV 颜色空间中要比在 BGR 空间中更容易表示一个特定颜色。在我们的程序中,我们提取的是一个蓝色的物体。下就是就是我们做的几步:
  • 从视频中获取每一帧图像(一帧图像,我们可以理解为一张图片)
  • 将图像从BGR换到 HSV 空间
  • 设置 HSV 阀值到蓝色范围。
  • 获取蓝色物体,当然我们可以做其他任何我们想做的事,比如:在蓝色物体周围画一个圈。(后面会降到如何操作)

import cv2
import numpy as npcap = cv2.VideoCapture(0)while(1):#获取每一帧ret,frame = cap.read()#转换到HSVhsv = cv2.cvtColor(frame,cv2.COLOR_BGR2HSV)#设定蓝色的阀值lower_blue = np.array([110,50,50])upper_blue = np.array([130,255,255])#根据阀值构建掩模mask = cv2.inRange(hsv,lower_blue,upper_blue)#对原图和掩模进行位运算res = cv2.bitwise_and(frame,frame,mask=mask)#显示图像cv2.imshow('frame',frame)cv2.imshow('mask',mask)cv2.imshow('res',res)k = cv2.waitKey(5)&0xFFif k == ord('q'):break
#关闭窗口
cv2.destroyAllWindows()


  现在的噪点还是很多,后面会介绍如何通过滤波、形态学腐蚀与膨胀去消减噪音或者得到更加准确地捕捉物体。
  追踪物体轮廓,以后可以找物体中心,然后跟踪物体,画出物体的轮廓,包含各种各样的拟合(椭圆拟合、直线拟合等,之后会一一介绍)可以在摄像头前挥挥手就可以画图等一些有趣的事。

任务3:怎样找到要跟踪对象的HSV值

  函数cv2.cvtColor()可以用到这里,现在需要传入的参数是RGB的值而不是一幅图。例如要找到绿色的HSV值,只需在终端输入以下命令:

import cv2 import numpy as np
green=np.uint8([0,255,0]) hsv_green=cv2.cvtColor(green,cv2.COLOR_BGR2HSV)error: /builddir/build/BUILD/opencv-2.4.6.1/ modules/imgproc/src/color.cpp:3541:
error: (-215) (scn == 3 || scn == 4) && (depth == CV_8U || depth == CV_32F) in function cvtColor#scn (the number of channels of the source),
#i.e. self.img.channels(), is neither 3 nor 4.
# #depth (of the source),
#i.e. self.img.depth(), is neither CV_8U nor CV_32F.
# 所以不能用 [0,255,0] 而用 [[[0,255,0]]]
# 的三层括号应分别对应于 cvArray cvMat IplImagegreen=np.uint8([[[0,255,0]]]) hsv_green=cv2.cvtColor(green,cv2.COLOR_BGR2HSV)
print (hsv_green )
[[[60 255 255]]]

  现在你可以分别用 [H-100,100,100] 和 [H+100,255,255] 做上下阀值。除了个方法之外,你可以使用任何其他图像编辑软件(例如 GIMP) 或者在线换软件找到相应的 HSV 值,但是后别忘了调节 HSV 的范围。
  推荐一个查主要颜色HSV阀值的网址,点击即可进入

总结

(本系列每周持续更新,谢谢大家的支持!)

(Python)从零开始,简单快速学机器仿人视觉Opencv---第九节:颜色空间转换相关推荐

  1. python配置opencv最简单_(Python)从零开始,简单快速学机器仿人视觉Opencv—第二节:OpenCV的视频操作...

    准备工作 使用库: numpy opencv 任务1 用摄像头捕获视频 cv2.VideoCapture() :0为默认计算机默认摄像头,1可以更换来源: import numpy as np imp ...

  2. (Python)从零开始,简单快速学机器仿人视觉Opencv---运用四:图像损痕修复

    教程: 博主之前写了24节关于使用OpenCV的教程,欢迎大家阅读: (Python)从零开始,简单快速学机器仿人视觉Opencv-第一节:OpenCV的图像读取显示及保存 (Python)从零开始, ...

  3. (Python)从零开始,简单快速学机器仿人视觉Opencv---运用二:物体检测

    教程: 博主之前写了22节关于使用OpenCV的教程,欢迎大家阅读: (Python)从零开始,简单快速学机器仿人视觉Opencv-第一节:OpenCV的图像读取显示及保存 (Python)从零开始, ...

  4. (Python)从零开始,简单快速学机器仿人视觉Opencv---运用一:快速截取图像中指定单个物体

    教程: 博主之前写了21节关于使用Opencv的教程,欢迎大家阅读: (Python)从零开始,简单快速学机器仿人视觉Opencv-第一节:OpenCV的图像读取显示及保存 (Python)从零开始, ...

  5. (Python)从零开始,简单快速学机器仿人视觉Opencv---运用三:物体运动跟踪

    教程: 博主之前写了23节关于使用OpenCV的教程,欢迎大家阅读: (Python)从零开始,简单快速学机器仿人视觉Opencv-第一节:OpenCV的图像读取显示及保存 (Python)从零开始, ...

  6. python可以做工业视觉_(Python)从零开始,简单快速学机器仿人视觉Opencv—运用四:图像损痕修复...

    主题 在本节中我们将描述一种称为图像修复的区域填充算法. 这种图片修复算法的作用是可以通过使用OpenCV模块来进行图片上异常划痕或斑点等噪线.噪点的修复,而且代码相对其他的图片修复算法而言要稍微简单 ...

  7. python八角图形绘制_(Python)从零开始,简单快速学机器仿人视觉Opencv—第四节:OpenCV处理鼠标事件...

    准备工作 使用工具:Python3.5 涉及包:cv2 numpy 涉及函数 函数:cv2.setMouseCallback() 任务开始 简单的程序,在图片上双击过的位置绘制一个圆圈 任务1.创建鼠 ...

  8. python如何做四象图_(Python)从零开始,简单快速学机器仿人视觉Opencv—第十四节:图像梯度...

    事先说明 图像梯度原理:简单来说就是求导 OpenCV提供了三种不同的梯度滤波器,或者说高通滤波器:Sobel,Scharr和Laplacian.Sobel和Scharr是求一阶或二阶导数.Schar ...

  9. (Python)从零开始,简单快速学机器仿人视觉Opencv---第十九节:关于轮廓的函数

    1 凸缺陷   找到凸缺陷 hull=cv2.convexHull(cnt,returnPoints=False) defects=cv2.convexityDefects(cnt,hull)   它 ...

最新文章

  1. Navicat添加新数据、保存当前修改
  2. Python中的赋值、引用和深浅拷贝
  3. 如何开发auto complete 智能提示功能
  4. Beaglebone Black的启动
  5. boost::mpl模块实现replace_if相关的测试程序
  6. kaptcha配置java_kaptcha 配置
  7. 搞嵌入式Linux,做底层还是应用?底层要掌握哪些技能?
  8. 集赞有礼!进击吧! Blazor !第六期 企业内部应用建设实战
  9. java程序表头出不来_JAVA SWING 表头不显示问题
  10. 命令启动jar包_java项目打jar包,一句命令搞定
  11. 解决 transaction-manager Attribute transaction-manager is not allowed here
  12. C# 值类型 引用类型 作为参数传递区别
  13. Wirkshark表达式
  14. 智力问答选择题_儿童智力问答题带答案
  15. python判断完美数_Python识别完美数
  16. 【AI案例实践】基于深度学习的超分辨率技术
  17. thinkphp 下实现繁简体汉字转换
  18. 友情链接加nofollow_如何在WordPress中添加Nofollow链接(适用于初学者的简单指南)
  19. linux色彩配置文件,Xfce得到颜色配置文件的支持
  20. 服务器2012还原系统,Windows Server 2012如何进行系统映像还原

热门文章

  1. 业余草通告CSDN博客用户zhang__ao非法转载文章的公告
  2. C语言单引号和双引号
  3. 使用百度BMap地图
  4. 追寻凌云梦——对话阿里云总裁王坚
  5. docker pytorch-cuda 安装 devel 版本
  6. 【linux系统安装jdk11】
  7. 机器学习---数据科学包-第2天
  8. 全面开启 BI PaaS|衡石十月头条
  9. ZYNQ 图像处理之千兆网传(一)【寄存器级操作】
  10. 深度KWeaver:价值驱动,认知智能走向开源共创