InkCanvasSelectionHitResult Enumeration

Identifies the various parts of a selection adorner of an InkCanvas.

Namespace: System.Windows.Controls
Assembly: PresentationFramework (in presentationframework.dll)
XML Namespace:

Public Enumeration InkCanvasSelectionHitResult
Dim instance As InkCanvasSelectionHitResult

public enum InkCanvasSelectionHitResult
public enum InkCanvasSelectionHitResult
 This class is not typically used in XAML. 

 Member nameDescription
BottomThe lower middle handle of the selection adorner. 
BottomLeftThe lower left handle of the selection adorner. 
BottomRightThe lower right handle of the selection adorner. 
LeftThe middle handle on the left edge of the selection adorner. 
NoneNo part of the selection adorner. 
RightThe middle handle on the right edge of the selection adorner. 
SelectionThe area within the bounds of the selection adorner. 
TopThe upper middle handle of the selection adorner. 
TopLeftThe upper left handle of the selection adorner. 
TopRightThe upper right handle of the selection adorner. 

The HitTestSelection method returns an InkCanvasSelectionHitResult to indicate which part of the selection adorner intersects or surrounds a Point. This is useful when performing drag-and-drop operations.

The following example demonstrates how use HitTestSelection to determine whether to create a DataObject to initiate drag and drop. To implement drag and drop between two InkCanvas objects, see How to: Drag and Drop Ink.

Sub InkCanvas_PreviewMouseDown(ByVal sender As Object, _
                               ByVal e As MouseButtonEventArgs)

    Dim ic As InkCanvas = CType(sender, InkCanvas)

    Dim pt As Point = e.GetPosition(ic)

    ' If the user is moving selected strokes, prepare the strokes to be
    ' moved to another InkCanvas.
    If ic.HitTestSelection(pt) = InkCanvasSelectionHitResult.Selection Then

        Dim selectedStrokes As StrokeCollection = _

        Dim strokesToMove As StrokeCollection = _

        ' Remove the offset of the selected strokes so they
        ' are positioned when the strokes are dropped.
        Dim inkBounds As Rect = strokesToMove.GetBounds()
        TranslateStrokes(strokesToMove, -inkBounds.X, -inkBounds.Y)

        ' Perform drag and drop.
        Dim ms As New MemoryStream()

        Dim dataObject As New DataObject _
            (StrokeCollection.InkSerializedFormat, ms)

        Dim effects As DragDropEffects = _
            DragDrop.DoDragDrop(ic, dataObject, DragDropEffects.Move)

        If (effects And DragDropEffects.Move) = DragDropEffects.Move Then

            ' Remove the selected strokes from the current InkCanvas.
        End If
    End If

End Sub 'OnMouseDown

Windows 98, Windows Server 2000 SP4, Windows CE, Windows Millennium Edition, Windows Mobile for Pocket PC, Windows Mobile for Smartphone, Windows Server 2003, Windows XP Media Center Edition, Windows XP Professional x64 Edition, Windows XP SP2, Windows XP Starter Edition

The Microsoft .NET Framework 3.0 is supported on Windows Vista, Microsoft Windows XP SP2, and Windows Server 2003 SP1.

.NET Framework

Supported in: 3.0