Использование MODI в C# для чтения изображений - числа с длиной 1 отсутствуют
Я собираюсь создать приложение на C#, в котором я пытаюсь читать текст из gif-изображения (OCR) - я использую MODI, а изображения немного похожи на лото-купон (случайные числа в строках и столбцах). Теперь я получил следующий код, который читает все числа, кроме отдельных чисел (1, 2, 3...)
MODI.Document objModi = new MODI.Document();
objModi.Create("C:\\image.gif");
objModi.OCR(MODI.MiLANGUAGES.miLANG_DANISH, true, true);
MODI.Image image = (MODI.Image)objModi.Images[0];
MODI.Layout layout = image.Layout;
Я не могу изменить содержимое изображения, но могу ли я что-то сделать с помощью приведенного выше кода, чтобы он мог читать отдельные числа?
3 ответа
Решение
Не нашел идеального решения, получил лучший результат, добавив дополнительный контент к моей картинке, как описано в моем последнем комментарии.
string reult=""; foreach(MODI.Word worditems в imag.Layout.Words) { result+=worditems.Text+','; }
Вы можете добавить следующий код
numofwords = layout.NumWords;
for (int l = 0; l < numofwords; l++)
{
word = (MODI.Word)layout.Words[l];
for (int j = 0; j < word.Rects.Count; j++)
{
MODI.MiRect rect = (MODI.MiRect)word.Rects[j];
if (j == 0)
{
top = rect.Top;
}
if (height == 0 || height < (rect.Bottom - rect.Top))
height = rect.Bottom - rect.Top;
width = rect.Right - rect.Left;
right = rect.Left + width;
top = rect.Top;
left = rect.Left;
}
OCRDocWord ocrword = new OCRDocWord(top, left, width, height, word.Text);
width = 0;
wordlist.Add(ocrword);
}