c# opencv 轮廓检测_C#中OpenCVSharp实现轮廓检测

OpenCv提供了函数 findContours()用于对物体轮廓进行检测,该函数实现算法是由S.suzuki K.Abe于1985年发表的。OpenCVSharp封装了这个函数,有2个参数(contours,hierarchy)要做特别的说明。

public static void FindContours(InputOutputArray image, out Point[][] contours,

out HierarchyIndex[] hierarchy, RetrievalModes mode,

ContourApproximationModes method, Point? offset = null);

解析:contours 的类型是Point[][],它相当于OpenCV中的Vector> contours,存储多个轮廓,每个轮廓是由若干个点组成,可以在该函数前声明Point[][] contours;,在C#中没有赋值的变量在用的时候是不允许的,因为它是输出的结果,可以不需要给它new空间,但必须在函数的参数中声明是out;参数hierarchy为包含图像拓扑结构的信息,它是HierarchyIndex[]类型,这是输入的结果,同样要在函数的参数中声明为out。具体代码如下:

using System;

using System.Collections.Generic;

using System.Linq;

using System.Text;

using System.Threading.Tasks;

using OpenCvSharp;

using OpenCvSharp.Extensions;

namespace OpenCvSharp_03

{

class Program

{

static void Main(string[] args)

{

Mat srcImage = Cv2.ImRead(@"D:\MyData\circle.jpg");

Mat dst_Image = MyFindContours(srcImage);

Cv2.ImShow("srcImage:", srcImage);

Cv2.ImShow("contours", dst_Image);

Cv2.WaitKey();

}

public static Mat MyFindContours(Mat srcImage)

{

//转化为灰度图

Mat src_gray = new Mat();

Cv2.CvtColor(srcImage, src_gray, ColorConversionCodes.RGB2GRAY);

//滤波

Cv2.Blur(src_gray, src_gray, new Size(3, 3));

//Canny边缘检测

Mat canny_Image = new Mat();

Cv2.Canny(src_gray, canny_Image, 100, 200);

//获得轮廓

Point[][] contours;

HierarchyIndex[] hierarchly;

Cv2.FindContours(canny_Image,out contours,out hierarchly, RetrievalModes.Tree,ContourApproximationModes.ApproxSimple,new Point(0,0));

//将结果画出并返回结果

Mat dst_Image = Mat.Zeros(canny_Image.Size(),srcImage.Type());

Random rnd = new Random();

for (int i = 0; i < contours.Length; i++)

{

Scalar color = new Scalar(rnd.Next(0,255),rnd.Next(0,255),rnd.Next(0,255));

Cv2.DrawContours(dst_Image, contours, i, color, 2,LineTypes.Link8, hierarchly);

}

return dst_Image;

}

}

}

我封装好了MyFindContours()这个函数,方便大家调用进行测试

测试结果如下:

到此这篇关于C#中OpenCVSharp实现轮廓检测的文章就介绍到这了,更多相关C# OpenCVSharp轮廓检测内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

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

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

相关文章

鸿蒙系统的挑战,简单的讲解下何为鸿蒙系统,可能会挑战你的认知颠覆你的想象...

本帖最后由 一梦盛夏 于 2020-12-2 17:33 编辑这篇文章可能会颠覆你的想象&#xff0c;挑战你的认知&#xff0c;请耐心阅读。今天不说专业术语&#xff0c;全部用比喻方式来聊&#xff0c;这样会更明白一些&#xff0c;也欢迎大家一起来讨论。首先&#xff0c;我们先聊聊何为鸿…

linux nat冲突,Linux系统下的NAT及防火墙的混合应用

2011-11-28 13:03朋友你好&#xff01;我刚开始搞linux&#xff0c;碰到了很多问题&#xff0c;想问你下&#xff0c;希望能帮我解答下。下面是我的一段shell 程序#&#xff01;/bin/shwhile [ 0 ]doread scoreif [ $score -lt 60 ];thenecho " you must work hard!"…

外贸常用术语_13个常用的国际贸易术语详解

原标题&#xff1a;13个常用的国际贸易术语详解做外贸的我们一定要详细的了解外贸运输术语的含义&#xff0c;每一个术语买卖双方所需承担的责任与义务。这样能够更好的区分买卖双方该承担履行的责任与义务。很多时候我们只是知道我们日常经常用到的&#xff0c;其他的还是不是…

卡夫卡–一次语义学

在分布式环境中&#xff0c;故障是很常见的情况&#xff0c;可以随时发生。 在Kafka环境中&#xff0c;代理可能会崩溃&#xff0c;网络故障&#xff0c;处理故障&#xff0c;发布消息时失败或无法使用消息等。这些不同的场景引入了不同类型的数据丢失和重复。 失败场景 A&am…

android 打印机蜂鸣器,CANON喷墨打印机 蜂鸣器响5声不打印的问题解决办法

CANON喷墨打印机 蜂鸣器响5声不打印的问题解决办法通常我们如果遇到CANON打印机蜂鸣器响5声即表示废墨仓满&#xff0c;一般都可以通过按键且使用02、03、05墨盒的机型按下面方法操作&#xff1a;同时按住左、右两键&#xff0c;插入电源&#xff0c;然后松开两键&#xff1b;按…

python病毒usb文件自动安装_win7禁USB自动安装驱动功能避免木马病毒入侵

用户在限制USB设备使用方面&#xff0c;首先考虑的就是禁止其自动播放&#xff0c;以避免木马病毒入侵&#xff0c;但很多时候&#xff0c;这样的方法并不是很有效。如果你是Win7用户&#xff0c;那就可以通过它独有的“权限控制”技术&#xff0c;从源头上控制USB设备的自动运…

java错误代码典型案例_Java代码中的典型错误

java错误代码典型案例该页面包含在与我一起工作的人的Java代码中看到的最典型的错误。 静态分析&#xff08;出于明显的原因&#xff0c;我们使用查询无法捕获所有错误&#xff0c;这就是为什么我决定在此处列出所有错误的原因。 如果您要在此处添加其他内容&#xff0c;请告诉…

tinymce vue 部分工具不显示_tinymce-vue使用问题及解决记录

一、本地图片上传&#xff1a;1.转成base64&#xff0c;转换后的字符粘贴到notpadd中看了下&#xff0c;有近20万个字符&#xff0c;所以直接没考虑2.选择图片后调用后台方法传到服务器&#xff0c;保存后返回一个网络地址&#xff0c;传入success的回调方法&#xff0c;通过网…

清洁单元测试

使用JUnit和一些模拟库编写“单元测试”测试很容易。 即使测试甚至不是单元测试并提供可疑的价值&#xff0c;它们也可能产生使某些涉众满意的代码覆盖范围。 编写单元测试&#xff08;在理论上是单元测试&#xff0c;但比基础代码更复杂&#xff09;因此也很容易编写&#xff…

谷歌发布android+8.2,谷歌Pixel 2代三款新机齐曝光:骁龙835+Android 8.0

随着5月份谷歌I/O大会的临近&#xff0c;关于Android O(安卓8.0)和Pixel手机的消息逐渐多了起来。据外媒报道&#xff0c; Android Open Source Project的代码表中确认&#xff0c;三款Pixel新机搭载的都是MSM8998芯片&#xff0c;也就是骁龙835。目前&#xff0c;Pixel 2的代号…

怎么停止skywalking_Skywalking部署常见问题以及注意事项

Skywalking部署常见问题以及注意事项IntroSkyWalking 创建与2015年&#xff0c;提供分布式追踪功能。从5.x开始&#xff0c;项目进化为一个完成功能的Application Performance Management系统。他被用于追踪、监控和诊断分布式系统&#xff0c;特别是使用微服务架构&#xff0c…

akka的介绍_Akka笔记–演员介绍

akka的介绍过去做过多线程的任何人都不会否认管理多线程应用程序有多么艰辛和痛苦。 我说管理是因为它开始很简单&#xff0c;一旦您开始看到性能改进&#xff0c;它就会变得非常有趣。 但是&#xff0c;当您发现没有一种简单的方法可以从子任务中的错误或难以发现的僵尸错误中…

HTML语言name,HTML a 标签的 name 属性

延伸阅读&#xff1a;使用 name 属性还是 id 属性&#xff1f;在 HTML 4.0 之前的版本中&#xff0c;只有使用 标签的 name 属性才能创建片段标识符。随着 HTML 4.0 中 id 属性的出现&#xff0c;所有 HTML 或 XHTML 元素都可以是片段标识符。这是因为 id 标识符几乎可以用在所…

使用模拟进行测试

如果使用正确的方法&#xff0c;模拟对象将非常有用。 我在需要驱动软件开发使用的帖子中分享了一些使用Mock Objects的经验。 在这篇文章中&#xff0c;我分享了两件事 –使用模拟进行基于合同的测试。 –用于组织模拟代码的模式。 基于合同的测试 让我们以正在构建汇款服…

hazelcast_Hazelcast的MapLoader陷阱

hazelcastHazelcast提供的核心数据结构之一是IMap<K, V> &#xff0c;它扩展了java.util.concurrent.ConcurrentMap &#xff0c;它基本上是一个分布式地图&#xff0c;通常用作缓存。 您可以将此类地图配置为使用自定义MapLoader<K, V> -每次尝试从该地图&#xf…

html ul左侧浮动,UL里的LI元素左浮动层一行显示时使其居中的方法

在制作页面是&#xff0c;li浮动是很常用的&#xff0c;一般情况也不用其居中&#xff0c;但有时&#xff0c;其特殊原因需要居中&#xff0c;这是就有点犯难了&#xff0c;这里有了一个很好的解决方法&#xff0c;主要是用了相对定位的原理。在ul外报一层&#xff0c;使其相对…

aws s3 獲取所有文件_AWS SA associate 证书考试学习记录-EBS,S3,EFS比较

我们的目标&#xff0c;就是花最少的时间&#xff0c;学到最多的东西&#xff1a;-&#xff09;在AWS中&#xff0c;可以选择的存储服务很多&#xff0c;纷繁复杂&#xff0c;新手根本弄不清楚选择哪个。因为做为一个云架构师&#xff0c;你并不是让你的产品能用就够了&#xf…

ios调用restful接口_做iOS上最好的REST API测试App

对于Web开发者和移动应用开发者来说&#xff0c;少不了和REST API打交道。何为REST API&#xff0c;维基百科是这么解释的(https://zh.wikipedia.org/wiki/REST)REST(英文&#xff1a;Representational State Transfer)是Roy Thomas Fielding博士于2000年在他的博士论文中提出来…

Java 14:记录

Java 14是在几周前问世的&#xff0c;它引入了Record类型&#xff0c;它是一个不变的数据载体类&#xff0c;旨在容纳一组固定的字段。 请注意&#xff0c;这是预览语言功能 &#xff0c;这意味着必须使用--enable-preview标志在Java编译器和运行时中显式启用它。 我将直接介绍…

html设置顶部对齐,HTML / CSS文本从div顶部对齐

首先&#xff0c;你需要修复你的CSS选择器 .你可以通过这种方式t write all those id .#content #main #services只需选择1个元素和他的孩子 .例如&#xff0c;如果你测试它&#xff0c;它将适用于你&#xff1a;#services .langelis .txt {width: 440px;height: auto;float: l…