この例では、1 つ以上の Geometry オブジェクトで構成されるビジュアル オブジェクトに対してヒット テストを実行する方法を示します。
例
次の例は、DrawingGroup メソッドを使用するビジュアル オブジェクトからGetDrawingを取得する方法を示しています。 次に、 DrawingGroup 内の各図面のレンダリングされたコンテンツに対してヒット テストが実行され、ヒットしたジオメトリが特定されます。
注
ほとんどの場合、 HitTest メソッドを使用して、ポイントがビジュアルのレンダリングされたコンテンツと交差するかどうかを判断します。
// 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
FillContains メソッドはオーバーロードされたメソッドであり、指定したPointまたはGeometryを使用してヒット テストを実行できます。 ジオメトリをストロークすると、ストロークは塗りつぶし境界の外側に延びることがあります。 その場合は、StrokeContainsに加えてFillContainsを呼び出す必要があります。
ベジエフラット化の目的で使用される ToleranceType を提供することもできます。
注
このサンプルでは、ジオメトリに適用できる変換やクリッピングは考慮されません。 さらに、このサンプルはスタイル付きコントロールでは、直接関連付けられた描画がないため、動作しません。
こちらも参照ください
GitHub で Microsoft と共同作業する
このコンテンツのソースは GitHub にあります。そこで、issue や pull request を作成および確認することもできます。 詳細については、共同作成者ガイドを参照してください。
.NET Desktop feedback