Creates a new empty virtual document.
public static LEADDocument Create(
CreateDocumentOptions options
)
Public Shared Function Create(
ByVal options As CreateDocumentOptions
) As LEADDocument
public:
static LEADDocument^ Create(
CreateDocumentOptions^ options
)
public static Document create(CreateDocumentOptions options)
options
Options to use when creating the document. Cannot be null.
The newly created document.
Creates a new empty virtual document ready to be filled with pages from other documents.
This method will add items with the key "Created", "Accessed" and "Modified" to Metadata with values equal to the current date and time. The newly created LEADDocument object will have an empty list of Pages. It can then be populated by the user.
The member of options are used as follows:
Member | Description |
---|---|
Cache and UseCache | Used to determine if the newly created document will be saved into the cache later. |
CachePolicy |
If caching is used: Copied to the newly created document and is used to determine when the document and its item are purged from the cache. |
MimeType |
Copied as is into the newly created document MimeType member. This value can be null but it is recommend you set it to the MIME type of the document since it will be used when saving the document. Use one of the MIME types constants defined in the Constants class. In the case of virtual documents, this value can be left as null. |
using Leadtools;
using Leadtools.Codecs;
using Leadtools.Document.Writer;
using Leadtools.Svg;
using LeadtoolsExamples.Common;
using Leadtools.Document;
using Leadtools.Caching;
using Leadtools.Annotations.Engine;
using Leadtools.Ocr;
using Leadtools.Barcode;
using Leadtools.Document.Converter;
public static void DocumentFactoryCreateExample()
{
var cache = GetCache();
// Create a new document
var createOptions = new CreateDocumentOptions();
createOptions.Cache = cache;
string documentId = null;
using (LEADDocument document = DocumentFactory.Create(createOptions))
{
document.Name = "Virtual";
// Should have 0 pages and documents
System.Diagnostics.Debug.Assert(document.Pages.Count == 0);
System.Diagnostics.Debug.Assert(document.Documents.Count == 0);
// Add page 1 and 2 from a PDF file
LoadDocumentOptions loadOptions = new LoadDocumentOptions();
loadOptions.Cache = cache;
LEADDocument childDocument = DocumentFactory.LoadFromFile(Path.Combine(ImagesPath.Path, "Leadtools.pdf"), loadOptions);
// Do not dispose the child documents, but save it into the cache
// This is optional and is done in this example since we will try to re-load the parent document
// from the cache - and the child documents should be in the cache as well
childDocument.SaveToCache();
// Now add the pages
document.Pages.Add(childDocument.Pages[0]);
document.Pages.Add(childDocument.Pages[1]);
// Add an empty page
var documentPage = document.Pages.CreatePage(LeadSizeD.Create(LEADDocument.UnitsPerInch * 8.5, LEADDocument.UnitsPerInch * 11), 300);
document.Pages.Add(documentPage);
// Add page 3 and 4 from a TIF file
childDocument = DocumentFactory.LoadFromFile(Path.Combine(ImagesPath.Path, "Ocr.tif"), loadOptions);
// Also save it into the cache
childDocument.SaveToCache();
// Now add the pages
document.Pages.Add(childDocument.Pages[2]);
document.Pages.Add(childDocument.Pages[3]);
// Should have 5 pages and 2 documents (the PDF and the TIF)
System.Diagnostics.Debug.Assert(document.Pages.Count == 5);
System.Diagnostics.Debug.Assert(document.Documents.Count == 2);
// Tell the parent document to dispose any child documents when the parent is disposed
document.AutoDisposeDocuments = true;
// Show the info of this document, should say 5 pages
Console.WriteLine("Original document information");
PrintOutDocumentInfo(document);
// Now save, the parent document into the cache
document.SaveToCache();
// And tell all documents to not delete themselves from the cache
document.AutoDeleteFromCache = false;
// Save the ID so we can load it
documentId = document.DocumentId;
}
// Now, load the document from the cache
var loadFromCacheOptions = new LoadFromCacheOptions();
loadFromCacheOptions.Cache = cache;
loadFromCacheOptions.DocumentId = documentId;
using (LEADDocument document = DocumentFactory.LoadFromCache(loadFromCacheOptions))
{
// Should have 5 pages and 2 documents (the PDF and the TIF)
System.Diagnostics.Debug.Assert(document.Pages.Count == 5);
System.Diagnostics.Debug.Assert(document.Documents.Count == 2);
// Show the info of this document, should still say 5 pages
Console.WriteLine("Loaded from cache information");
PrintOutDocumentInfo(document);
// Delete first page
document.Pages.RemoveAt(0);
// Delete the last page
document.Pages.RemoveAt(document.Pages.Count - 1);
// Should have 3 pages and 2 documents (the PDF and the TIF)
System.Diagnostics.Debug.Assert(document.Pages.Count == 3);
System.Diagnostics.Debug.Assert(document.Documents.Count == 2);
Console.WriteLine("After removing the first 2 pages");
PrintOutDocumentInfo(document);
// Delete this document and all its children from the cache when we are disposed
document.AutoDeleteFromCache = true;
}
}
Imports Leadtools
Imports Leadtools.Codecs
Imports Leadtools.Document.Writer
Imports Leadtools.Svg
Imports Leadtools.Document
Imports Leadtools.Caching
Imports Leadtools.Annotations.Engine
Imports Leadtools.Barcode
Imports Leadtools.Ocr
Imports LeadtoolsDocumentExamples.LeadtoolsExamples.Common
Imports Leadtools.Document.Converter
Public Sub DocumentFactoryCreateExample()
Dim cache As ObjectCache = GetCache()
' Create a New document
Dim createOptions As New CreateDocumentOptions()
createOptions.Cache = cache
Dim documentId As String = Nothing
Using document As LEADDocument = DocumentFactory.Create(createOptions)
document.Name = "Virtual"
' Should have 0 pages And documents
System.Diagnostics.Debug.Assert(document.Pages.Count = 0)
System.Diagnostics.Debug.Assert(document.Documents.Count = 0)
' Add page 1 And 2 from a PDF file
Dim loadOptions As New LoadDocumentOptions()
loadOptions.Cache = cache
Dim childDocument As LEADDocument = DocumentFactory.LoadFromFile(Path.Combine(ImagesPath.Path, "Leadtools.pdf"), loadOptions)
' Do Not dispose the child documents, but save it into the cache
' This Is optional And Is done in this example since we will try to re-load the parent document
' from the cache - And the child documents should be in the cache as well
childDocument.SaveToCache()
' Now add the pages
document.Pages.Add(childDocument.Pages(0))
document.Pages.Add(childDocument.Pages(1))
' Add an empty page
Dim documentPage As Leadtools.Document.DocumentPage = document.Pages.CreatePage(LeadSizeD.Create(LEADDocument.UnitsPerInch * 8.5, LEADDocument.UnitsPerInch * 11), 300)
document.Pages.Add(documentPage)
' Add page 3 And 4 from a TIF file
childDocument = DocumentFactory.LoadFromFile(Path.Combine(ImagesPath.Path, "Ocr.tif"), loadOptions)
' Also save it into the cache
childDocument.SaveToCache()
' Now add the pages
document.Pages.Add(childDocument.Pages(2))
document.Pages.Add(childDocument.Pages(3))
' Should have 5 pages And 2 documents (the PDF And the TIF)
System.Diagnostics.Debug.Assert(document.Pages.Count = 5)
System.Diagnostics.Debug.Assert(document.Documents.Count = 2)
' Tell the parent document to dispose any child documents when the parent Is disposed
document.AutoDisposeDocuments = True
' Show the info of this document, should say 5 pages
Console.WriteLine("Original document information")
PrintOutDocumentInfo(document)
' Now save, the parent document into the cache
document.SaveToCache()
' And tell all documents to Not delete themselves from the cache
document.AutoDeleteFromCache = False
' Save the ID so we can load it
documentId = document.DocumentId
End Using
' Now, load the document from the cache
Dim loadFromCacheOptions As New LoadFromCacheOptions
loadFromCacheOptions.Cache = cache
loadFromCacheOptions.DocumentId = documentId
Using document As LEADDocument = DocumentFactory.LoadFromCache(loadFromCacheOptions)
' Should have 5 pages And 2 documents (the PDF And the TIF)
System.Diagnostics.Debug.Assert(document.Pages.Count = 5)
System.Diagnostics.Debug.Assert(document.Documents.Count = 2)
' Show the info of this document, should still say 5 pages
Console.WriteLine("Loaded from cache information")
PrintOutDocumentInfo(document)
' Delete first page
document.Pages.RemoveAt(0)
' Delete the last page
document.Pages.RemoveAt(document.Pages.Count - 1)
' Should have 3 pages And 2 documents (the PDF And the TIF)
System.Diagnostics.Debug.Assert(document.Pages.Count = 3)
System.Diagnostics.Debug.Assert(document.Documents.Count = 2)
Console.WriteLine("After removing the first 2 pages")
PrintOutDocumentInfo(document)
' Delete this document And all its children from the cache when we are disposed
document.AutoDeleteFromCache = True
End Using
End Sub
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