public string WorkDirectory { get; }
The path to the work directory used by this IOcrEngine to store the engine temporary files.
The WorkDirectory is passed as the workDirectory parameter to the Startup method. This directory is used when the engine saves the its temporary files. The IOcrEngine object will create various temporary files during recognition and document saving processes. It will use the path passed in WorkDirectory as the location where these temporary files will be created. You can pass null (Nothing in VB) to let the engine select the temporary directory of the current logged in user (TEMP).
In either case, the value of working directory of the current started IOcrEngine can be obtained through the WorkDirectory property.
The engine will automatically deletes any temporary files created. However, if an unexpected error occurs (for example, an unhandled exception), some temporary files may still reside in the work directory after the application exits. A typical application may use a custom directory inside the application path and manually deletes any files that may reside there before calling Startup in case the previous instance of the application exited abnormally.
If the value of WorkDirectory is not null (Nothing in VB), then it must refer to a valid directory that exists in the system and the process that created the engine must have access rights to read, write and delete files from this directory.
The value WorkDirectory will hold the current work directory used by the OCR engine, if you passed null (Nothing in VB) in the Startup method, the value of this property will be set to the current logged in user TEMP value.
using Leadtools;using Leadtools.Codecs;using Leadtools.Ocr;using Leadtools.Document.Writer;public void StartupEngineExample(){// Use RasterCodecs to load an image file// Note: You can let the engine load the image file directly as shown in the other examplesRasterCodecs codecs = new RasterCodecs();RasterImage image = codecs.Load(Path.Combine(LEAD_VARS.ImagesDir, "Ocr1.tif"));// Assume you copied the engine runtime files to C:\MyApp\Ocrstring engineDir = @"C:\MyApp\Ocr";// Store the engine work directory into a path inside our applicationstring workDir = @"C:\MyApp\OcrTemp";// Delete all files in the work directory in case the previous version of our application exited abnormally and// the engine did not get the chance to clean all of its temporary files (if any)Directory.Delete(workDir, true);// Re-create the work directoryDirectory.CreateDirectory(workDir);// Create an instance of the engineusing (IOcrEngine ocrEngine = OcrEngineManager.CreateEngine(OcrEngineType.LEAD)){// Show that the engine has not been started yetConsole.WriteLine("Before calling Startup, IsStarted = " + ocrEngine.IsStarted);// Start the engine using our parameters// Since we already have a RasterCodecs object, we can re-use it to save memory and resourcesocrEngine.Startup(codecs, null, workDir, engineDir);// Make sure the engine is using our working directoryConsole.WriteLine("workDir passed is {0}, the value of WorkDirectory after Startup is {1}", workDir, ocrEngine.WorkDirectory);// Show that the engine has started fineConsole.WriteLine("After calling Startup, EngineType is {0}, IsStarted = {1}", ocrEngine.EngineType, ocrEngine.IsStarted);// Maks sure the engine is using our own version of RasterCodecsDebug.Assert(codecs == ocrEngine.RasterCodecsInstance);// Create a page from the raster image as page to the documentIOcrPage ocrPage = ocrEngine.CreatePage(image, OcrImageSharingMode.AutoDispose);// image belongs to the page and will be dispose when the page is disposed// Recognize the page// Note, Recognize can be called without calling AutoZone or manually adding zones. The engine will// check and automatically auto-zones the pageocrPage.Recognize(null);// Create a file based documentusing (IOcrDocument ocrDocument = ocrEngine.DocumentManager.CreateDocument(null, OcrCreateDocumentOptions.AutoDeleteFile)){// Add the pageocrDocument.Pages.Add(ocrPage);// No need for the page anymoreocrPage.Dispose();// Save the document we have as PDFstring pdfFileName = Path.Combine(LEAD_VARS.ImagesDir, "Ocr1.pdf");ocrDocument.Save(pdfFileName, DocumentFormat.Pdf, null);}// Shutdown the engine// Note: calling Dispose will also automatically shutdown the engine if it has been startedocrEngine.Shutdown();}}static class LEAD_VARS{public const string ImagesDir = @"C:\LEADTOOLS23\Resources\Images";}