opencv 实现特定颜色线条提取与定位操作


Posted in Python onJune 02, 2020

本篇文章通过调用opencv里的函数简单的实现了对图像里特定颜色提取与定位,以此为基础,我们可以实现对特定颜色物体的前景分割与定位,或者特定颜色线条的提取与定位

主要步骤:

将RGB图像转化为HSV,H表示色调(度数表示0-180),S表示饱和度(取值0-255),V表示亮度(取值0-255),不同的颜色有着不同的取值范围,一般给出如下:

设定待提取颜色的HSV范围值,然后调用inRange函数实现对颜色空间的提取,该函数会将除目标颜色外的其余颜色为黑色背景,仅保留该颜色为前景

cv2.inRange(hsv, lower_red, upper_red)

参数解析:

第一个参数:hsv指的是原图

第二个参数:lower_red指的是图像中低于这个lower_red的值,图像值变为0

第三个参数:upper_red指的是图像中高于这个upper_red的值,图像值变为0

而在lower_red~upper_red之间的值变成255

二值化

腐蚀与膨胀操作,去除噪点,连接断点

调用findContours函数进行轮廓检测

cv2.findContours()函数接受的参数为二值图,即黑白的(不是灰度图)

cv2.findContours(image, mode, method[, contours[, hierarchy[, offset ]]])

参数解析

第一个参数是寻找轮廓的图像;

第二个参数表示轮廓的检索模式,有四种(本文介绍的都是新的cv2接口):

cv2.RETR_EXTERNAL表示只检测外轮廓

cv2.RETR_LIST检测的轮廓不建立等级关系

cv2.RETR_CCOMP建立两个等级的轮廓,上面的一层为外边界,里面的一层为内孔的边界信息。如果内孔内还有一个连通物体,这个物体的边界也在顶层。

cv2.RETR_TREE建立一个等级树结构的轮廓。

第三个参数method为轮廓的近似办法

cv2.CHAIN_APPROX_NONE存储所有的轮廓点,相邻的两个点的像素位置差不超过1,即max(abs(x1-x2),abs(y2-y1))==1

cv2.CHAIN_APPROX_SIMPLE压缩水平方向,垂直方向,对角线方向的元素,只保留该方向的终点坐标,例如一个矩形轮廓只需4个点来保存轮廓信息

cv2.CHAIN_APPROX_TC89_L1,CV_CHAIN_APPROX_TC89_KCOS使用teh-Chinl chain 近似算法

返回值

cv2.findContours()函数返回三个值,一个是图像,一个是轮廓本身,还有一个是每条轮廓对应的属性。

对于轮廓是以坐标的形式返回,可以通过函数cv2.drawContours()绘制出轮廓

绘制矩形区域对轮廓进行定位

主要代码如下:

import numpy as np
import cv2
import os
image = 'image1.jpg'
savefile = './mark1'
# image = os.listdir(image_file)
save_image = os.path.join(savefile, image)

#设定颜色HSV范围,假定为红色
redLower = np.array([156, 43, 46])
redUpper = np.array([179, 255, 255])

#读取图像
img = cv2.imread(image)

#将图像转化为HSV格式
hsv = cv2.cvtColor(img, cv2.COLOR_BGR2HSV)

#去除颜色范围外的其余颜色
mask = cv2.inRange(hsv, redLower, redUpper)

# 二值化操作
ret, binary = cv2.threshold(mask, 0, 255, cv2.THRESH_BINARY)

#膨胀操作,因为是对线条进行提取定位,所以腐蚀可能会造成更大间隔的断点,将线条切断,因此仅做膨胀操作
kernel = np.ones((5, 5), np.uint8)
dilation = cv2.dilate(binary, kernel, iterations=1)

#获取图像轮廓坐标,其中contours为坐标值,此处只检测外形轮廓
_, contours, hierarchy = cv2.findContours(dilation, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)

if len(contours) > 0:
  #cv2.boundingRect()返回轮廓矩阵的坐标值,四个值为x, y, w, h, 其中x, y为左上角坐标,w,h为矩阵的宽和高
  boxes = [cv2.boundingRect(c) for c in contours]
  for box in boxes:
    x, y, w, h = box
    #绘制矩形框对轮廓进行定位
    cv2.rectangle(img, (x, y), (x+w, y+h), (153, 153, 0), 2)
	#将绘制的图像保存并展示
	cv2.imwrite(save_image, img)
	cv2.imshow('image', img)
	cv2.waitKey(0)
	cv2.destroyAllWindows()

效果如图,一试卷红色批改字样为例:

原图:

opencv 实现特定颜色线条提取与定位操作

对批改区域定位图:

opencv 实现特定颜色线条提取与定位操作

以上这篇opencv 实现特定颜色线条提取与定位操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python中的异常处理学习笔记
Jan 28 Python
python中子类调用父类函数的方法示例
Aug 18 Python
[原创]教女朋友学Python(一)运行环境搭建
Nov 29 Python
浅谈python连续赋值可能引发的错误
Nov 10 Python
python的pyecharts绘制各种图表详细(附代码)
Nov 11 Python
Python函数式编程指南:对生成器全面讲解
Nov 19 Python
tensorflow 实现从checkpoint中获取graph信息
Feb 10 Python
pyinstaller打包成无控制台程序时运行出错(与popen冲突的解决方法)
Apr 15 Python
Python基于QQ邮箱实现SSL发送
Apr 26 Python
python中shell执行知识点
May 06 Python
Python监听剪切板实现方法代码实例
Nov 11 Python
Python+MySQL随机试卷及答案生成程序的示例代码
Feb 01 Python
Python爬虫入门有哪些基础知识点
Jun 02 #Python
Python实现进度条和时间预估的示例代码
Jun 02 #Python
python爬虫容易学吗
Jun 02 #Python
基于Python词云分析政府工作报告关键词
Jun 02 #Python
使用OpenCV获取图像某点的颜色值,并设置某点的颜色
Jun 02 #Python
如何利用python web框架做文件流下载的实现示例
Jun 02 #Python
python3+opencv 使用灰度直方图来判断图片的亮暗操作
Jun 02 #Python
You might like
php中转义mysql语句的实现代码
2011/06/24 PHP
解析PHP多种序列化与反序列化的方法
2013/06/06 PHP
YII2框架中添加自定义模块的方法实例分析
2020/03/18 PHP
JavaScript实现穷举排列(permutation)算法谜题解答
2014/12/29 Javascript
javascript连续赋值问题
2015/07/08 Javascript
超漂亮的jQuery图片轮播特效
2015/11/24 Javascript
即将发布的jQuery 3 有哪些新特性
2016/04/14 Javascript
jQuery实现可移动选项的左右下拉列表示例
2016/12/26 Javascript
一个例子轻松学会Vue.js
2017/01/02 Javascript
three.js中3D视野的缩放实现代码
2017/11/16 Javascript
移动前端图片压缩上传的实例
2017/12/06 Javascript
Jquery和CSS实现选择框重置按钮功能
2018/11/08 jQuery
vue通过指令(directives)实现点击空白处收起下拉框
2018/12/06 Javascript
mpvue性能优化实战技巧(小结)
2019/04/17 Javascript
微信小程序的开发范式BeautyWe.js入门详解
2019/07/10 Javascript
javascript设计模式 ? 解释器模式原理与用法实例分析
2020/04/17 Javascript
浅谈使用nodejs搭建web服务器的过程
2020/07/20 NodeJs
[01:51]2018年度CS GO最具人气外援-完美盛典
2018/12/16 DOTA
Python pickle模块用法实例
2015/04/14 Python
给Python入门者的一些编程建议
2015/06/15 Python
python实现读取并显示图片的两种方法
2017/01/13 Python
python实现下载整个ftp目录的方法
2017/01/17 Python
Python实现的简单模板引擎功能示例
2017/09/02 Python
python把数组中的数字每行打印3个并保存在文档中的方法
2018/07/17 Python
对python调用RPC接口的实例详解
2019/01/03 Python
提升python处理速度原理及方法实例
2019/12/25 Python
Python3实现监控新型冠状病毒肺炎疫情的示例代码
2020/02/13 Python
Crocs卡骆驰洞洞鞋日本官方网站:Crocs日本
2016/08/25 全球购物
Hotels.com拉丁美洲:从豪华酒店到经济型酒店的预定优惠和折扣
2019/12/09 全球购物
5个HTML5的常用本地存储方式详解与介绍
2021/03/27 HTML / CSS
心得体会的写法
2014/09/05 职场文书
卫校毕业生自我鉴定
2014/09/28 职场文书
私人房屋买卖协议书
2014/10/04 职场文书
2015年五四青年节演讲稿
2015/03/18 职场文书
利用Python+OpenCV三步去除水印
2021/05/28 Python
解决Redis启动警告问题
2022/02/24 Redis