• C# 查找迷宫路径


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

    1. using var img = new Imagebyte>(_path);
    2. using var grayImg = img.Convertbyte>();

    2.自动二值化图像

    1. using var inputGrayOut = new Imagebyte>(grayImg.Size);
    2. // 计算OTSU阈值
    3. var threshold = CvInvoke.Threshold(grayImg, inputGrayOut, 0, 255, ThresholdType.BinaryInv | ThresholdType.Otsu);
    4. // 二值化图像
    5. using var binaryImage = inputGrayOut.ThresholdBinary(new Gray(threshold), new Gray(255));

     

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

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

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

    1. using VectorOfVectorOfPoint contours = new VectorOfVectorOfPoint();
    2. using Mat hierarchy = new Mat();
    3. CvInvoke.FindContours(binaryImage2, contours, hierarchy, RetrType.External, ChainApproxMethod.ChainApproxSimple);
    4. // 绘制在全黑图像上
    5. using var draw = new Imagebyte>(binaryImage2.Size);
    6. CvInvoke.DrawContours(draw, contours, 0, new Bgr(255, 255, 255).MCvScalar,1);

     

    5.膨胀

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

     

    6.腐蚀

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

     

    7.膨胀腐蚀相减

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

     

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

    1. using VectorOfVectorOfPoint contours2 = new VectorOfVectorOfPoint();
    2. using var hierarchy2 = new Mat();
    3. //CvInvoke.CvtColor(diff, diff, ColorConversion.Bgr2Gray);
    4. CvInvoke.FindContours(diff, contours2, hierarchy2, RetrType.External, ChainApproxMethod.ChainApproxSimple);
    5. double maxArea = 0;
    6. int maxAreaIndex = 0;
    7. for (int i = 0; i < contours2.Size; i++)
    8. {
    9. double area = CvInvoke.ContourArea(contours2[i]);
    10. if (area > maxArea)
    11. {
    12. maxArea = area;
    13. maxAreaIndex = i;
    14. }
    15. }
    16. CvInvoke.DrawContours(img, contours2, maxAreaIndex, new Bgr(0, 0, 255).MCvScalar, 2);

  • 相关阅读:
    如何编辑扫描的PDF文件?
    【微软技术栈】C#.NET 中的管道操作
    swift语言用哪种库适合做爬虫?
    单例模式Singleton
    初级篇—第八章精讲MySQL数据类型
    三、开发工具
    【Arduino28】LM35温度传感器实验
    数据库系统概论必背知识
    iOS 使用陀螺仪实现裸眼3d效果
    如果给你一次机会,你想对前任说什么?是祝福他还是恨他
  • 原文地址:https://blog.csdn.net/ftfmatlab/article/details/132919702