public void CompactFile(Stream srcStream,Stream destStream,int pages)
- (BOOL)compactStream:(LTLeadStream *)sourceStreamdestinationStream:(LTLeadStream *)destinationStreampages:(NSUInteger)pageserror:(NSError **)error
public:void CompactFile(Stream^ srcStream,Stream^ destStream,int pages)
def CompactFile(self,srcStream,destStream,pages): 
srcStream
A source Stream containing the data for the file being compacted. All the pages will be read from this stream.
destStream
A destination Stream that will contain the written data.
pages
Value that represents the number of pages to copy. Use 0 to copy all the pages. If  pages is > 0, only  pages will be copied to  destStream.
This method can also be used to copy or extract one or more pages from a TIFF/BigTIFF file and copy them without recompression to another TIFF/BigTIFF file.
This method can also be used to convert a TIFF file to BigTIFF or vice versa. The destination file will be TIFF or BigTIFF, depending on the value of BigTiff.
If the source is PNG, the destination is also PNG. If the source is Exif JPEG, the destination is also Exif JPEG. For both of these formats, setting pages to 1 will discard the thumbnail if it exists.
using Leadtools;using Leadtools.Codecs;using Leadtools.ImageProcessing;using Leadtools.ImageProcessing.Color;using Leadtools.Svg;public void CompactFileExample(){RasterCodecs codecs = new RasterCodecs();string srcFileName = Path.Combine(LEAD_VARS.ImagesDir, "CompactFile1_Src.tif");string destFileName = Path.Combine(LEAD_VARS.ImagesDir, "CompactFile1_Dest.tif");// Create a RasterImage with 4 pages containing text showing the page numberRasterImage image = null;const int pageCount = 4;using (System.Drawing.Font f = new System.Drawing.Font("Arial", 36, System.Drawing.FontStyle.Bold))using (System.Drawing.Bitmap btmp = new System.Drawing.Bitmap(320, 200))using (System.Drawing.StringFormat sf = new System.Drawing.StringFormat()){System.Drawing.Rectangle rc = new System.Drawing.Rectangle(0, 0, btmp.Width, btmp.Height);sf.Alignment = System.Drawing.StringAlignment.Center;sf.LineAlignment = System.Drawing.StringAlignment.Center;for (int i = 1; i <= pageCount; i++){// Create a GDI+ bitmap with the textstring text = "Page " + i;using (System.Drawing.Graphics g = System.Drawing.Graphics.FromImage(btmp)){g.FillRectangle(System.Drawing.Brushes.White, rc);g.DrawString(text, f, System.Drawing.Brushes.Black, rc, sf);}RasterImage tempImage = Leadtools.Drawing.RasterImageConverter.ConvertFromImage(btmp, Leadtools.Drawing.ConvertFromImageOptions.None);if (image == null)image = tempImage;elseimage.AddPage(tempImage);}}// Save all the pages to the file// The file should have 4 pages now: 1, 2, 3, 4codecs.Save(image, srcFileName, RasterImageFormat.Tif, 1, 1, pageCount, 1, CodecsSavePageMode.Overwrite);image.Dispose();// All the pages in the source TIFF file. This will create the destination filecodecs.CompactFile(srcFileName, destFileName, 0);// Compact the source file again and append all the pages to the existing destination fileint pagesToAdd = 0; // 0 means all pagesint srcStartPage = 1;int destStartPage = 5; // insert at the endcodecs.CompactFile(srcFileName,destFileName,pagesToAdd,srcStartPage,false,0,destStartPage,false,0,CodecsSavePageMode.Insert,false,false);// Clean upcodecs.Dispose();}static class LEAD_VARS{public const string ImagesDir = @"C:\LEADTOOLS22\Resources\Images";}
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
