完成工作
我尝试通过以下步骤检测和读取车牌:
1)使用 houghlines 检测四边形(此步骤已经遇到此问题,抱歉)
2)将此四边形的透视校正为矩形
3)在此矩形上执行 OCR
您可以在此处查看我的代码的视觉问题/效果。
代码本身可以在这里找到。
免责声明:我为此使用 Emgu CV,但如果有人愿意回答我,我不想打扰他或她专门给我这个包装的答案。
public string loadImage()
{
OpenFileDialog ofd = new OpenFileDialog();
ofd.ShowDialog();
String s = ofd.FileName.Normalize();
return s;
}
public void processImage()
{
String s = loadImage();
Image<Gray, Byte> img = new Image<Gray, byte>(s);
Console.WriteLine("read file @" + s);
Image<Gray, Byte> tinyGrayImg = img.Resize(0.25, INTER.CV_INTER_NN);
CvInvoke.cvShowImage("original gray", tinyGrayImg);
Console.WriteLine("converted " + s + " to grayscale");
Image<Gray, Byte> canny = new Image<Gray, byte>(CvInvoke.cvGetSize(tinyGrayImg));
CvInvoke.cvCanny(tinyGrayImg, canny, 97, 225, 3);
CvInvoke.cvShowImage("canny", canny);
Console.WriteLine("applied Canny to " + s);
try
{
MemStorage mem = new MemStorage();
Image<Bgr, byte> linesImg = canny.Convert<Bgr, byte>();
IntPtr lines = CvInvoke.cvHoughLines2(canny, mem.Ptr, HOUGH_TYPE.CV_HOUGH_PROBABILISTIC, 1, Math.PI / 180, 70, 30, 10);
Seq<LineSegment2D> segments = new Seq<LineSegment2D>(lines, mem);
LineSegment2D[] segArray = segments.ToArray();
for (int i = 0; i < segArray.Length; i++)
{
linesImg.Draw(segArray[i], new Bgr(Color.Red), 1);
}
CvInvoke.cvShowImage("lines", linesImg);
}
catch (Exception e)
{
MessageBox.Show(e.Message);
}
问题
正如您在附加图像中看到的(我没有足够的业力直接添加图像),HOUGH_PROBABILISTIC 过滤器无法按预期工作,我不知道为什么无法识别车牌的边缘。欢迎任何想法如何达到我的目标。