对于一般的图像提取轮廓,介绍了一个很好的方法,但是对于有噪声的图像,并不能很好地捕获到目标物体。

比如对于我的鼠标,提取的轮廓效果并不好,因为噪声很多:
所以本文增加了去掉噪声的部分。
首先加载原始图像,并显示图像
img = cv2.imread("temp.jpg") #载入图像
h, w = img.shape[:2] #获取图像的高和宽
cv2.imshow("Origin", img)
然后进行低通滤波处理,进行降噪
blured = cv2.blur(img,(5,5)) #进行滤波去掉噪声
cv2.imshow("Blur", blured) #显示低通滤波后的图像
使用floodfill来去掉目标周围的背景,泛洪填充类始于ps的魔棒工具,这里用来清除背景。
然后转换成灰度图
gray = cv2.cvtColor(blured,cv2.COLOR_BGR2GRAY)
cv2.imshow("gray", gray)
此时目标图像周围有写不光滑,还有一些噪声,因此进行开闭运算,得到比较光滑的目标
#定义结构元素
kernel = cv2.getStructuringElement(cv2.MORPH_RECT,(50, 50))
#开闭运算,先开运算去除背景噪声,再继续闭运算填充目标内的孔洞
opened = cv2.morphologyEx(gray, cv2.MORPH_OPEN, kernel)
closed = cv2.morphologyEx(opened, cv2.MORPH_CLOSE, kernel)
cv2.imshow("closed", closed)
接着转换成二值图以便于获取图像的轮廓
最后进行轮廓提取,抓取到目标
#找到轮廓
_,contours, hierarchy = cv2.findContours(binary,cv2.RETR_TREE,cv2.CHAIN_APPROX_SIMPLE)
#绘制轮廓
cv2.drawContours(img,contours,-1,(0,0,255),3)
#绘制结果
cv2.imshow("result", img)
全部代码如下
#coding=utf-8
import cv2
import numpy as np
img = cv2.imread("temp.jpg") #载入图像
h, w = img.shape[:2] #获取图像的高和宽
cv2.imshow("Origin", img) #显示原始图像
blured = cv2.blur(img,(5,5)) #进行滤波去掉噪声
cv2.imshow("Blur", blured) #显示低通滤波后的图像
mask = np.zeros((h+2, w+2), np.uint8) #掩码长和宽都比输入图像多两个像素点,满水填充不会超出掩码的非零边缘
#进行泛洪填充
cv2.floodFill(blured, mask, (w-1,h-1), (255,255,255), (2,2,2),(3,3,3),8)
cv2.imshow("floodfill", blured)
#得到灰度图
gray = cv2.cvtColor(blured,cv2.COLOR_BGR2GRAY)
cv2.imshow("gray", gray)
#定义结构元素
kernel = cv2.getStructuringElement(cv2.MORPH_RECT,(50, 50))
#开闭运算,先开运算去除背景噪声,再继续闭运算填充目标内的孔洞
opened = cv2.morphologyEx(gray, cv2.MORPH_OPEN, kernel)
closed = cv2.morphologyEx(opened, cv2.MORPH_CLOSE, kernel)
cv2.imshow("closed", closed)
#求二值图
ret, binary = cv2.threshold(closed,250,255,cv2.THRESH_BINARY)
cv2.imshow("binary", binary)
#找到轮廓
_,contours, hierarchy = cv2.findContours(binary,cv2.RETR_TREE,cv2.CHAIN_APPROX_SIMPLE)
#绘制轮廓
cv2.drawContours(img,contours,-1,(0,0,255),3)
#绘制结果
cv2.imshow("result", img)
cv2.waitKey(0)
cv2.destroyAllWindows()
以上这篇python-opencv在有噪音的情况下提取图像的轮廓实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
# python-opencv提取图像轮廓
# python用opencv完成图像分割并进行目标物的提取
# python+opencv图像分割实现分割不规则ROI区域方法汇总
# OpenCV-Python使用分水岭算法实现图像的分割与提取
# Python使用OpenCV和K-Means聚类对毕业照进行图像分割
# Python 深入了解opencv图像分割算法
# python中的opencv 图像分割与提取
# 很好
# 给大家
# 开闭
# 转换成
# 掩码
# 鼠标
# 希望能
# 这篇
# 并不能
# 还有一些
# 都比
# 小编
# 大家多多
# 长和
# 增加了
# 降噪
# 情况下
# 边缘
# 加载
# blur
相关文章:
宝塔新建站点为何无法访问?如何排查?
定制建站流程步骤详解:一站式方案设计与开发指南
php json中文编码为null的解决办法
胶州企业网站制作公司,青岛石头网络科技有限公司怎么样?
如何基于云服务器快速搭建网站及云盘系统?
定制建站策划方案_专业建站与网站建设方案一站式指南
广州网站制作公司哪家好一点,广州欧莱雅百库网络科技有限公司官网?
,南京靠谱的征婚网站?
大同网页,大同瑞慈医院官网?
如何确认建站备案号应放置的具体位置?
制作网站公司那家好,网络公司是做什么的?
专业网站制作服务公司,有哪些网站可以免费发布招聘信息?
Python如何创建带属性的XML节点
,在苏州找工作,上哪个网站比较好?
如何通过虚拟主机快速搭建个人网站?
番禺网站制作公司哪家值得合作,番禺图书馆新馆开放了吗?
如何在VPS电脑上快速搭建网站?
香港服务器租用费用高吗?如何避免常见误区?
在线ppt制作网站有哪些,请推荐几个好的课件下载的网站?
测试制作网站有哪些,测试性取向的权威测试或者网站?
中山网站推广排名,中山信息港登录入口?
如何通过商城自助建站源码实现零基础高效建站?
成都响应式网站开发,dw怎么把手机适应页面变成网页?
网站app免费制作软件,能免费看各大网站视频的手机app?
,想在网上投简历,哪几个网站比较好?
如何在局域网内绑定自建网站域名?
电商网站制作多少钱一个,电子商务公司的网站制作费用计入什么科目?
如何在服务器上三步完成建站并提升流量?
平台云上自主建站:模板化设计与智能工具打造高效网站
建站之星云端配置指南:模板选择与SEO优化一键生成
建站三合一如何选?哪家性价比更高?
网站制作公司排行榜,四大门户网站排名?
广州美橙建站如何快速搭建多端合一网站?
建站之星后台密码遗忘?如何快速找回?
韩国代理服务器如何选?解析IP设置技巧与跨境访问优化指南
品牌网站制作公司有哪些,买正品品牌一般去哪个网站买?
ui设计制作网站有哪些,手机UI设计网址吗?
如何零成本快速生成个人自助网站?
中山网站制作网页,中山新生登记系统登记流程?
建站DNS解析失败?如何正确配置域名服务器?
详解免费开源的DotNet二维码操作组件ThoughtWorks.QRCode(.NET组件介绍之四)
网站好制作吗知乎,网站开发好学吗?有什么技巧?
建站之星备案流程有哪些注意事项?
MySQL查询结果复制到新表的方法(更新、插入)
济南专业网站制作公司,济南信息工程学校怎么样?
广州网站设计制作一条龙,广州巨网网络科技有限公司是干什么的?
如何通过WDCP绑定主域名及创建子域名站点?
如何在腾讯云服务器快速搭建个人网站?
弹幕视频网站制作教程下载,弹幕视频网站是什么意思?
视频网站app制作软件,有什么好的视频聊天网站或者软件?
*请认真填写需求信息,我们会在24小时内与您取得联系。