This class contains the form recognition engine that creates, compares, and aligns forms.
public class FormRecognitionEngine Public Class FormRecognitionEngine
public class FormRecognitionEngine public ref class FormRecognitionEngine This class is used to create Master Forms and Forms, to compare a form with a Master Form, and to calculate the alignment for a Form in relation to a specified Master Form.
Important: Different OCR engines might have slight differences in form alignment and recognition. Therefore, it is recommended to use the same Leadtools.Ocr.OcrEngineType when generating the master forms and when recognizing and processing forms.
This example shows a complete skeleton of a form recognition and processing application.
using Leadtools;using Leadtools.Barcode;using Leadtools.Codecs;using Leadtools.Forms.Common;using Leadtools.Ocr;using Leadtools.Forms.Processing;using Leadtools.Forms.Recognition;using Leadtools.Forms.Recognition.Barcode;using Leadtools.Forms.Recognition.Ocr;/// This class contains all Master Form information.class MasterForm{public RasterImage Image;public FormRecognitionAttributes Attributes;public FormRecognitionProperties Properties;public FormPages ProcessingPages;/// This constructor initializes all MasterForm members to zero/null/Empty.public MasterForm(){Image = null;Attributes = null;Properties = FormRecognitionProperties.Empty;ProcessingPages = null;}}/// This class contains all MyForm information. MyForm is the filled form that is going to be identified and processed by the application.class MyForm{public string FileName;public RasterImage Image;public FormRecognitionAttributes Attributes;public MasterForm Master;public FormRecognitionResult Result;public IList<PageAlignment> Alignment;public FormPages ProcessingPages;/// This constructor initializes all MyForm members to zero/null/Empty.public MyForm(){FileName = null;Image = null;Attributes = null;Master = null;Result = null;Alignment = null;}}/// TestForms is a class that has all the needed methods to recognize and process unknown forms. Once an instance of it is created StartUp should be called first to initialize the/// OCR and barcode engines in addition to building the Master Forms set. Next, call the Run method to recognize and process a specific form. Finally, call the ShutDown method/// once the program is terminated.class TestForms{FormRecognitionEngine RecognitionEngine;FormProcessingEngine ProcessingEngine;BarcodeEngine FormsBarcodeEngine;IOcrEngine FormsOcrEngine;List<MasterForm> FormSet;bool RecognizeFirstPageOnly;bool LoadFromScanner;RasterCodecs FormsCodec;//===========================================================================/// This method loads an image from a scanner.public RasterImage LoadImageScanner(int count){//TODOreturn null;}/// This method loads an image from a scanner for recognition.public RasterImage LoadRecognitionImageScanner(){//TODOreturn null;}/// This method loads an image from a file.public RasterImage LoadImageFile(string fileName, int firstPage, int lastPage){// This method loads an image and verifies that all pages have been loaded.RasterImage image = FormsCodec.Load(fileName, 1, CodecsLoadByteOrder.Bgr, firstPage, lastPage);return image;}//===========================================================================/// This method loads an image from a file for recognition.public RasterImage LoadRecognitionImageFile(string fileName){RasterImage image;if (RecognizeFirstPageOnly)image = LoadImageFile(fileName, 1, 1);elseimage = LoadImageFile(fileName, 1, -1);return image;}/// This method loads an image for recognition.public RasterImage LoadRecognitionImage(string fileName){RasterImage image;if (RecognizeFirstPageOnly)image = LoadRecognitionImageScanner();elseimage = LoadRecognitionImageFile(fileName);return image;}//===========================================================================/// This method creates a form attributes object for recognition.public FormRecognitionAttributes CreateForm(){FormRecognitionAttributes attributes = RecognitionEngine.CreateForm(null);RecognitionEngine.CloseForm(attributes);return attributes;}/// This method adds a page to a form attributes object for recognition.public void AddPageToForm(RasterImage image, FormRecognitionAttributes attributes){RecognitionEngine.OpenForm(attributes);RecognitionEngine.AddFormPage(attributes, image, null);RecognitionEngine.CloseForm(attributes);}/// This method deletes a page from a form attributes object for recognition.public void DeletePageFromForm(int pagenumber, FormRecognitionAttributes form){RecognitionEngine.OpenForm(form);RecognitionEngine.DeleteFormPage(form, pagenumber);RecognitionEngine.CloseForm(form);}/// This method creates a form along with its pages for recognition.public void CreateFormForRecognition(MyForm form){form.Attributes = CreateForm();int saveCurrentPageIndex = form.Image.Page;for (int i = 0; i < form.Image.PageCount; i++){form.Image.Page = i + 1;//page index is a 1-based index that starts from 1 not zeroAddPageToForm(form.Image, form.Attributes);}form.Image.Page = saveCurrentPageIndex;}//===========================================================================/// This method creates a Master Form recognition attributes object.public FormRecognitionAttributes CreateMasterForm(string name){FormRecognitionAttributes attributes = RecognitionEngine.CreateMasterForm(name, Guid.Empty, null);RecognitionEngine.CloseMasterForm(attributes);return attributes;}/// This method adds a page to a Master Form recognition attributes object.public void AddPageToMasterForm(RasterImage image, FormRecognitionAttributes attributes){RecognitionEngine.OpenMasterForm(attributes);RecognitionEngine.AddMasterFormPage(attributes, image, null);RecognitionEngine.CloseMasterForm(attributes);}/// This method deletes a page from a Master Form recognition attributes object.public void DeletePageFromMasterForm(int pagenumber, FormRecognitionAttributes form){RecognitionEngine.OpenMasterForm(form);RecognitionEngine.DeleteMasterFormPage(form, pagenumber);RecognitionEngine.CloseMasterForm(form);}/// This method creates a Master Form with its pages for recognition purposes.public void CreateMasterFormForRecognition(string name, MasterForm form){form.Attributes = CreateMasterForm(name);int saveCurrentPageIndex = form.Image.Page;for (int i = 0; i < form.Image.PageCount; i++){form.Image.Page = i + 1;//page index is a 1-based starts from 1 not zeroAddPageToMasterForm(form.Image, form.Attributes);}form.Image.Page = saveCurrentPageIndex;}//===========================================================================///This method compares a Form to a Master Form using all pages.FormRecognitionResult CompareForm(FormRecognitionAttributes master, FormRecognitionAttributes form){return RecognitionEngine.CompareForm(master, form, null);}///This method compares the first page of a Form to the first page of a Master Form.FormRecognitionResult CompareFirstPage(FormRecognitionAttributes master, FormRecognitionAttributes form){PageRecognitionResult resultPage = RecognitionEngine.ComparePage(master, 1, form, 1);FormRecognitionResult result = new FormRecognitionResult();result.Confidence = resultPage.Confidence;result.LargestConfidencePageNumber = 1;result.PageResults.Add(resultPage);result.Reason = FormRecognitionReason.Success;return result;}///This method identifies the type of the form based on the comparison results.public int IdentifyForm(FormRecognitionResult[] results){int maxIndex = 0;maxIndex = 0;for (int i = 1; i < results.Length; i++){if (results[maxIndex].Confidence < results[i].Confidence)maxIndex = i;}if (results[maxIndex].Confidence < 30)maxIndex = -1;//no matchreturn maxIndex;}///This method recognizes the type of an unknown form.public void RecognizeForm(MyForm form){CreateFormForRecognition(form);FormRecognitionResult[] results = new FormRecognitionResult[FormSet.Count];for (int i = 0; i < FormSet.Count; i++){if (RecognizeFirstPageOnly)results[i] = CompareFirstPage(FormSet[i].Attributes, form.Attributes);elseresults[i] = CompareForm(FormSet[i].Attributes, form.Attributes);}int index = IdentifyForm(results);if (index >= 0){form.Master = FormSet[index];form.Result = results[index];}else{form.Master = null;form.Result = null;}}//===========================================================================///This method loads images for processing purposes if needed.bool LoadProcessingImage(MyForm form){int count = form.Master.Properties.Pages - form.Image.PageCount;if (count == 0)return false;RasterImage image;if (LoadFromScanner)image = LoadImageScanner(count);elseimage = LoadImageFile(form.FileName, form.Image.PageCount + 1, form.Image.PageCount + count);form.Image.AddPages(image, 1, count);return true;}//===========================================================================///This method calculates the alignment for the recognized form.public void AlignForm(MyForm form, bool calculateAlignment){if (calculateAlignment){CreateFormForRecognition(form);form.Alignment = RecognitionEngine.GetFormAlignment(form.Master.Attributes, form.Attributes, null);}else{form.Alignment = new List<PageAlignment>();for (int i = 0; i < form.Result.PageResults.Count; i++)form.Alignment.Add(form.Result.PageResults[i].Alignment);}}//===========================================================================///This method processes the recognized form.public void ProcessForm(MyForm form){form.ProcessingPages = form.Master.ProcessingPages;ProcessingEngine.Pages.Clear();ProcessingEngine.Pages.AddRange(form.ProcessingPages);ProcessingEngine.Process(form.Image, form.Alignment);}//===========================================================================///This method recognizes the unknown form then processes it.public void RunFormRecognitionAndProcessing(MyForm form){form.Image = LoadRecognitionImage(form.FileName);RecognizeForm(form);if (form.Master == null){Console.WriteLine("Unknown form");return;}bool calculateAlignment = LoadProcessingImage(form);AlignForm(form, calculateAlignment);ProcessForm(form);PrintOutResults(form);}//===========================================================================/// This method loads the specified master form attributes object, fields, and image.public MasterForm LoadMasterForm(string attributesFileName, string fieldsFileName, string imageFileName){byte[] formData;MasterForm form = new MasterForm();formData = File.ReadAllBytes(attributesFileName);form.Attributes = new FormRecognitionAttributes();form.Attributes.SetData(formData);form.Properties = RecognitionEngine.GetFormProperties(form.Attributes);ProcessingEngine.LoadFields(fieldsFileName);form.ProcessingPages = new FormPages();form.ProcessingPages.AddRange(ProcessingEngine.Pages);form.Image = FormsCodec.Load(imageFileName, 1, CodecsLoadByteOrder.Bgr, 1, -1);return form;}/// This method saves the master form attributes object to the specified filename.public void SaveMasterFormAttributes(MasterForm form, string attributesFileName){byte[] formData = form.Attributes.GetData();File.WriteAllBytes(attributesFileName, formData);}/// This method saves master form fields to the specified filename.public void SaveMasterFormFields(MasterForm form, string fieldsFileName){ProcessingEngine.Pages.Clear();ProcessingEngine.Pages.AddRange(form.ProcessingPages);ProcessingEngine.SaveFields(fieldsFileName);}//===========================================================================/// This method builds the Form Set.public void BuildFormsSet(){FormSet = new List<MasterForm>();MasterForm Form107 = LoadMasterForm(Path.Combine(LEAD_VARS.ImagesDir, @"Forms\MasterForm Sets\OCR\FFC-107.bin"),Path.Combine(LEAD_VARS.ImagesDir, @"Forms\MasterForm Sets\OCR\FFC-107.xml"),Path.Combine(LEAD_VARS.ImagesDir, @"Forms\MasterForm Sets\OCR\FFC-107.tif"));FormSet.Add(Form107);MasterForm Form180 = LoadMasterForm(Path.Combine(LEAD_VARS.ImagesDir, @"Forms\MasterForm Sets\OCR\SF-180.bin"),Path.Combine(LEAD_VARS.ImagesDir, @"Forms\MasterForm Sets\OCR\SF-180.xml"),Path.Combine(LEAD_VARS.ImagesDir, @"Forms\MasterForm Sets\OCR\SF-180.tif"));FormSet.Add(Form180);MasterForm Form3881 = LoadMasterForm(Path.Combine(LEAD_VARS.ImagesDir, @"Forms\MasterForm Sets\OCR\SF-3881.bin"),Path.Combine(LEAD_VARS.ImagesDir, @"Forms\MasterForm Sets\OCR\SF-3881.xml"),Path.Combine(LEAD_VARS.ImagesDir, @"Forms\MasterForm Sets\OCR\SF-3881.tif"));FormSet.Add(Form3881);}//===========================================================================/// This method prints the image field resultspublic void PrintOutImage(ImageFormField field){Console.WriteLine();Console.WriteLine("*** Image Field");ImageFormFieldResult result = field.Result as ImageFormFieldResult;FormsCodec.Save(result.Image, Path.Combine(LEAD_VARS.ImagesDir, "ImageField.tif"), RasterImageFormat.Tif, 1);}/// This method prints the barcode field results.public void PrintOutBarcode(BarcodeFormField field){Console.WriteLine();Console.WriteLine("*** Barcode Field");BarcodeFormFieldResult result = field.Result as BarcodeFormFieldResult;foreach (BarcodeFieldData barcode in result.BarcodeData){Console.WriteLine(" *- Barcode Type: " + barcode.Symbology);Console.WriteLine(" - Barcode Data: " + barcode.GetData());}}/// This method prints the OMR field results.public void PrintOutOmr(OmrFormField field){Console.WriteLine();Console.WriteLine("*** Omr Field");OmrFormFieldResult result = field.Result as OmrFormFieldResult;Console.WriteLine(" Is Checked?[1 = yes, 0 = No] = " + result.Text);}/// This method prints the text field results.public void PrintOutText(TextFormField field){Console.WriteLine();Console.WriteLine("*** Text Field");TextFormFieldResult result = field.Result as TextFormFieldResult;Console.WriteLine("Text: " + result.Text);}/// This method prints the processing results.public void PrintOutResults(MyForm form){if (form.Result.Confidence < 30){Console.WriteLine("No match found");return;}Console.WriteLine("=======================Type===========================");Console.WriteLine("Form Type is: " + form.Master.Properties.Name);Console.WriteLine("Confidence = " + form.Result.Confidence);Console.WriteLine();Console.WriteLine("====================Fields Result=======================");for (int pageIndex = 0; pageIndex < form.ProcessingPages.Count; pageIndex++){Console.WriteLine();Console.WriteLine("=====Page # " + form.ProcessingPages[pageIndex].PageNumber + "=====");Console.WriteLine();foreach (FormField field in form.ProcessingPages[pageIndex]){if (field is ImageFormField)PrintOutImage(field as ImageFormField);else if (field is BarcodeFormField)PrintOutBarcode(field as BarcodeFormField);else if (field is OmrFormField)PrintOutOmr(field as OmrFormField);else if (field is TextFormField)PrintOutText(field as TextFormField);}}}//===========================================================================///This method starts up the OCR engine.private void StartUpOcrEngine(){try{FormsOcrEngine = OcrEngineManager.CreateEngine(OcrEngineType.LEAD);FormsOcrEngine.Startup(FormsCodec, null, null, LEAD_VARS.OcrLEADRuntimeDir);}catch (Exception exp){Console.WriteLine(exp.Message);}}///This method shuts down the OCR engine.private void ShutDownOcrEngine(){FormsOcrEngine.Shutdown();FormsOcrEngine.Dispose();}///This method starts up the Barcode engine.private void StartUpBarcodeEngine(){try{FormsBarcodeEngine = new BarcodeEngine();}catch (Exception exp){Console.WriteLine(exp.Message);}}///This method sets the object managers.public void SetObjectManagers(bool enableDefault, bool enableOcr, bool enableBarcode){if (RecognitionEngine == null)return;if (enableDefault){DefaultObjectsManager defaultObjectManager = new DefaultObjectsManager();RecognitionEngine.ObjectsManagers.Add(defaultObjectManager);}if (enableOcr){OcrObjectsManager ocrObejectManager = new OcrObjectsManager(FormsOcrEngine);ocrObejectManager.Engine = FormsOcrEngine;RecognitionEngine.ObjectsManagers.Add(ocrObejectManager);}if (enableBarcode){BarcodeObjectsManager barcodeObjectManager = new BarcodeObjectsManager(FormsBarcodeEngine);barcodeObjectManager.Engine = FormsBarcodeEngine;RecognitionEngine.ObjectsManagers.Add(barcodeObjectManager);}}///This method starts up all engines.public void StartUpEngines(){StartUpOcrEngine();StartUpBarcodeEngine();RecognitionEngine = new FormRecognitionEngine();SetObjectManagers(false, true, false);ProcessingEngine = new FormProcessingEngine();ProcessingEngine.OcrEngine = FormsOcrEngine;ProcessingEngine.BarcodeEngine = FormsBarcodeEngine;}///This method shuts down all engines.public void ShutDownEngines(){ShutDownOcrEngine();}///This method starts up a RasterCodec object, initializes a Form Codec, starts up all engines, and builds the form set.public void StartUp(){//1)FormsCodec = new RasterCodecs();//2)StartUpEngines();//3)RecognizeFirstPageOnly = false;LoadFromScanner = false;//4)BuildFormsSet();}///This method shuts down all engines, dispose of all images, and shuts down the RasterCodec.public void ShutDown(){//1)ShutDownEngines();//2)foreach (MasterForm master in FormSet)master.Image.Dispose();//3)FormsCodec.Dispose();}/// This method starts the recognition process on the unknown form that is stored in a file with the passed fileName.public void Run(string fileName){MyForm form = new MyForm();form.FileName = fileName;RunFormRecognitionAndProcessing(form);if (form.Image != null)form.Image.Dispose();}}class Program{/// The main entry to the program.static void Main(string[] args){if (args == null || args.Length == 0)return;TestForms test = new TestForms();test.StartUp();test.Run(args[0]);test.ShutDown();}}static class LEAD_VARS{public const string ImagesDir = @"C:\LEADTOOLS21\Resources\Images";public const string OcrLEADRuntimeDir = @"C:\LEADTOOLS21\Bin\Common\OcrLEADRuntime";}
Imports LeadtoolsImports Leadtools.BarcodeImports Leadtools.CodecsImports Leadtools.Forms.CommonImports Leadtools.OcrImports Leadtools.Forms.ProcessingImports Leadtools.Forms.RecognitionImports Leadtools.Forms.Recognition.BarcodeImports Leadtools.Forms.Recognition.Ocr''' This class contains all Master Form information.Friend Class MasterFormPublic Image As RasterImagePublic Attributes As FormRecognitionAttributesPublic Properties As FormRecognitionPropertiesPublic ProcessingPages As FormPages''' This constructor initialize all MasterForm members to zero/null/Empty.Public Sub New()Image = NothingAttributes = NothingProperties = FormRecognitionProperties.EmptyProcessingPages = NothingEnd SubEnd Class''' This class contains all my Form information. My Form is the filled form that is going to be identified and processed by the application.Friend Class MyFormPublic FileName As StringPublic Image As RasterImagePublic Attributes As FormRecognitionAttributesPublic Master As MasterFormPublic Result As FormRecognitionResultPublic Alignment As IList(Of PageAlignment)Public ProcessingPages As FormPages''' This constructor initialize all MyForm members to zero/null/Empty.Public Sub New()FileName = NothingImage = NothingAttributes = NothingMaster = NothingResult = NothingAlignment = NothingEnd SubEnd Class''' TestForms is a class that has all the needed methods to recognize and process unknown forms. Once an instance of it is created StartUp should be''' called first to initialize Ocr and barcode engines, besides building the Master Forms set, then Run method should be called to recognize and''' process a specific form, finally the ShutDown method should be called once the program is terminated.Friend Class TestFormsPrivate RecognitionEngine As FormRecognitionEnginePrivate ProcessingEngine As FormProcessingEnginePrivate FormsBarcodeEngine As BarcodeEnginePrivate FormsOcrEngine As IOcrEnginePrivate FormSet As List(Of MasterForm)Private RecognizeFirstPageOnly As BooleanPrivate LoadFromScanner As BooleanPrivate FormsCodec As RasterCodecs'===========================================================================''' This method loads an image from scanner.Public Function LoadImageScanner(ByVal count As Integer) As RasterImage'TODOReturn NothingEnd Function''' This method loads an image from scanner for recognition purposes.Public Function LoadRecognitionImageScanner() As RasterImage'TODOReturn NothingEnd Function''' This method loads an image from a file.Public Function LoadImageFile(ByVal fileName As String, ByVal firstPage As Integer, ByVal lastPage As Integer) As RasterImage' Load the image and verify that we loaded all the pagesDim image As RasterImage = FormsCodec.Load(fileName, 1, CodecsLoadByteOrder.Bgr, firstPage, lastPage)Return imageEnd Function'===========================================================================''' This method loads an image from a file for recognition purposes.Public Function LoadRecognitionImageFile(ByVal fileName As String) As RasterImageDim image As RasterImageIf RecognizeFirstPageOnly Thenimage = LoadImageFile(fileName, 1, 1)Elseimage = LoadImageFile(fileName, 1, -1)End IfReturn imageEnd Function''' This method loads an image for recognition purposes.Public Function LoadRecognitionImage(ByVal fileName As String) As RasterImageDim image As RasterImageIf RecognizeFirstPageOnly Thenimage = LoadRecognitionImageScanner()Elseimage = LoadRecognitionImageFile(fileName)End IfReturn imageEnd Function'===========================================================================''' This method creates a form attributes for recognition.Public Function CreateForm() As FormRecognitionAttributesDim attributes As FormRecognitionAttributes = RecognitionEngine.CreateForm(Nothing)RecognitionEngine.CloseForm(attributes)Return attributesEnd Function''' This method adds a page to form attributes for recognition.Public Sub AddPageToForm(ByVal image As RasterImage, ByVal attributes As FormRecognitionAttributes)RecognitionEngine.OpenForm(attributes)RecognitionEngine.AddFormPage(attributes, image, Nothing)RecognitionEngine.CloseForm(attributes)End Sub''' This method deletes a page from form attributes for recognition.Public Sub DeletePageFromForm(ByVal pagenumber As Integer, ByVal form As FormRecognitionAttributes)RecognitionEngine.OpenForm(form)RecognitionEngine.DeleteFormPage(form, pagenumber)RecognitionEngine.CloseForm(form)End Sub''' This method creates a form with its pages for recognition.Public Sub CreateFormForRecognition(ByVal form As MyForm)form.Attributes = CreateForm()Dim saveCurrentPageIndex As Integer = form.Image.PageDim i As Integer = 0Do While i < form.Image.PageCountform.Image.Page = i + 1 'page index is a 1-based starts from 1 not zeroAddPageToForm(form.Image, form.Attributes)i += 1Loopform.Image.Page = saveCurrentPageIndexEnd Sub'===========================================================================''' This method creates a Master Form recognition attributes.Public Function CreateMasterForm(ByVal name As String) As FormRecognitionAttributesDim attributes As FormRecognitionAttributes = RecognitionEngine.CreateMasterForm(name, Guid.Empty, Nothing)RecognitionEngine.CloseMasterForm(attributes)Return attributesEnd Function''' This method adds a page to a Master Form recognition attributes.Public Sub AddPageToMasterForm(ByVal image As RasterImage, ByVal attributes As FormRecognitionAttributes)RecognitionEngine.OpenMasterForm(attributes)RecognitionEngine.AddMasterFormPage(attributes, image, Nothing)RecognitionEngine.CloseMasterForm(attributes)End Sub''' This method deletes a page from a Master Form recognition attributes.Public Sub DeletePageFromMasterForm(ByVal pagenumber As Integer, ByVal form As FormRecognitionAttributes)RecognitionEngine.OpenMasterForm(form)RecognitionEngine.DeleteMasterFormPage(form, pagenumber)RecognitionEngine.CloseMasterForm(form)End Sub''' This method creates a Master Form with its pages for recognition purposes.Public Sub CreateMasterFormForRecognition(ByVal name As String, ByVal form As MasterForm)form.Attributes = CreateMasterForm(name)Dim saveCurrentPageIndex As Integer = form.Image.PageDim i As Integer = 0Do While i < form.Image.PageCountform.Image.Page = i + 1 'page index is a 1-based starts from 1 not zeroAddPageToMasterForm(form.Image, form.Attributes)i += 1Loopform.Image.Page = saveCurrentPageIndexEnd Sub'==========================================================================='''This method compares a Form to a Master Form using all pages.Private Function CompareForm(ByVal master As FormRecognitionAttributes, ByVal form As FormRecognitionAttributes) As FormRecognitionResultReturn RecognitionEngine.CompareForm(master, form, Nothing)End Function'''This method compares the first page of a Form to the first page of a Master Form.Private Function CompareFirstPage(ByVal master As FormRecognitionAttributes, ByVal form As FormRecognitionAttributes) As FormRecognitionResultDim resultPage As PageRecognitionResult = RecognitionEngine.ComparePage(master, 1, form, 1)Dim result As FormRecognitionResult = New FormRecognitionResult()result.Confidence = resultPage.Confidenceresult.LargestConfidencePageNumber = 1result.PageResults.Add(resultPage)result.Reason = FormRecognitionReason.SuccessReturn resultEnd Function'''This method identifies the type of the form based on the comparison results.Public Function IdentifyForm(ByVal results As FormRecognitionResult()) As IntegerDim maxIndex As Integer = 0maxIndex = 0Dim i As Integer = 1Do While i < results.LengthIf results(maxIndex).Confidence < results(i).Confidence ThenmaxIndex = iEnd Ifi += 1LoopIf results(maxIndex).Confidence < 30 ThenmaxIndex = -1 'no matchEnd IfReturn maxIndexEnd Function'''This method recognizes the type of the unknown formPublic Sub RecognizeForm(ByVal form As MyForm)CreateFormForRecognition(form)Dim results As FormRecognitionResult() = New FormRecognitionResult(FormSet.Count - 1) {}Dim i As Integer = 0Do While i < FormSet.CountIf RecognizeFirstPageOnly Thenresults(i) = CompareFirstPage(FormSet(i).Attributes, form.Attributes)Elseresults(i) = CompareForm(FormSet(i).Attributes, form.Attributes)End Ifi += 1LoopDim index As Integer = IdentifyForm(results)If index >= 0 Thenform.Master = FormSet(index)form.Result = results(index)Elseform.Master = Nothingform.Result = NothingEnd IfEnd Sub'==========================================================================='''This method load images for processing purposes if needed.Private Function LoadProcessingImage(ByVal form As MyForm) As BooleanDim count As Integer = form.Master.Properties.Pages - form.Image.PageCountIf count = 0 ThenReturn FalseEnd IfDim image As RasterImageIf LoadFromScanner Thenimage = LoadImageScanner(count)Elseimage = LoadImageFile(form.FileName, form.Image.PageCount + 1, form.Image.PageCount + count)End Ifform.Image.AddPages(image, 1, count)Return TrueEnd Function'==========================================================================='''This method calculates the alignment for the recognized form.Public Sub AlignForm(ByVal form As MyForm, ByVal calculateAlignment As Boolean)If calculateAlignment ThenCreateFormForRecognition(form)form.Alignment = RecognitionEngine.GetFormAlignment(form.Master.Attributes, form.Attributes, Nothing)Elseform.Alignment = New List(Of PageAlignment)()Dim i As Integer = 0Do While i < form.Result.PageResults.Countform.Alignment.Add(form.Result.PageResults(i).Alignment)i += 1LoopEnd IfEnd Sub'==========================================================================='''This method processes the recognized form.Public Sub ProcessForm(ByVal form As MyForm)form.ProcessingPages = form.Master.ProcessingPagesProcessingEngine.Pages.Clear()ProcessingEngine.Pages.AddRange(form.ProcessingPages)ProcessingEngine.Process(form.Image, form.Alignment)End Sub'==========================================================================='''This method recognizes the unknown form then processes it.Public Sub RunFormRecognitionAndProcessing(ByVal form As MyForm)form.Image = LoadRecognitionImage(form.FileName)RecognizeForm(form)If form.Master Is Nothing ThenConsole.WriteLine("Unknown form")ReturnEnd IfDim calculateAlignment As Boolean = LoadProcessingImage(form)AlignForm(form, calculateAlignment)ProcessForm(form)PrintOutResults(form)End Sub'===========================================================================''' This method loads the specified master form attributes, fields, and image.Public Function LoadMasterForm(ByVal attributesFileName As String, ByVal fieldsFileName As String, ByVal imageFileName As String) As MasterFormDim formData As Byte()Dim form As MasterForm = New MasterForm()formData = File.ReadAllBytes(attributesFileName)form.Attributes = New FormRecognitionAttributesform.Attributes.SetData(formData)form.Properties = RecognitionEngine.GetFormProperties(form.Attributes)ProcessingEngine.LoadFields(fieldsFileName)form.ProcessingPages = New FormPages()form.ProcessingPages.AddRange(ProcessingEngine.Pages)form.Image = FormsCodec.Load(imageFileName, 1, CodecsLoadByteOrder.Bgr, 1, -1)Return formEnd Function''' This method saves master form attributes to the specified filename.Public Sub SaveMasterFormAttributes(ByVal form As MasterForm, ByVal attributesFileName As String)Dim formData As Byte() = form.Attributes.GetData()File.WriteAllBytes(attributesFileName, formData)End Sub''' This method saves master form fields to the specified filename.Public Sub SaveMasterFormFields(ByVal form As MasterForm, ByVal fieldsFileName As String)ProcessingEngine.Pages.Clear()ProcessingEngine.Pages.AddRange(form.ProcessingPages)ProcessingEngine.SaveFields(fieldsFileName)End Sub'===========================================================================''' This method builds the Form Set.Public Sub BuildFormsSet()FormSet = New List(Of MasterForm)()Dim Form107 As MasterForm = LoadMasterForm(Path.Combine(LEAD_VARS.ImagesDir, "Forms\MasterForm Sets\OCR\FFC-107.bin"),Path.Combine(LEAD_VARS.ImagesDir, "Forms\MasterForm Sets\OCR\FFC-107.xml"),Path.Combine(LEAD_VARS.ImagesDir, "Forms\MasterForm Sets\OCR\FFC-107.tif"))FormSet.Add(Form107)Dim Form180 As MasterForm = LoadMasterForm(Path.Combine(LEAD_VARS.ImagesDir, "Forms\MasterForm Sets\OCR\SF-180.bin"),Path.Combine(LEAD_VARS.ImagesDir, "Forms\MasterForm Sets\OCR\SF-180.xml"),Path.Combine(LEAD_VARS.ImagesDir, "Forms\MasterForm Sets\OCR\SF-180.tif"))FormSet.Add(Form180)Dim Form3881 As MasterForm = LoadMasterForm(Path.Combine(LEAD_VARS.ImagesDir, "Forms\MasterForm Sets\OCR\SF-3881.bin"),Path.Combine(LEAD_VARS.ImagesDir, "Forms\MasterForm Sets\OCR\SF-3881.xml"),Path.Combine(LEAD_VARS.ImagesDir, "Forms\MasterForm Sets\OCR\SF-3881.tif"))FormSet.Add(Form3881)End Sub'===========================================================================''' This method prints the image field resultsPublic Sub PrintOutImage(ByVal field As ImageFormField)Console.WriteLine()Console.WriteLine("*** Image Field")Dim result As ImageFormFieldResult = TryCast(field.Result, ImageFormFieldResult)FormsCodec.Save(result.Image, Path.Combine(LEAD_VARS.ImagesDir, "ImageField.tif"), RasterImageFormat.Tif, 1)End Sub''' This method prints the barcode field resultsPublic Sub PrintOutBarcode(ByVal field As BarcodeFormField)Console.WriteLine()Console.WriteLine("*** Barcode Field")Dim result As BarcodeFormFieldResult = TryCast(field.Result, BarcodeFormFieldResult)For Each barcode As BarcodeFieldData In result.BarcodeDataConsole.WriteLine(" *- Barcode Type: " & barcode.Symbology)Console.WriteLine(" - Barcode Data: ")Console.WriteLine(barcode.GetData())Next barcodeEnd Sub''' This method prints the Omr field resultsPublic Sub PrintOutOmr(ByVal field As OmrFormField)Console.WriteLine()Console.WriteLine("*** Omr Field")Dim result As OmrFormFieldResult = TryCast(field.Result, OmrFormFieldResult)Console.WriteLine(" Is Checked?[1 = yes, 0 = No] = " & result.Text)End Sub''' This method prints the text field resultsPublic Sub PrintOutText(ByVal field As TextFormField)Console.WriteLine()Console.WriteLine("*** Text Field")Dim result As TextFormFieldResult = TryCast(field.Result, TextFormFieldResult)Console.WriteLine("Text: " & result.Text)End Sub''' This method prints the processing resultsPublic Sub PrintOutResults(ByVal form As MyForm)If form.Result.Confidence < 30 ThenConsole.WriteLine("No match found")ReturnEnd IfConsole.WriteLine("=======================Type===========================")Console.WriteLine("Form Type is: " & form.Master.Properties.Name)Console.WriteLine("Confidence = " & form.Result.Confidence)Console.WriteLine()Console.WriteLine("====================Fields Result=======================")Dim pageIndex As Integer = 0Do While pageIndex < form.ProcessingPages.CountConsole.WriteLine()Console.WriteLine("=====Page # " & form.ProcessingPages(pageIndex).PageNumber & "=====")Console.WriteLine()For Each field As FormField In form.ProcessingPages(pageIndex)If TypeOf field Is ImageFormField ThenPrintOutImage(TryCast(field, ImageFormField))ElseIf TypeOf field Is BarcodeFormField ThenPrintOutBarcode(TryCast(field, BarcodeFormField))ElseIf TypeOf field Is OmrFormField ThenPrintOutOmr(TryCast(field, OmrFormField))ElseIf TypeOf field Is TextFormField ThenPrintOutText(TryCast(field, TextFormField))End IfNext fieldpageIndex += 1LoopEnd Sub'==========================================================================='''This method starts up the Ocr enginePrivate Sub StartUpOcrEngine()TryFormsOcrEngine = OcrEngineManager.CreateEngine(OcrEngineType.LEAD)FormsOcrEngine.Startup(FormsCodec, Nothing, Nothing, LEAD_VARS.OcrLEADRuntimeDir)Catch exp As ExceptionConsole.WriteLine(exp.Message)End TryEnd Sub'''This method shuts down the Ocr enginePrivate Sub ShutDownOcrEngine()FormsOcrEngine.Shutdown()FormsOcrEngine.Dispose()End Sub'''This method starts up the Barcode enginePrivate Sub StartUpBarcodeEngine()TryFormsBarcodeEngine = New BarcodeEngine()Catch exp As ExceptionConsole.WriteLine(exp.Message)End TryEnd Sub'''This method sets the object managers.Public Sub SetObjectManagers(ByVal enableDefault As Boolean, ByVal enableOcr As Boolean, ByVal enableBarcode As Boolean)If RecognitionEngine Is Nothing ThenReturnEnd IfIf enableDefault ThenDim defaultObjectManager As DefaultObjectsManager = New DefaultObjectsManager()RecognitionEngine.ObjectsManagers.Add(defaultObjectManager)End IfIf enableOcr ThenDim ocrObejectManager As OcrObjectsManager = New OcrObjectsManager(FormsOcrEngine)ocrObejectManager.Engine = FormsOcrEngineRecognitionEngine.ObjectsManagers.Add(ocrObejectManager)End IfIf enableBarcode ThenDim barcodeObjectManager As BarcodeObjectsManager = New BarcodeObjectsManager(FormsBarcodeEngine)barcodeObjectManager.Engine = FormsBarcodeEngineRecognitionEngine.ObjectsManagers.Add(barcodeObjectManager)End IfEnd Sub'''This method starts up all engines.Public Sub StartUpEngines()StartUpOcrEngine()StartUpBarcodeEngine()RecognitionEngine = New FormRecognitionEngine()SetObjectManagers(False, True, False)ProcessingEngine = New FormProcessingEngine()ProcessingEngine.OcrEngine = FormsOcrEngineProcessingEngine.BarcodeEngine = FormsBarcodeEngineEnd Sub'''This method shuts down all engines.Public Sub ShutDownEngines()ShutDownOcrEngine()End Sub'''This method starts up RasterCodec, initialize Form Codec, starts up all engines, and Build the form setPublic Sub StartUp()'1)FormsCodec = New RasterCodecs()'2)StartUpEngines()'3)RecognizeFirstPageOnly = FalseLoadFromScanner = False'4)BuildFormsSet()End Sub'''This method shuts down engines, dispose all images, and shut down the RasterCodec.Public Sub ShutDown()'1)ShutDownEngines()'2)For Each master As MasterForm In FormSetmaster.Image.Dispose()Next master'3)FormsCodec.Dispose()End Sub''' Here all starts for to recognize and process the unknown form that is stored in a fiel with passed fileName.Public Sub Run(ByVal fileName As String)Dim form As MyForm = New MyForm()form.FileName = fileNameRunFormRecognitionAndProcessing(form)If Not form.Image Is Nothing Thenform.Image.Dispose()End IfEnd SubEnd ClassFriend Class Program''' The main entry to the program.Shared Sub Main(ByVal args As String())If args Is Nothing OrElse args.Length = 0 ThenReturnEnd IfDim test As TestForms = New TestForms()test.StartUp()test.Run(args(0))test.ShutDown()End SubEnd ClassPublic NotInheritable Class LEAD_VARSPublic Const ImagesDir As String = "C:\LEADTOOLS21\Resources\Images"Public Const OcrLEADRuntimeDir As String = "C:\LEADTOOLS21\Bin\Common\OcrLEADRuntime"End Class
Help Collections
Raster .NET | C API | C++ Class Library | HTML5 JavaScript
Document .NET | C API | C++ Class Library | HTML5 JavaScript
Medical .NET | C API | C++ Class Library | HTML5 JavaScript
Medical Web Viewer .NET
Multimedia
Direct Show .NET | C API | Filters
Media Foundation .NET | C API | Transforms
Supported Platforms
.NET, Java, Android, and iOS/macOS Assemblies
Imaging, Medical, and Document
C API/C++ Class Libraries
Imaging, Medical, and Document
HTML5 JavaScript Libraries
Imaging, Medical, and Document
