Procedura: eseguire un hit test della geometria in un oggetto Visual
In questo esempio viene illustrato come eseguire un hit test su un oggetto visivo composto da uno o più Geometry oggetti.
Esempio
Nell'esempio seguente viene illustrato come recuperare l'oggetto DrawingGroup da un oggetto visivo che usa il GetDrawing metodo . Viene quindi eseguito un hit test sul contenuto sottoposto a rendering di ogni disegno in DrawingGroup per determinare quale geometria è stata raggiunta.
Nota
Nella maggior parte dei casi, è necessario utilizzare il HitTest metodo per determinare se un punto interseca uno qualsiasi dei contenuti di cui è stato eseguito il rendering di un oggetto visivo.
// Determine if a geometry within the visual was hit.
static public void HitTestGeometryInVisual(Visual visual, Point pt)
{
// Retrieve the group of drawings for the visual.
DrawingGroup drawingGroup = VisualTreeHelper.GetDrawing(visual);
EnumDrawingGroup(drawingGroup, pt);
}
// Enumerate the drawings in the DrawingGroup.
static public void EnumDrawingGroup(DrawingGroup drawingGroup, Point pt)
{
DrawingCollection drawingCollection = drawingGroup.Children;
// Enumerate the drawings in the DrawingCollection.
foreach (Drawing drawing in drawingCollection)
{
// If the drawing is a DrawingGroup, call the function recursively.
if (drawing.GetType() == typeof(DrawingGroup))
{
EnumDrawingGroup((DrawingGroup)drawing, pt);
}
else if (drawing.GetType() == typeof(GeometryDrawing))
{
// Determine whether the hit test point falls within the geometry.
if (((GeometryDrawing)drawing).Geometry.FillContains(pt))
{
// Perform action based on hit test on geometry.
}
}
}
}
' Determine if a geometry within the visual was hit.
Public Shared Sub HitTestGeometryInVisual(ByVal visual As Visual, ByVal pt As Point)
' Retrieve the group of drawings for the visual.
Dim drawingGroup As DrawingGroup = VisualTreeHelper.GetDrawing(visual)
EnumDrawingGroup(drawingGroup, pt)
End Sub
' Enumerate the drawings in the DrawingGroup.
Public Shared Sub EnumDrawingGroup(ByVal drawingGroup As DrawingGroup, ByVal pt As Point)
Dim drawingCollection As DrawingCollection = drawingGroup.Children
' Enumerate the drawings in the DrawingCollection.
For Each drawing As Drawing In drawingCollection
' If the drawing is a DrawingGroup, call the function recursively.
If drawing.GetType() Is GetType(DrawingGroup) Then
EnumDrawingGroup(CType(drawing, DrawingGroup), pt)
ElseIf drawing.GetType() Is GetType(GeometryDrawing) Then
' Determine whether the hit test point falls within the geometry.
If (CType(drawing, GeometryDrawing)).Geometry.FillContains(pt) Then
' Perform action based on hit test on geometry.
End If
End If
Next drawing
End Sub
Il FillContains metodo è un metodo di overload che consente di eseguire il hit test usando un oggetto specificato Point o Geometry. Se viene tracciata una geometria, il tratto può estendersi oltre i limiti del riempimento. In questo caso, è possibile chiamare StrokeContains oltre a FillContains.
È anche possibile fornire un ToleranceType oggetto che viene usato ai fini dell'appiattimento di Bezier.
Nota
Questo esempio non prende in considerazione eventuali trasformazioni o ritagli applicabili alla geometria. L'esempio, inoltre, non funziona con un controllo con stili, poiché a esso non saranno direttamente associati disegni.
Vedi anche
.NET Desktop feedback