【发布时间】:2025-12-09 03:50:01
【问题描述】:
我正在尝试通过使用下面的代码将图像与数字 0 - 9 的位图进行比较,对图像执行基本的纯数字 OCR。我试图按照this question 的答案中的代码进行操作,但它没有返回正确的结果。我面临两个主要问题:
1:如果程序确定数字 0 出现在任何给定点,那么它也确定 1、2、3、...和 9 出现在该位置,这显然不正确。
2:它找到数字的位置......大多数位置都是空白(白色)空格。
我会第一个承认使用 lockbits 方法对我来说是新的,因为我通常使用 getPixel() 方法进行比较,但是对于这个项目来说太慢了,所以我可能正在做一个菜鸟错误或2。
谢谢你的帮助!!!
附: OCR 的图像是 RTA,我相信其他一切都是不言自明的。
void newOCR()
{
Rectangle rect = new Rectangle(0, 0, 8, 9);
Rectangle numRect = new Rectangle(0, 0, 8, 9);
for (int i = 0; i < RTA.Width - 8; i++)
{
for (int j = 0; j < RTA.Height - 9; j++)
{
rect.Location = new Point(i, j);
for (int n = 0; n < numbers.Length; n++)
{
System.Drawing.Imaging.BitmapData data = RTA.LockBits(rect, System.Drawing.Imaging.ImageLockMode.ReadOnly, RTA.PixelFormat);
System.Drawing.Imaging.BitmapData numData = numbers[n].LockBits(numRect, System.Drawing.Imaging.ImageLockMode.ReadOnly, numbers[n].PixelFormat);
unsafe
{
byte* ptr = (byte*)data.Scan0.ToPointer();
byte* numPtr = (byte*)data.Scan0.ToPointer();
int width = rect.Width * Image.GetPixelFormatSize(data.PixelFormat) / 8;
for(int y = 0; y < rect.Height; y++)
{
bool outBreak = false;
for(int x = 0; x < width; x++)
{
if(*ptr != *numPtr)
{
outBreak = true;
break;
}
else if(y == rect.Height - 1 && x == width - 1)
{
timeDict.Add(new Point(i, j), n);
}
ptr++;
numPtr++;
}
if(outBreak)
{
break;
}
ptr += data.Stride - width;
numPtr += numData.Stride - width;
}
RTA.UnlockBits(data);
numbers[n].UnlockBits(numData);
}
}
}
}
}
【问题讨论】:
-
这
byte* numPtr = (byte*)data.Scan0.ToPointer();不应该是byte* numPtr = (byte*)numData.Scan0.ToPointer();。看起来您正在将位图与自身进行比较:-) -
@IvanStoev 是的!那个作品很完美。见——菜鸟失误。如果你回答我会接受它:) 非常感谢!
-
欢迎您。我不太确定我是否应该发布这样的答案,但既然你在问,我会的。
-
@IvanStoev 这就是答案。它解决了问题,我对此表示赞赏。我只是不高兴有人对我的问题投了反对票 LOL
-
没问题,这很容易解决 :-) 保重,伙计。
标签: c# bitmap comparison lockbits