LEADTOOLS (Leadtools assembly) Send comments on this topic. | Back to Introduction - All Topics | Help Version 17.0.3.29
CombineFastCommand Class
See Also  Members  
Leadtools.ImageProcessing Namespace : CombineFastCommand Class



Combines image data from two images (source and destination), letting you specify the areas to be combined and the operations to be performed when combining the data. Supported in Silverlight, Windows Phone 7

Object Model

CombineFastCommand ClassRasterImage ClassLeadRect StructureLeadPoint Structure

Syntax

Visual Basic (Declaration) 
Public Class CombineFastCommand 
   Inherits RasterCommand
   Implements IRasterCommand 
Visual Basic (Usage)Copy Code
Dim instance As CombineFastCommand
C# 
public class CombineFastCommand : RasterCommand, IRasterCommand  
C++/CLI 
public ref class CombineFastCommand : public RasterCommand, IRasterCommand  

Example

The following example loads two images and combines them using an "AND" operation.

Visual BasicCopy Code
Public Sub CombineFastCommandExample()
      Dim codecs As RasterCodecs = New RasterCodecs()

      Dim srcFileName1 As String = Path.Combine(LEAD_VARS.ImagesDir, "Image1.cmp")
      Dim srcFileName2 As String = Path.Combine(LEAD_VARS.ImagesDir, "Image2.cmp")
      Dim destFileName As String = Path.Combine(LEAD_VARS.ImagesDir, "CombineFastCommand.bmp")

      ' Load the source images from disk
      Dim srcImage As RasterImage = codecs.Load(srcFileName1)
      Dim destImage As RasterImage = codecs.Load(srcFileName2)

      ' Combine them
      Dim command As CombineFastCommand = New CombineFastCommand()

      ' Specify a position in the destination image
      command.DestinationRectangle = New LeadRect(destImage.Width \ 8, destImage.Height \ 8, destImage.Width, destImage.Height)
      command.SourcePoint = LeadPoint.Empty
      command.DestinationImage = destImage
      command.Flags = CombineFastCommandFlags.OperationAdd Or CombineFastCommandFlags.Destination0
      command.Run(srcImage)

      ' Save it to disk
      codecs.Save(destImage, destFileName, RasterImageFormat.Bmp, 24)

      ' Clean Up
      destImage.Dispose()
      srcImage.Dispose()
   End Sub

Public NotInheritable Class LEAD_VARS
   Public Const ImagesDir As String = "C:\Users\Public\Documents\LEADTOOLS Images"
End Class
C#Copy Code
public void CombineFastCommandExample()
   {
      RasterCodecs codecs = new RasterCodecs();

      string srcFileName1 = Path.Combine(LEAD_VARS.ImagesDir, "Image1.cmp");
      string srcFileName2 = Path.Combine(LEAD_VARS.ImagesDir, "Image2.cmp");
      string destFileName = Path.Combine(LEAD_VARS.ImagesDir, "CombineFastCommand.bmp");

      // Load the source images from disk
      RasterImage srcImage = codecs.Load(srcFileName1);
      RasterImage destImage = codecs.Load(srcFileName2);

      // Combine them
      CombineFastCommand command = new CombineFastCommand();

      // Specify a position in the destination image
      command.DestinationRectangle = new LeadRect(
         destImage.Width / 8,
         destImage.Height / 8,
         destImage.Width,
         destImage.Height);
      command.SourcePoint = LeadPoint.Empty;
      command.DestinationImage = destImage;
      command.Flags = CombineFastCommandFlags.OperationAdd | CombineFastCommandFlags.Destination0;
      command.Run(srcImage);

      // Save it to disk
      codecs.Save(destImage, destFileName, RasterImageFormat.Bmp, 24);

      // Clean Up
      destImage.Dispose();
      srcImage.Dispose();
   }

static class LEAD_VARS
{
   public const string ImagesDir = @"C:\Users\Public\Documents\LEADTOOLS Images";
}
SilverlightCSharpCopy Code
public void CombineFastCommandExample(RasterImage srcImage, RasterImage destImage, Stream destStream)
{
   RasterCodecs codecs = new RasterCodecs();
   // Combine them
   CombineFastCommand command = new CombineFastCommand();

   // Specify a position in the destination image
   command.DestinationRectangle = new LeadRect(
      destImage.Width / 8,
      destImage.Height / 8,
      destImage.Width,
      destImage.Height);
   command.SourcePoint = LeadPoint.Empty;
   command.DestinationImage = destImage;
   command.Flags = CombineFastCommandFlags.OperationAdd | CombineFastCommandFlags.Destination0;
   command.Run(srcImage);

   // Save it to disk
   codecs.Save(destImage, destStream, RasterImageFormat.Png, 24);

   // Clean Up
   destImage.Dispose();
   srcImage.Dispose();
}
SilverlightVBCopy Code
Public Sub CombineFastCommandExample(ByVal srcImage As RasterImage, ByVal destImage As RasterImage, ByVal destStream As Stream)
   Dim codecs As RasterCodecs = New RasterCodecs()
   ' Combine them
   Dim command As CombineFastCommand = New CombineFastCommand()

   ' Specify a position in the destination image
   command.DestinationRectangle = New LeadRect(destImage.Width / 8, destImage.Height / 8, destImage.Width, destImage.Height)
   command.SourcePoint = LeadPoint.Empty
   command.DestinationImage = destImage
   command.Flags = CombineFastCommandFlags.OperationAdd Or CombineFastCommandFlags.Destination0
   command.Run(srcImage)

   ' Save it to disk
   codecs.Save(destImage, destStream, RasterImageFormat.Png, 24)

   ' Clean Up
   destImage.Dispose()
   srcImage.Dispose()
End Sub

Remarks

As an example, suppose you use Leadtools.ImageProcessing.Effects.SpatialFilterCommand class to apply an edge detection filter. You can then use this class to combine the resulting image with the original one to produce an image with hard edges.

The CombineFastCommand class works by combining the image in the DestinationImage property with the image passed to the RasterCommand.Run method. The DestinationImage will then hold the result of the combine operation.

The CombineFastCommand flags are divided into four groupings: source (SRC) flags, destination (DST) flags, operation (OP) flags, and resulting image (RES) flags. The flags apply only to the defined rectangles (not necessarily the whole image). The flags are applied in the following order:

  1. Operations on the source and destination rectangles are applied. These are implemented at the same time.
  2. Combining operations are performed.
  3. Operations on the resulting rectangle are applied.

You can use a bitwise OR (|) to specify one flag from each group.

Group Flags
Flags that define treatment of the source rectangle None, SourceNot, Source0, Source1
Flags that define treatment of the destination rectangle DestinationNot, Destination0, Destination1
Flags that define the operation to use when combining the data OperationOr, OperationXor, OperationAdd, OperationSubtractSource, OperationSubtractDestination, OperationMultiply, OperationDivideSource, OperationDivideDestination, OperationAverage, OperationMinimum, OperationMaximum
Flags that define treatment of the resulting image rectangle ResultNot, Result0, Result1, SourceCopy

Certain flags when combined have no meaning:

  • Setting the flag (RES flags) to either CB_RES_0 or CB_RES_1 will render the rest of the flags useless.
  • Setting the SRC and DST flags to CB_SRC_0 and CB_DST_0 respectively, then the OP flags (the operation flags) will be useless.
  • Setting the SRC and DST flags to CB_SRC_1 and CB_DST_1 respectively, then the OP flags (the operation flags) will be useless.
  • Setting the flag (OP Flags) to CB_OP_ADD or CB_OP_OR or CB_OP_MAX, while setting the (SRC flags) to CB_SRC_1 will make the (DST flags) useless.
  • Setting the flag (OP Flags) to CB_OP_ADD or CB_OP_OR or CB_OP_MAX, while setting the (DST flags) to CB_SRC_1 will make the (SRC flags) useless.
  • Setting the flag (OP Flags) to CB_OP_AND or CB_OP_SUBDST or CB_OP_MIN, while setting the (SRC flags) to CB_SRC_0 will make the (DST flags) useless.
  • Setting the flag (OP Flags) to CB_OP_AND or CB_OP_SUBSRC or CB_OP_MIN, while setting the (DST flags) to CB_SRC_0 will make the (SRC flags) useless.

For more options, like specifying the color plane, use Leadtools.ImageProcessing.Effects.CombineCommand.

For more information, refer to Processing an Image.

Inheritance Hierarchy

System.Object
   Leadtools.ImageProcessing.RasterCommand
      Leadtools.ImageProcessing.CombineFastCommand

Requirements

Target Platforms: Silverlight, Windows XP, Windows Server 2003 family, Windows Server 2008 family, Windows Vista, Windows 7, MAC OS/X (Intel Only), Windows Phone 7

See Also