An unsigned integer specifying the equality threshold for colors.
public uint Threshold {get; set;}
@property (nonatomic, assign) NSUInteger threshold;
public long getThreshold();
public void setThreshold(
long longValue
);
public:
property UInt32 Threshold
{
UInt32 get()
void set(UInt32 value)
}
Threshold # get and set (CompareBitmapCommand)
The maximum distance between two colors that can still be considered to be equal. The default value is 0.
The Threshold defines the range in color values allowed and still be considered the same color. The distance is calculated in Euclidean RGB color space using the following equation:
using Leadtools;
using Leadtools.Codecs;
using Leadtools.ImageProcessing;
using Leadtools.ImageProcessing.Core;
public void CompareBitmapCommandExample()
{
using (RasterCodecs codecs = new RasterCodecs())
// Load the original image
using (RasterImage referenceImage = codecs.Load(Path.Combine(LEAD_VARS.ImagesDir, "ocr1.tif")))
// Use the same image for the "modified" image
using (RasterImage modifiedImage = referenceImage.Clone())
{
// Remove the last paragraph of the reference image
referenceImage.AddRectangleToRegion(null, new LeadRect(290, 2470, 1930, 360), RasterRegionCombineMode.Set);
new FillCommand(RasterColor.White).Run(referenceImage);
referenceImage.MakeRegionEmpty();
// Remove the title from the modified image
modifiedImage.AddRectangleToRegion(null, new LeadRect(290, 300, 810, 110), RasterRegionCombineMode.Set);
new FillCommand(RasterColor.White).Run(modifiedImage);
modifiedImage.MakeRegionEmpty();
// Rotate the modified image for demonstration (angle measured in hundredths of a degree)
new RotateCommand(340 * 100, RotateCommandFlags.Resize, RasterColor.Black).Run(modifiedImage);
// Update the transformation to align/reverse the above rotation
LeadMatrix alignment = LeadMatrix.Identity;
alignment.Translate(-modifiedImage.Width * 0.5, -modifiedImage.Height * 0.5);
alignment.Rotate(20.0);
alignment.Translate(referenceImage.Width * 0.5, referenceImage.Height * 0.5);
// Setup the comparison options
CompareBitmapCommand command = new CompareBitmapCommand()
{
Alignment = alignment,
ReferenceImage = referenceImage,
// following properties can be left to their defaults or set to desired values:
ModifiedBackground = RasterColor.White,
ModifiedForeground = RasterColor.Black,
OutputAddition = RasterColor.FromKnownColor(RasterKnownColor.Lime),
OutputBackground = RasterColor.FromKnownColor(RasterKnownColor.White),
OutputChange = RasterColor.FromKnownColor(RasterKnownColor.Yellow),
OutputDeletion = RasterColor.FromKnownColor(RasterKnownColor.Red),
OutputExternal = new RasterColor(0x80, 0x80, 0xff),
OutputMatch = new RasterColor(0x40, 0x40, 0x40),
ReferenceBackground = RasterColor.White,
ReferenceForeground = RasterColor.Black,
Threshold = 0
};
// Compare the images
command.Run(modifiedImage);
// Save the results
using (RasterImage outputImage = command.OutputImage)
codecs.Save(outputImage, Path.Combine(LEAD_VARS.ImagesDir, "CompareBitmap_Output.png"), RasterImageFormat.Png, 0);
// Save the two input images, for reference
codecs.Save(referenceImage, Path.Combine(LEAD_VARS.ImagesDir, "CompareBitmap_Reference.png"), RasterImageFormat.Png, 0);
codecs.Save(modifiedImage, Path.Combine(LEAD_VARS.ImagesDir, "CompareBitmap_Modified.png"), RasterImageFormat.Png, 0);
}
}
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