←Select platform

HolePunchRemove Event

Summary
Optional delegate method for additional processing.
Syntax
C#
C++/CLI
Python
public event EventHandler<HolePunchRemoveCommandEventArgs> HolePunchRemove 
public: 
event EventHandler<HolePunchRemoveCommandEventArgs^>^ HolePunchRemove 
def HolePunchRemove(sender,e): # sender: HolePunchRemoveCommand e: HolePunchRemoveCommandEventArgs 
Event Data

The event handler receives an argument of type HolePunchRemoveCommandEventArgs containing data related to this event. The following HolePunchRemoveCommandEventArgs properties provide information specific to this event.

PropertyDescription
BlackCount Gets the total number of black pixels in one of the holes of a hole punch pattern.
BoundingRectangle Gets a rectangle structure that contains the bounding rectangle of one of the holes in a hole punch pattern.
HoleIndex Gets the index of the hole within a hole punch pattern.
HoleTotalCount Gets the total number of holes that make up the hole punch pattern.
Image Gets the RasterImage object that references the affected image.
Region Gets the LEADTOOLS RasterRegion representing one of the holes of the hole punch pattern.
Status Gets or sets the status of the hole punch removal process.
WhiteCount Gets the total number of white pixels in one of the holes of a hole punch pattern.
Example
C#
using Leadtools; 
using Leadtools.Codecs; 
using Leadtools.ImageProcessing.Core; 
 
public void HolePunchRemoveCommandExample() 
{ 
   // Load an image 
   RasterCodecs codecs = new RasterCodecs(); 
   codecs.ThrowExceptionsOnInvalidImages = true; 
 
   RasterImage image = codecs.Load(Path.Combine(LEAD_VARS.ImagesDir, "Clean.tif")); 
 
   // Prepare the command 
   HolePunchRemoveCommand command = new HolePunchRemoveCommand(); 
   command.HolePunchRemove += new EventHandler<HolePunchRemoveCommandEventArgs>(HolePunchRemoveEvent_S1); 
   command.Flags = HolePunchRemoveCommandFlags.UseDpi | HolePunchRemoveCommandFlags.UseCount | HolePunchRemoveCommandFlags.UseLocation; 
   command.Location = HolePunchRemoveCommandLocation.Left; 
   command.MaximumHoleCount = 4; 
   command.MinimumHoleCount = 2; 
 
   command.Run(image); 
 
} 
 
private void HolePunchRemoveEvent_S1(object sender, HolePunchRemoveCommandEventArgs e) 
{ 
   MessageBox.Show("Size " + "( " + e.BoundingRectangle.Left + ", " + e.BoundingRectangle.Top + ") - " + "( " + e.BoundingRectangle.Right + ", " + e.BoundingRectangle.Bottom + ")" + 
      "\n Hole Index " + e.HoleIndex.ToString() + 
      "\n Holes Total Count " + e.HoleTotalCount.ToString() + 
      "\n Black Count " + e.BlackCount.ToString() + 
      "\n White Count " + e.WhiteCount.ToString()); 
   e.Status = RemoveStatus.Remove; 
} 
 
static class LEAD_VARS 
{ 
   public const string ImagesDir = @"C:\LEADTOOLS22\Resources\Images"; 
} 
Requirements

Target Platforms

Help Version 22.0.2023.11.1
Products | Support | Contact Us | Intellectual Property Notices
© 1991-2023 LEAD Technologies, Inc. All Rights Reserved.

Leadtools.ImageProcessing.Core Assembly

Products | Support | Contact Us | Intellectual Property Notices
© 1991-2023 LEAD Technologies, Inc. All Rights Reserved.