C#中OpenCVSharp实现轮廓检测
作者:IT_BOY__ 时间:2022-04-03 17:38:11
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<Vector<Point>> 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()这个函数,方便大家调用进行测试
测试结果如下:
来源:https://blog.csdn.net/IT_BOY__/article/details/91041004
标签:C#,OpenCVSharp,轮廓检测
0
投稿
猜你喜欢
SpringBoot实用小技巧之如何动态设置日志级别
2023-02-09 04:27:58
详解Java对象的强、软、弱和虚引用+ReferenceQueue
2021-11-30 16:23:01
java之swing表格实现方法
2023-06-05 09:44:03
Android编程开发之Spinner组件用法
2022-09-02 17:55:26
JAVA基础-GUI
2023-10-24 22:26:07
c#委托详解和和示例分享
2022-10-26 12:29:41
C++编程中用put输出单个字符和cin输入流的用法
2023-05-28 06:14:49
Java如何去掉指定字符串的开头的指定字符
2022-05-23 13:28:31
c#实现输出的字符靠右对齐的示例
2023-02-26 12:23:39
Android优化提升应用启动速度及Splash页面的设计
2022-02-18 06:02:27
C#设计模式之策略模式
2023-08-08 21:00:11
c# 实现KMP算法的示例代码
2023-12-02 06:35:19
Java RPC框架熔断降级机制原理解析
2023-06-07 06:01:48
简单了解JAVA public class与class区别
2023-11-15 23:59:26
Mybatis使用大于等于或小于等于进行比较
2021-12-25 10:21:44
java使用EasyExcel导入导出excel
2022-10-31 03:48:30
dubbo服务链路跟踪方式
2023-08-24 09:54:21
SpringCloud如何搭建一个多模块项目
2022-10-22 13:33:39
C#微信开发之获取接口调用凭据
2023-10-28 07:57:54
Java的动态分派和静态分派的实现
2023-10-09 12:58:37