空间皮肤代码_不废话,看我20行代码搞定色块提取与定位…….

e413f35fa5e85a8b89e81b2cd616d117.gif

点击上方蓝字关注我们

微信公众号:OpenCV学堂

关注获取更多计算机视觉与深度学习知识

问题来由

这个问题是谁问我的我已经不记得了,刚开始的时候他发了这张图像给我,让我给他看一下,我当时告诉他转换一下色彩空间提取就好啦,后来我记得他在微信上有问了我一次,今天我整理文件看到这张图又想起了,感觉他问了我好几次我都没回复挺不意思的,但是我实在不知道他是谁了,微信上消息太多,早已经把他淹没了,加之我记忆力退化严重,思来想去只好写篇文章告诉他,我回答了!如果看完感觉对你也有用,点在看支持即可!

先看看他发我的图像文件吧

69bd48112620b84fb757e443bde749ac.png

在来说说他的需求:

找到途中全部青色的区域,检测出来,绘制中心点!他用霍夫变换,结果直接翻车了,原因其实我很理解,这个图有很多梯度干扰,噪声干扰,用了肯定翻车!然后他就问我怎么办?

解题思路

直接转换到HSV色彩空间,得到如下结果:

017d0167aa0eaf285661863517d22474.png

然后我选择5x5的开操作,完成之后得到

53c7f8a586f315b18f5b68bbb11d243a.png

使用OpenCV轮廓发现,对轮廓拟合圆,求的圆心坐标得到输出结果如下:

f8c13199f0e6989106e1ff717e75883c.png

怎么样,效果好吗?

代码实现

上述步骤的代码演示,主要分为如下步骤

1.加载图像并转换到HSV色彩空间,得到mask
2.根据mask二值图像,进行形体学处理
3.使用轮廓发现,找到所有最外层轮廓
4.对轮廓进行圆拟合,得到圆心与半径,然后绘制

 代码如下:

 1#include 
2#include 
3
4using namespace cv;
5using namespace std;
6
7int main(int argc, char** argv) {
8    Mat image = imread("D:/images/zsxq/zsxq_20.png");
9    imshow("input", image);
10
11    // 色彩空间转换
12    Mat hsv, mask;
13    cvtColor(image, hsv, COLOR_BGR2HSV);
14    inRange(hsv, Scalar(40,43, 46), Scalar(50, 255, 255), mask);
15    imshow("mask", mask);
16    imwrite("D:/mask.png", mask);
17
18    // 形态学开操作
19    Mat se = getStructuringElement(MORPH_RECT, Size(5, 5), Point(-1, -1));
20    morphologyEx(mask, mask, MORPH_OPEN, se);
21    imshow("binary", mask);
22    imwrite("D:/binary.png", mask);
23
24    // 轮廓发现
25    vector<vector> contours;26    vector hiearchy;27    findContours(mask, contours, hiearchy, RETR_EXTERNAL, CHAIN_APPROX_SIMPLE);28    for (int i = 0; i 29        // 圆拟合30        RotatedRect rrt = fitEllipse(contours[i]);31        Point ct = rrt.center;32        int h = rrt.size.height;33        int w = rrt.size.width;34        printf("height : %d, width : %d \n", h, w);35        circle(image, ct, 2, Scalar(0, 0, 255), 2, 8);36        circle(image, ct, (h + w) / 4, Scalar(255, 0, 0), 2, 8, 0);37    }3839    // 显示输出40    imshow("result", image);41    imwrite("D:/result.png", image);42    waitKey(0);43    return 0;44}45


希望他会看到,如果看到给我留言知道一下!最后跟大家道歉一下,代码超过20行了@_@!!!!

天下难事,必作于易

天下大事,必作于细

 推荐阅读 

OpenCV4系统化学习路线图-视频版本!

OpenCV单应性矩阵发现参数估算方法详解

单应性矩阵应用-基于特征的图像拼接

OpenCV图像拼接改进算法之完美拼接

OpenCV | 二值图像分析的技巧都在这里

OpenCV二值图像分析之形态学应用技巧

图像色彩空间与应用转换

五分钟学会C++高效图表绘制神器调用

没想到图像直方图有这么多应用场景

基于灰度共生矩阵(GLCM)的图像纹理分析与提取

OpenCV中一个最容易搞错的形态学操作

OpenCV实现皮肤表面粗糙度3D显示

解密 | OpenCV加载图像大小是有限制的 ?

8e3ba5be029a55502063fa9fbe1b34c8.png

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/551687.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

python字符串怎么表示_python中字符串的几种表达方式(用什么方式表示字符串)...

原博文 2018-11-21 18:45 − 说明: 今天在学习python的基础的内容,学习在python中如何操作字符串,在此记录下. 主要是python中字符串的几种表达&#xff0c;表示方式。 python的几种表达方式 1 使用单引号扩起来字符串 >>> my python lession #以单引号将字符串扩...0…

dw如何写php代码提示,DW CS5 jquery代码提示插件

喜欢使用Dreamweaver(业内简称dw)做php开发的朋友应该都知道dw是从6.0开始才支持jquery代码提示的。那么对于电脑上安装的是dw cs5而又需要jquery代码提示的该怎么办呢&#xff1f;将cs5卸了然后安装6吗&#xff1f;这个方法不是很妥&#xff0c;毕竟现在dw cs软件已经是几百兆…

python3.6 django部署_Apache2+Django+Python3.6部署-

本文指导安装Apache2, mod_wsgi 4.6.5, Django2.1,以及安装过程中可能出现的问题及解决方法。1,安装Apache2.4我本机是Ubuntu16.04的系统,如果时CenterOS&#xff0c;使用yum安装就好了.sudo apt install apache2 这个安装一般没有什么问题2,源码编译安装Python3.6源码地址&…

python中文文本分析_python使用snownlp进行中文文本处理以及分词和情感分析 - pytorch中文网...

SnowNLP: 一个简单的中文文本处理库 SnowNLP是一个python写的类库&#xff0c;可以方便的处理中文文本内容&#xff0c;是受到了TextBlob的启发而写的&#xff0c;由于现在大部分的自然语言处理库基本都是针对英文的&#xff0c;于是写了一个方便处理中文的类库&#xff0c;并且…

php异步方案,php 伪异步执行实现方法

需求描述&#xff1a;客户端访问php文件&#xff0c;php需要做某个耗时的操作。例如&#xff1a;访问远程接口数据 而客户端不需耗时操作的结果只期望快速得到输出.php本身是不支持异步操作的&#xff0c;可以用子进程的方式模拟异步操作执行&#xff0c;但实现起来比较复杂而且…

python原理与架构_Python:爬虫原理和网页构造

入门网络数据爬取&#xff0c;也就是Python爬虫现实中我们使用浏览器访问网页时&#xff0c;网络是怎么运转的&#xff0c;做了什么呢&#xff1f;首先&#xff0c;必须了解网络连接基本过程原理&#xff0c;然后&#xff0c;再进入爬虫原理了解就好理解的多了。1、网络连接原理…

flutter打包的app有多大_前端大势所趋---Flutter 这篇文章会让你行动起来

Flutter和原生APP的性能对比前言自从今年google IO大会推出flutter跨平台开发框架以来&#xff0c;flutter在各个技术论坛里被吵得如日中天。flutter团队直言flutter可以帮助开发者轻松实现恒定60fps的性能体验。我们知道flutter跨平台的原理是采用dart语言预编译的方式直接编译…

用java创建窗口程序,创建窗口的应用程序

创建窗口的应用程序通过前面的基础知识的学习&#xff0c;已经对ctypes库的基本功能学会了使用&#xff0c;为了加强这种知识训练&#xff0c;以及运用刚学习的知识的快乐&#xff0c;我们来创建一个稍稍复杂一点的应用程序。这个应用程序是所有后面应用程序的基础&#xff0c;…

python前端代码_python前端HTML

超文本标记语言(Hypertext Markup Language, HTML)是一种用于创建网页的标记语言,不是一种编程语言,没有逻辑的HTML基础文档结构#声明为HTML5文档#是文档的开始标记和结束的标记,lang设置浏览器语言#定义了网页标题,在浏览器标题栏显示,charset声明编码,否则会出现乱码网页标题…

python爬取b站排行榜_实时爬取B站排行榜并保存为表格——每周一个爬虫小教程系列...

从这周开始&#xff0c;每周来一个爬虫小教程&#xff0c;希望对你们有所帮助&#xff0c;这次的目标是B站排行榜至于爬取什么内容&#xff0c;目前感觉就把序号&#xff0c;名称以及评分爬取下来吧&#xff08;因为我是边写教程边写代码的&#xff09; 这次需要用到的知识&…

java7优化,让Eclipse在10秒内启动的7个优化提速技巧

大约一个月前&#xff0c;我发表了一篇博客&#xff0c;其中介绍了对Eclipse的爱与恨。 有些人问我如何给Eclipse提速&#xff0c;这篇文章就来讨论这个问题。顺带提一下&#xff0c;这篇文章不是比较IDE&#xff0c;所以不要说你讨厌某个IDE而选择另外一个。这篇文章只是关注如…

python四位的千位百位十位_输入一个四位正整数,使用字符串切片方法,计算出这个数的个位 十位 百位 千位?...

展开全部#includeint main(){ char s[5],s1[9]"千百十62616964757a686964616fe59b9ee7ad9431333433653938个";int i;printf("输入一个四位数:");scanf("%s",s);for(i3;i>-1;i--)printf("%c%c位数&#xff1a;%c\n",s1[ii],s1[ii1],…

css 垂直居中_html中div使用CSS实现水平/垂直居中的多种方式

CSS中的居中&#xff0c;在工作中&#xff0c;会经常遇到。它可以分为水平居中和垂直居中&#xff0c;以下是几种实现居中的方式。以下例子中&#xff0c;涉及到的CSS属性值。.parent-frame { width: 200px; height: 200px; border: 1px solid red; } .child-frame { width…

python同时输出两个数组_python中实现将多个print输出合成一个数组

{"moduleinfo":{"card_count":[{"count_phone":1,"count":1}],"search_count":[{"count_phone":4,"count":4}]},"card":[{"des":"阿里技术人对外发布原创技术内容的最大平台&…

matlab如何实现降维,matlab怎么把矩阵降维

1. matlab如何对一个矩阵 求导而且不降维gradient计算数值梯度。函数F(x,y&#xff0c;。)在(x0,y0&#xff0c;。)的梯度就是函数在该点的导数&#xff0c;通常在数学上记作▽F(x0,y0&#xff0c;。)或gradF(x0,y0,。)。梯度是一个向量&#xff0c; 它的方向是函数在一点变化率…

python线程等待_python3 中 Event.wait 多线程等待

原博文 2018-04-26 20:45 − event.wait(time) 等待 time 时间后&#xff0c;执行下一步。或者在调用 event.set() 后立即执行下一步。 event.clear() 清除信号 event.set() 设置信号 event.isSet() 判断是否设置信号 要求: 定义一个按钮&#xff0c;等待 3... 相关推荐 2019-1…

php表白情话,朋友圈唯美表白短句情话 适合发朋友圈的情话

1、一个人经历了所有的苦难&#xff0c;也不要指望能和谁在一起&#xff1b;我曾经真诚的尝试过&#xff0c;但是结果我不想说。2、只要你愿意&#xff0c;只要我有&#xff0c;整个世界都是你的&#xff0c;而你只能是我的。3、只要你愿意&#xff0c;当你失落失意的时候&…

高德地图看各省分界线_深度解读|高德宣布高精地图“百元时代”背后的商业逻辑是什么...

车展前夕&#xff0c;高德的一次媒体沟通会&#xff0c;或许将为国内自动驾驶的发展带来深远影响。4月11日&#xff0c;高德地图在北京举行“高精宣言”媒体沟通会&#xff0c;表示将对高精地图服务进行升级&#xff0c;并以成本价格提供标准化高精地图&#xff0c;与合作伙伴分…

js获取ip地址_(原创)Node.JS实战31:大名鼎鼎的Express!

Express &#xff08;http://expressjs.com&#xff09;是Node.JS中一个简洁、灵活、强大的Web应用框架&#xff0c; 它提供了一系列强大特性&#xff0c;可以帮助我们快速创建各种Web 应用&#xff0c;也可用来编写各种的Web工具。Express博大精深&#xff0c;本文在此只做简单…

pythonpath manager_python 路径操作工具 pathlib,比 os 模块好用太多

在 python 当中&#xff0c;如果你想控制路径&#xff0c;基本上绕不开 os.path。我希望看完这篇文章以后&#xff0c;熟练使用 python 的你能立刻开始使用 pathlib 模块&#xff0c;一刻也不要耽误。pathlib 相对于 os.path 有以下优势&#xff1a;pathlib 导入更加清晰&#…