I want to find small black squares / rectangles in the scanned sheet:
- Reverse image if necessary.
- delete the white page.
Input Image:
Sample Image 1 http://us.cdn.persiangig.com/preview/ii2jf6/2.jpg
Output Image:
Sample Image 2 http://us.cdn.persiangig.com/preview/9ntpnc/1.jpg
My code to find the square:
Bitmap pic =(Bitmap) pictureBox1.Image;
AForge.Imaging.Filters.Median Medianfilter = new AForge.Imaging.Filters.Median();
Medianfilter.ApplyInPlace(pic);
Bitmap grayImage;
if (pic.PixelFormat != PixelFormat.Format16bppGrayScale && pic.PixelFormat != PixelFormat.Format8bppIndexed)
{
AForge.Imaging.Filters.Grayscale grayscalefilter = new AForge.Imaging.Filters.Grayscale(0.2125, 0.7154, 0.0721);
grayImage = grayscalefilter.Apply((Bitmap)pictureBox1.Image);
}
else
{
grayImage = pic;
}
Threshold(ref grayImage, Convert.ToInt32(textBox1.Text), Convert.ToInt32(textBox1.Text));
Invert invertfilter = new Invert();
invertfilter.ApplyInPlace(grayImage);
DifferenceEdgeDetector EdgeDetectorfilter = new DifferenceEdgeDetector();
EdgeDetectorfilter.ApplyInPlace(grayImage);
Dilatation Dilatationfilter = new Dilatation();
Dilatationfilter.ApplyInPlace(grayImage);
Search for an object (square / rectangle) in the image:
BitmapData bitmapData = grayImage.LockBits(new Rectangle(0, 0, grayImage.Width, grayImage.Height),
ImageLockMode.ReadWrite, grayImage.PixelFormat);
BlobCounter blobCounter = new BlobCounter();
blobCounter.FilterBlobs = true;
blobCounter.MinHeight = 10;
blobCounter.MinWidth = 10;
blobCounter.MaxHeight = 50;
blobCounter.MaxWidth = 50;
blobCounter.ProcessImage(bitmapData);
Blob[] blobs = blobCounter.GetObjectsInformation();
grayImage.UnlockBits(bitmapData);
SimpleShapeChecker shapeChecker = new SimpleShapeChecker();
Graphics g = Graphics.FromImage(pic);
Pen redPen = new Pen(Color.Red, 2);
Pen bluePen = new Pen(Color.Blue, 2);
for (int i = 0, n = blobs.Length; i < n; i++)
{
List<IntPoint> edgePoints = blobCounter.GetBlobsEdgePoints(blobs[i]);
List<IntPoint> corners;
if (shapeChecker.IsQuadrilateral(edgePoints, out corners))
{
PolygonSubType subType = shapeChecker.CheckPolygonSubType(corners);
Pen pen;
if (subType == PolygonSubType.Square)
{
pen = (corners.Count == 4) ? bluePen : redPen;
g.DrawPolygon(pen, ToPointsArray(corners));
}
}
}
redPen.Dispose();
bluePen.Dispose();
g.Dispose();
pictureBox1.Image = pic;
The problem is the low accuracy of detecting squares and rectangles !!!
How can I solve this problem?
source
share