hDocCleanRgn example for Visual Basic

    Dim nRet As Integer
    'HolePunch Remove
    'This example updates a windows region with all removed hole punches
    'For the example, a windows region is updated and then converted to a LEAD region
    'but in practice it would easier and faster to just update a LEAD region
    'The HOLEPUNCH_USE_DPI flag instructs the API to determine the size of the hole punches
    'based on the image DPI
    'The image is modified
    'The HolePunch Event is used to display information about each hole punch removed
    nRet = LEAD1.HolePunchRemove(HOLEPUNCH_SINGLE_REGION Or HOLEPUNCH_USE_DPI Or HOLEPUNCH_USE_COUNT Or HOLEPUNCH_USE_LOCATION, _
                                 2, 4, 0, 0, 0, 0, HOLEPUNCH_LEFT)
    
    If (nRet = 0) Then
        LEAD1.FreeRgn
        LEAD1.SetRgnHandle LEAD1.hDocCleanRgn, 0, 0, L_RGN_SET
        LEAD1.hDocCleanRgn = 0 'no longer need rgn
        LEAD1.RgnFrameType = RGNFRAME_COLOR
    End If

Private Sub LEAD1_HolePunchRemove(ByVal hRgn As Stdole.OLE_HANDLE, ByVal fBoundingRectLeft As Single, ByVal fBoundingRectTop As Single, ByVal fBoundingRectWidth As Single, ByVal fBoundingRectHeight As Single, ByVal iHoleIndex As Long, ByVal iHoleTotalCount As Long, ByVal iWhiteCount As Long, ByVal iBlackCount As Long)
    Debug.Print "HolePunch at " & CStr(fBoundingRectLeft) & "," & CStr(fBoundingRectTop) _
                & "," & CStr(fBoundingRectWidth) & "," & CStr(fBoundingRectHeight) _
                & " HoleIndex=" & CStr(iHoleIndex) & " TotalCount=" & CStr(iHoleTotalCount) _
                & " WhiteCount=" & CStr(iWhiteCount) & " BlackCount=" & CStr(iBlackCount)
End Sub