c# – 在位图中查找blob

前端之家收集整理的这篇文章主要介绍了c# – 在位图中查找blob前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我在位图中使用 AForge.Net查找blob,我的位图如下:

我的问题是AForge.Net只检测到一个blob,实际上细线上有两个连接的blob.

我的问题是有一个算法可以确定它们之间有两个连接很薄的大blob?我如何在C#或VB中实现此算法?

样品图片

解决方法

正如其他人所建议的,我会使用OpenCv而不是AForge(似乎AForge已经有一段时间没有更新,OpenCv有很多可用的样本).
使用C#,我建议使用 OpenCvSharp nuget包.它很容易使用,因为代码看起来像C或python代码,就像大多数样本一样.

所以,OpenCv有一个blob探测器,但是它会检测blob中心,所以在你的情况下,你看起来比轮廓更多(通常是这种情况).

幸运的是,使用OpenCv和你的样本图像,它只是没有做任何花哨的事情(我们甚至不必先侵蚀图像),我们可以使用findContours,过滤一些毛刺,并获得convexHull.这是一个示例代码,演示了:

using (var src = new Mat(filePath))
using (var gray = new Mat())
{
    using (var bw = src.CvtColor(ColorConversionCodes.BGR2GRAY)) // convert to grayscale
    {
        // invert b&w (specific to your white on black image)
        Cv2.BitwiseNot(bw,gray);
    }

    // find all contours
    var contours = gray.FindContoursAsArray(RetrievalModes.List,ContourApproximationModes.ApproxSimple);
    using (var dst = src.Clone())
    {
        foreach (var contour in contours)
        {
            // filter small contours by their area
            var area = Cv2.ContourArea(contour);
            if (area < 15 * 15) // a rect of 15x15,or whatever you see fit
                continue;

            // also filter the whole image contour (by 1% close to the real area),there may be smarter ways...
            if (Math.Abs((area - (src.Width * src.Height)) / area) < 0.01f)
                continue;

            var hull = Cv2.ConvexHull(contour);
            Cv2.Polylines(dst,new[] { hull },true,Scalar.Red,2);
        }

        using (new Window("src image",src))
        using (new Window("dst image",dst))
        {
            Cv2.WaitKey();
        }
    }
}

猜你在找的C#相关文章