public RasterImage CloneAll()
- (nullable LTRasterImage *)cloneAll:(NSError **)error
public RasterImage cloneAll();
public:
RasterImage^ CloneAll();
def CloneAll(self):
The RasterImage this method creates.
You can also use the RasterImage(RasterImage) constructor to create an exact copy of an existing RasterImage.
To create a copy of an object while maintaining a progress status, refer to the CloneCommand.
This method copies all the pages and any metadata contained in the RasterImage. To create a copy of only the current active page (no metadata information), use the Clone method.
To clone an image with support for a progress event, refer to CloneCommand.
using Leadtools;
using Leadtools.Codecs;
using Leadtools.ImageProcessing;
using Leadtools.ImageProcessing.Core;
using Leadtools.ImageProcessing.Color;
using Leadtools.Dicom;
using Leadtools.Drawing;
using Leadtools.Controls;
using Leadtools.Svg;
public void CloneExample()
{
RasterCodecs codecs = new RasterCodecs();
string srcFileName = Path.Combine(LEAD_VARS.ImagesDir, "eye.gif");
// Load the multi-page image
RasterImage srcImage = codecs.Load(srcFileName);
Console.WriteLine("Pages in source image: {0}", srcImage.PageCount);
// Use the Clone method to clone this image
// Notice, this method only clones the current active page only
RasterImage destImage1 = srcImage.Clone();
Console.WriteLine("Pages in image created with Clone: {0}", destImage1.PageCount);
Assert.IsTrue(destImage1.PageCount == 1);
// Use the Clone rectangle method to clone this image
// Notice, this method also clones the current active page only
LeadRect rc = new LeadRect(0, 0, srcImage.Width / 2, srcImage.Height / 2);
Console.WriteLine("Cloning with a rectangle = {0}", rc.ToString());
RasterImage destImage2 = srcImage.Clone(rc);
Console.WriteLine("Pages in image created with Clone(LeadRect): {0}", destImage2.PageCount);
Console.WriteLine("Image created with Clone(LeadRect) size = {0} by {1}", destImage2.Width, destImage2.Height);
Assert.IsTrue(destImage2.PageCount == 1);
Assert.IsTrue(destImage2.Width == srcImage.Width / 2);
Assert.IsTrue(destImage2.Height == srcImage.Height / 2);
// Use the CloneAll method, this should create a copy
// of all the pages
RasterImage destImage3 = srcImage.CloneAll();
Console.WriteLine("Pages in image created with CloneAll: {0}", destImage3.PageCount);
Assert.IsTrue(destImage3.PageCount == srcImage.PageCount);
// Use the CloneCommand, this allows you to have a progress
// bar as well as control the memory flags, here
// we will create a destination image using disk memory.
CloneCommand cloneCmd = new CloneCommand();
cloneCmd.Progress += new EventHandler<RasterCommandProgressEventArgs>(cloneCmd_Progress);
cloneCmd.CreateFlags = RasterMemoryFlags.Disk;
cloneCmd.Run(srcImage);
cloneCmd.Progress -= new EventHandler<RasterCommandProgressEventArgs>(cloneCmd_Progress);
RasterImage destImage4 = cloneCmd.DestinationImage;
Console.WriteLine("Pages in image created with CloneCommand: {0}", destImage4.PageCount);
Console.WriteLine("Disk memory model of image created with CloneCommand: {0}", destImage4.IsDiskMemory);
Assert.IsTrue(destImage4.PageCount == 1);
Assert.IsTrue(destImage4.IsDiskMemory);
// Clean up
destImage4.Dispose();
destImage3.Dispose();
destImage2.Dispose();
destImage1.Dispose();
srcImage.Dispose();
codecs.Dispose();
}
void cloneCmd_Progress(object sender, RasterCommandProgressEventArgs e)
{
if (e.Percent == 0)
Console.WriteLine("Clone progress started");
if (e.Percent == 100)
Console.WriteLine("Clone progress ended");
}
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