public static void Recognize() { int n_images = Workspace.Images.Length; int i_image = n_images - 1; //i_image = 0; i_image = 2; string fileName = Workspace.Images[i_image]; string imageFile = Path.Combine(Workspace.InputFolder, fileName); string language = "eng"; int oem = (int)eOcrEngineMode.OEM_DEFAULT; string name = Path.GetFileNameWithoutExtension(imageFile); { using (Bitmap bmp = Bitmap.FromFile(imageFile) as Bitmap) { using (GreyImage greyImage = GreyImage.FromImage(bmp)) { ImageThresholder thresholder = new AdaptiveThresholder(); using (BinaryImage binImage = thresholder.Threshold(greyImage)) { DateTime started = DateTime.Now; DateTime ended = DateTime.Now; Rectangle[] rois = new Rectangle[] { Rectangle.FromLTRB(807, 43, 1351, 613), Rectangle.FromLTRB(4, 604, binImage.Width - 15, binImage.Height-35) }; int nROIs = rois.Length; string[] texts = new string[nROIs]; #if PARALLEL Parallel.For(0, nROIs, delegate(int iROI) #else using (TesseractProcessor processor = new TesseractProcessor()) for (int iROI = 0; iROI < nROIs; iROI++) #endif { #if PARALLEL using (TesseractProcessor processor = new TesseractProcessor()) #endif { Rectangle roi = rois[iROI]; { //oem = (int)eOcrEngineMode.OEM_TESSERACT_CUBE_COMBINED; processor.Init(Workspace.TessdataFolder, language, oem); processor.UseROI = true; processor.ROI = roi; unsafe { texts[iROI] = processor.RecognizeBinaryImage( binImage.BinaryData, binImage.Width, binImage.Height); } } } }
static void Simple2_Recognize() { int n_images = Images.Length; int i_image = n_images - 1; //i_image = 0; string fileName = Images[i_image]; string imageFile = Path.Combine(InputFolder, fileName); string language = "eng"; int oem = (int)eOcrEngineMode.OEM_DEFAULT; using (TesseractProcessor processor = new TesseractProcessor()) { using (Bitmap bmp = Bitmap.FromFile(imageFile) as Bitmap) { using (GreyImage greyImage = GreyImage.FromImage(bmp)) { ImageThresholder thresholder = new AdaptiveThresholder(); using (BinaryImage binImage = thresholder.Threshold(greyImage)) { DateTime started = DateTime.Now; DateTime ended = DateTime.Now; int i = 3; //for (i = 0; i < 4; i++) //for (i = 3; i < 4; i++) { oem = i; processor.Init(TessdataFolder, language, oem); string text = ""; unsafe { started = DateTime.Now; text = processor.RecognizeBinaryImage( binImage.BinaryData, greyImage.Width, greyImage.Height); ended = DateTime.Now; Console.WriteLine("Duration recognition: {0} ms\n\n", (ended - started).TotalMilliseconds); } Console.WriteLine( string.Format("RecognizeMode: {1}\nRecognized Text:\n{0}\n++++++++++++++++++++++++++++++++\n", text, ((eOcrEngineMode)oem).ToString())); } } } } } }
public static void Recognize() { int n_images = Workspace.Images.Length; int i_image = n_images - 1; i_image = 0; string fileName = Workspace.Images[i_image]; string imageFile = Path.Combine(Workspace.InputFolder, fileName); string language = "eng"; int oem = 3; TesseractProcessor processor = new TesseractProcessor(); using (Bitmap bmp = Bitmap.FromFile(imageFile) as Bitmap) { GreyImage greyImage = GreyImage.FromImage(bmp); DateTime started = DateTime.Now; AdaptiveThresholder thresholder = new AdaptiveThresholder(); BinaryImage binImage = thresholder.Threshold(greyImage); DateTime ended = DateTime.Now; Console.WriteLine("Duration thresholding: {0} ms", (ended - started).TotalMilliseconds); binImage.Invert(); //for (int i = 0; i < 4; i++) for (int i = 3; i < 4; i++) { oem = i; oem = (int)eOcrEngineMode.OEM_TESSERACT_CUBE_COMBINED; processor.Init(Workspace.TessdataFolder, language, oem); string text = ""; unsafe { started = DateTime.Now; //string text = processor.Recognize(bmp); text = processor.RecognizeBinaryImage( binImage.BinaryData, binImage.Width, binImage.Height); ended = DateTime.Now; Console.WriteLine("Duration recognition: {0} ms\n\n", (ended - started).TotalMilliseconds); } Console.WriteLine( string.Format("RecognizeMode: {1}\nText:\n{0}\n++++++++++++++++++++++++++++++++\n", text, ((eOcrEngineMode)oem).ToString())); } } }