public RasterImage Image { get; set; }
An RasterImage that contains the image representation of the page.
The Image property must contain a RasterImage object --it cannot be null. This image object is used in the DocumentWriter.AddPage or DocumentWriter.InsertPage methods to create the visual representation of the new page added to the document being created.
The LEADTOOLS Document Writer toolkit will not use the RasterImage object after the call to DocumentWriter.AddPage or DocumentWriter.InsertPage returns. This handle needs to be disposed to free the resources associated with it by the user.
The raster image objects can be obtained from multiple sources as explained in LEADTOOLS Document Writers.
The LEADTOOLS Document Writer supports creating documents with zero or more empty pages inside them. Simply pass a page of type DocumentWriterEmptyPage to DocumentWriter.AddPage or DocumentWriter.InsertPage methods. The dimension of the empty page must be set before hand in the DocumentOptions.EmptyPageWidth and DocumentOptions.EmptyPageHeight and its resolution set to DocumentOptions.EmptyPageResolution. As many empty pages as desired can be added and in any index desired. To use empty pages, make sure the DocumentOptions.PageRestriction property is set to DocumentPageRestriction.Relaxed.
using Leadtools;
using Leadtools.Codecs;
using Leadtools.Document.Writer;
using Leadtools.Ocr;
public void DocumentRasterPageExample()
{
// Input file name
var inputFileName = Path.Combine(LEAD_VARS.ImagesDir, "TEST.docx");
// Output PDF file name
var outputFileName = Path.Combine(LEAD_VARS.ImagesDir, "out_Example.pdf");
// Create a new instance of the LEADTOOLS Document Writer
var docWriter = new DocumentWriter();
// Setup a new RasterCodecs object
using (var codecs = new RasterCodecs())
{
codecs.Options.RasterizeDocument.Load.Resolution = 300;
// Get information on the page
double pageWidth;
double pageHeight;
using (var info = codecs.GetInformation(inputFileName, false, 1))
{
// Get the size in inches, we need it for the empty page
pageWidth = info.Document.PageWidth;
pageHeight = info.Document.PageHeight;
}
// Begin the document
docWriter.BeginDocument(outputFileName, DocumentFormat.Pdf);
// Add the first page from SVG
var svgPage = new DocumentWriterSvgPage();
using (svgPage.SvgDocument = codecs.LoadSvg(inputFileName, 1, null))
{
// Add it
docWriter.AddPage(svgPage);
}
// Add a second page as empty
var emptyPage = new DocumentWriterEmptyPage();
emptyPage.Width = pageWidth;
emptyPage.Height = pageHeight;
docWriter.AddPage(emptyPage);
// Finally, add a third page as an image
var rasterPage = new DocumentWriterRasterPage();
using (rasterPage.Image = codecs.Load(inputFileName, 1))
{
// Add it
docWriter.AddPage(rasterPage);
}
}
// Finally finish writing the HTML file on disk
docWriter.EndDocument();
}
static class LEAD_VARS
{
public const string ImagesDir = @"C:\LEADTOOLS23\Resources\Images";
}