C# 查找迷宫路径

news/2024/11/28 8:17:28/

1.导入图像,并且将图像转灰度

using var img = new Image<Bgr, byte>(_path);
using var grayImg = img.Convert<Gray, byte>();

2.自动二值化图像

using var inputGrayOut = new Image<Gray, byte>(grayImg.Size);
// 计算OTSU阈值
var threshold = CvInvoke.Threshold(grayImg, inputGrayOut, 0, 255, ThresholdType.BinaryInv | ThresholdType.Otsu);
// 二值化图像
using var binaryImage = inputGrayOut.ThresholdBinary(new Gray(threshold), new Gray(255));

 

3.图像裁剪,只留下迷宫区域,如果不裁剪会出现最外围的路径

 using var dilated2 = new Mat();
CvInvoke.Dilate(binaryImage, dilated2, kernel, new Point(-1, -1), trackBar2.Value, BorderType.Default, new MCvScalar());
using Mat hierarchy3 = new Mat();
using VectorOfVectorOfPoint contours3 = new VectorOfVectorOfPoint();
CvInvoke.FindContours(dilated2, contours3, hierarchy3, RetrType.External, ChainApproxMethod.ChainApproxSimple);
using var binaryImage2=binaryImage.Copy(CvInvoke.BoundingRectangle(contours3[0]));

4.查找轮廓,并绘制在全黑图像上

using VectorOfVectorOfPoint contours = new VectorOfVectorOfPoint();
using Mat hierarchy = new Mat();
CvInvoke.FindContours(binaryImage2, contours, hierarchy, RetrType.External, ChainApproxMethod.ChainApproxSimple);
// 绘制在全黑图像上
using var draw = new Image<Gray, byte>(binaryImage2.Size);
CvInvoke.DrawContours(draw, contours, 0, new Bgr(255, 255, 255).MCvScalar,1);

 

5.膨胀

 using var dilated = new Mat();
CvInvoke.Dilate(draw, dilated, kernel, new Point(-1, -1), trackBar2.Value, BorderType.Default, new MCvScalar());

 

6.腐蚀

 using var eroded = new Mat();CvInvoke.Erode(dilated, eroded, kernel, new Point(-1, -1), trackBar2.Value, BorderType.Default, new MCvScalar());

 

7.膨胀腐蚀相减

 using var diff = new Mat();
CvInvoke.AbsDiff(dilated, eroded, diff);

 

8.在差异图diff中查找轮廓,并在原图上绘制轮廓(寻找最大边框绘画)

 using VectorOfVectorOfPoint contours2 = new VectorOfVectorOfPoint();using var hierarchy2 = new Mat();
//CvInvoke.CvtColor(diff, diff, ColorConversion.Bgr2Gray);CvInvoke.FindContours(diff, contours2, hierarchy2, RetrType.External, ChainApproxMethod.ChainApproxSimple);double maxArea = 0;int maxAreaIndex = 0;for (int i = 0; i < contours2.Size; i++){double area = CvInvoke.ContourArea(contours2[i]);if (area > maxArea){maxArea = area;maxAreaIndex = i;}}CvInvoke.DrawContours(img, contours2, maxAreaIndex, new Bgr(0, 0, 255).MCvScalar, 2);


http://www.ppmy.cn/news/1112952.html

相关文章

汇编指令概述 ATT汇编基本语法

操作系统 南大 计算机体系结构 性能分析 建模 深入理解计算机系统CMU15213_课件 深入理解计算机系统-笔记-第一章-计算机系统漫游 uCore OS实验指导书和源码网址 (2017) How-to-Make-a-Computer-Operating-System 各章节代码 linux 系统编程 双系统安装 ucore实验中…

AMD 5600G + 华硕A520M 引起的 Windows与Linux双系统冲突问题

上两周用了十年的i3技嘉主板的台式电脑进系统花屏&#xff0c;无法使用。机器用了这么久&#xff0c;我也懒得研究是是什么问题导致的&#xff0c;直接在网上买了一堆新的配件进行组装&#xff0c;具体的配置如下&#xff1a; 金百达DDR4 银爵 16G 3200 DDR4 长鑫颗粒&#xff…

2023面试知识点一

1、新生代和老年代的比例 默认的&#xff0c;新生代 ( Young ) 与老年代 ( Old ) 的比例的值为 1:2 ( 该值可以通过参数 –XX:NewRatio 来指定 )&#xff0c;即&#xff1a;新生代 ( Young ) 1/3 的堆空间大小。老年代 ( Old ) 2/3 的堆空间大小。其中&#xff0c;新生代 ( …

【毕设选题】opencv 图像识别 指纹识别 - python

文章目录 0 前言1 课题背景2 效果展示3 具体实现3.1 图像对比过滤3.2 图像二值化3.3 图像侵蚀细化3.4 图像增强3.5 特征点检测 4 OpenCV5 最后 0 前言 &#x1f525; 这两年开始毕业设计和毕业答辩的要求和难度不断提升&#xff0c;传统的毕设题目缺少创新和亮点&#xff0c;往…

用思维导图了解《骆驼祥子》的内容

《骆驼祥子》是一部经典的中国小说&#xff0c;由著名作家老舍所创作。小说以北京城下贫苦的人们为背景&#xff0c;讲述了一个叫做祥子的年轻人&#xff0c;为了摆脱贫困和苦难&#xff0c;不断地奋斗和努力的故事。下面我们进行文字思维导图的方式来一起了解一下整个故事的内…

什么是 Microsoft Office 365? Excel on Cloud 的好处

什么是Office 365 Office 365 是 Microsoft 的一套程序&#xff0c;可以在本地运行&#xff0c;也可以同步到云存储。 可以从访问程序。 借助 Office 365&#xff0c;您可以在任何地方进行工作&#xff0c;并与世界各地的同事共享工作文档。 Office 365 支持的设备&#xff1a…

Postman应用——下载注册和登录

文章目录 下载安装注册登录注册账号登录账号 下载安装 Postman下载&#xff1a;https://www.postman.com/ 访问链接后&#xff0c;进入首页&#xff0c;根据自己的操作系统下载对应的版本。 找到下载到的目录直接双击.exe文件&#xff0c;会默认安装在C盘&#xff0c;安装完会…

动态规划:子序列问题(C++)

动态规划&#xff1a;子序列问题 前言子序列问题1.最长递增子序列&#xff08;中等&#xff09;2.摆动序列&#xff08;中等&#xff09;3.最长递增子序列的个数&#xff08;中等&#xff09;4.最长数对链&#xff08;中等&#xff09;5.最长定差子序列&#xff08;中等&#x…