C# 查找迷宫路径

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

cs 复制代码
using var img = new Image<Bgr, byte>(_path);
using var grayImg = img.Convert<Gray, byte>();

2.自动二值化图像

cs 复制代码
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.图像裁剪,只留下迷宫区域,如果不裁剪会出现最外围的路径

cs 复制代码
 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.查找轮廓,并绘制在全黑图像上

cs 复制代码
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.膨胀

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

6.腐蚀

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

7.膨胀腐蚀相减

cs 复制代码
 using var diff = new Mat();
CvInvoke.AbsDiff(dilated, eroded, diff);

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

cs 复制代码
 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);
相关推荐
‎ദ്ദിᵔ.˛.ᵔ₎1 分钟前
STL 栈 队列
开发语言·c++
勿忘,瞬间6 分钟前
数据结构—顺序表
java·开发语言
张張40810 分钟前
(域格)环境搭建和编译
c语言·开发语言·python·ai
weixin_4235339914 分钟前
【Windows11离线安装anaconda、python、vscode】
开发语言·vscode·python
fzb5QsS1p17 分钟前
告别重复造轮子,Qt 快速开发脚手架
开发语言·qt·php
航Hang*19 分钟前
第3章:Linux系统安全管理——第2节:部署代理服务
linux·运维·服务器·开发语言·笔记·系统安全
周杰伦fans20 分钟前
C# required 关键字详解
开发语言·网络·c#
༾冬瓜大侠༿22 分钟前
vector
c语言·开发语言·数据结构·c++·算法
liu****35 分钟前
第16届省赛蓝桥杯大赛C/C++大学B组(京津冀)
开发语言·数据结构·c++·算法·蓝桥杯
fengfuyao98535 分钟前
VC++基于服务器的点对点文件传输实例
服务器·开发语言·c++