次の方法で共有


プロセス: ビジュアルでジオメトリのヒットテストを行う方法

この例では、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 を提供することもできます。

このサンプルでは、ジオメトリに適用できる変換やクリッピングは考慮されません。 さらに、このサンプルはスタイル付きコントロールでは、直接関連付けられた描画がないため、動作しません。

こちらも参照ください