public string[] GetAdditionalEngineFormats() It is recommended that you always use the formats supported by the LEADTOOLS Document Writers when saving OCR recognition data. For more information refer to DocumentFormat. Support for native engine formats may be deprecated in later versions of LEADTOOLS.
Use the GetSupportedEngineFormats method in OcrEngineType.LEAD to get a list of names of the supported native formats. If the native format is supported, a native format can be used to save it, instead of using the save mechanism of the LEADTOOLS Document Writers.
To save the recognition results using the engine native format:
If DocumentFormat.User is passed to the save method, then the document is saved using the native engine's format set in IOcrDocumentManager.EngineFormat.
However, if the engine does not support a native format, an exception will be thrown.
Note that the LEADTOOLS default installation does not ship with native engine format support. You must download and install the "OCR Additional Features" setup available at https://www.leadtools.com to add this feature.
For more information about the various document formats supported by LEADTOOLS refer to DocumentFormat.
To determine whether a specific engine native format is supported by this IOcrEngine, use IsEngineFormatSupported.
To get the file extension for a specific engine native format, use GetEngineFormatFileExtension.
To get the friendly name for a specific engine native format, use GetEngineFormatFriendlyName.
using Leadtools;using Leadtools.Codecs;using Leadtools.Ocr;using Leadtools.Forms.Common;using Leadtools.Document.Writer;using Leadtools.WinForms;public void OcrDocumentManagerExample(){string tifFileName1 = Path.Combine(LEAD_VARS.ImagesDir, "Ocr1.tif");string tifFileName2 = Path.Combine(LEAD_VARS.ImagesDir, "Ocr2.tif");string outputDirectory = Path.Combine(LEAD_VARS.ImagesDir, "OutputDirectory");// Create the output directoryif (Directory.Exists(outputDirectory))Directory.Delete(outputDirectory, true);Directory.CreateDirectory(outputDirectory);// Create an instance of the engineusing (IOcrEngine ocrEngine = OcrEngineManager.CreateEngine(OcrEngineType.LEAD)){// Start the engine using default parametersConsole.WriteLine("Starting up the engine...");ocrEngine.Startup(null, null, null, LEAD_VARS.OcrLEADRuntimeDir);// Create the OCR documentConsole.WriteLine("Creating the OCR document...");IOcrDocumentManager ocrDocumentManager = ocrEngine.DocumentManager;using (IOcrDocument ocrDocument = ocrDocumentManager.CreateDocument()){// Add the pages to the documentConsole.WriteLine("Adding the pages...");ocrDocument.Pages.AddPage(tifFileName1, null);ocrDocument.Pages.AddPage(tifFileName2, null);// Recognize the pages to this document. Note, we did not call AutoZone, it will explicitly be called by RecognizeConsole.WriteLine("Recognizing all the pages...");ocrDocument.Pages.Recognize(null);// Save to all the formats supported by this OCR engineArray formats = Enum.GetValues(typeof(DocumentFormat));foreach (DocumentFormat format in formats){string friendlyName = DocumentWriter.GetFormatFriendlyName(format);Console.WriteLine("Saving (using default options) to {0}...", friendlyName);// Construct the output file name (output_directory + document_format_name + . + extension)string extension = DocumentWriter.GetFormatFileExtension(format);string outputFileName = Path.Combine(outputDirectory, format.ToString() + "." + extension);// Save the documentocrDocument.Save(outputFileName, format, null);// If this is the LTD format, convert it to PDFif (format == DocumentFormat.Ltd){Console.WriteLine("Converting the LTD file to PDF...");string pdfFileName = Path.Combine(outputDirectory, format.ToString() + "_pdf.pdf");DocumentWriter docWriter = ocrEngine.DocumentWriterInstance;docWriter.Convert(outputFileName, pdfFileName, DocumentFormat.Pdf);}}// Now save to all the engine native formats (if any) supported by the enginestring[] engineFormats = ocrDocumentManager.GetSupportedEngineFormats();foreach (string engineFormat in engineFormats){string friendlyName = ocrDocumentManager.GetEngineFormatFriendlyName(engineFormat);Console.WriteLine("Saving to engine native format {0}...", friendlyName);// Construct the output file name (output_directory + "engine" + engine_format_name + . + extension)string extension = ocrDocumentManager.GetEngineFormatFileExtension(engineFormat);string outputFileName = Path.Combine(outputDirectory, "engine_" + engineFormat + "." + extension);// To use this format, set it in the IOcrDocumentManager.EngineFormat and do a normal save using DocumentFormat.User// Save the documentocrDocumentManager.EngineFormat = engineFormat;ocrDocument.Save(outputFileName, DocumentFormat.User, null);}}// Shutdown the engine// Note: calling Dispose will also automatically shutdown the engine if it has been startedConsole.WriteLine("Shutting down...");ocrEngine.Shutdown();}}static class LEAD_VARS{public const string ImagesDir = @"C:\LEADTOOLS23\Resources\Images";public const string OcrLEADRuntimeDir = @"C:\LEADTOOLS23\Bin\Common\OcrLEADRuntime";}