StrokeCollection.HitTest Método

Definição

Retorna uma coleção de traços contidos na área especificada.

Sobrecargas

Nome Description
HitTest(Rect, Int32)

Retorna uma coleção de traços que têm pelo menos o percentual de comprimento especificado dentro do retângulo especificado.

HitTest(Point, Double)

Retorna uma coleção de traços que cruzam a área especificada.

HitTest(IEnumerable<Point>, StylusShape)

Retorna uma coleção de traços que se cruzam com o caminho especificado.

HitTest(IEnumerable<Point>, Int32)

Retorna uma coleção de traços que têm pelo menos o percentual especificado de comprimento dentro da área especificada.

HitTest(Point)

Retorna uma coleção de traços que cruzam o ponto especificado.

HitTest(Rect, Int32)

Retorna uma coleção de traços que têm pelo menos o percentual de comprimento especificado dentro do retângulo especificado.

public:
 System::Windows::Ink::StrokeCollection ^ HitTest(System::Windows::Rect bounds, int percentageWithinBounds);
public System.Windows.Ink.StrokeCollection HitTest(System.Windows.Rect bounds, int percentageWithinBounds);
member this.HitTest : System.Windows.Rect * int -> System.Windows.Ink.StrokeCollection
Public Function HitTest (bounds As Rect, percentageWithinBounds As Integer) As StrokeCollection

Parâmetros

bounds
Rect

Um Rect que especifica os limites a serem atingidos testados.

percentageWithinBounds
Int32

O comprimento mínimo necessário de um Traço que deve existir dentro dos limites para que ele seja considerado atingido.

Retornos

Um StrokeCollection que tem traços com pelo menos a porcentagem especificada dentro do Rect.

Exemplos

O exemplo a seguir apaga os traços que são pelo menos 50% dentro dos limites do Rect. Este exemplo pressupõe que há um InkPresenter chamado presenter.

Rect rect = new Rect(100, 100, 200, 200);
StrokeCollection strokes = presenter.Strokes.HitTest(rect, 50);

presenter.Strokes.Remove(strokes);
Dim rect As Rect = New Rect(100, 100, 200, 200)
Dim strokes As StrokeCollection = presenter.Strokes.HitTest(rect, 50)

presenter.Strokes.Remove(strokes)

Aplica-se a

HitTest(Point, Double)

Retorna uma coleção de traços que cruzam a área especificada.

public:
 System::Windows::Ink::StrokeCollection ^ HitTest(System::Windows::Point point, double diameter);
public System.Windows.Ink.StrokeCollection HitTest(System.Windows.Point point, double diameter);
member this.HitTest : System.Windows.Point * double -> System.Windows.Ink.StrokeCollection
Public Function HitTest (point As Point, diameter As Double) As StrokeCollection

Parâmetros

point
Point

O Point teste de ocorrência.

diameter
Double

O tamanho da área ao redor do Point teste de ocorrência.

Retornos

Uma coleção de Stroke objetos que cruzam o ponto especificado.

Exemplos

O exemplo a seguir demonstra como obter os traços que cruzam o especificado Point. Este exemplo pressupõe que há um InkPresenter chamado presenter.

// Change the color of all the strokes at the specified position.
public void SelectStrokes(Point position)
{
    StrokeCollection selected = presenter.Strokes.HitTest(position, 5);

    foreach (Stroke s in selected)
    {
        s.DrawingAttributes.Color = Colors.Purple;
    }
}
' Change the color of all the strokes at the specified position.
Public Sub SelectStrokes(ByVal position As Point)

    Dim selected As StrokeCollection = presenter.Strokes.HitTest(position, 5)

    Dim s As Stroke
    For Each s In selected
        s.DrawingAttributes.Color = Colors.Purple
    Next s

End Sub

Aplica-se a

HitTest(IEnumerable<Point>, StylusShape)

Retorna uma coleção de traços que se cruzam com o caminho especificado.

public:
 System::Windows::Ink::StrokeCollection ^ HitTest(System::Collections::Generic::IEnumerable<System::Windows::Point> ^ path, System::Windows::Ink::StylusShape ^ stylusShape);
public System.Windows.Ink.StrokeCollection HitTest(System.Collections.Generic.IEnumerable<System.Windows.Point> path, System.Windows.Ink.StylusShape stylusShape);
member this.HitTest : seq<System.Windows.Point> * System.Windows.Ink.StylusShape -> System.Windows.Ink.StrokeCollection
Public Function HitTest (path As IEnumerable(Of Point), stylusShape As StylusShape) As StrokeCollection

Parâmetros

path
IEnumerable<Point>

Uma matriz a ser digitado Point que representa o caminho a ser atingido testado.

stylusShape
StylusShape

O StylusShape que especifica a forma de eraserPath.

Retornos

Um StrokeCollection dos traços que se cruzam com path.

Exemplos

O exemplo a seguir altera a cor de todos os traços que cruzam o caminho criado pela Point matriz. Este exemplo pressupõe que há um InkPresenter chamado presenter.

private void HitTestWithEraser(Point[] points)
{
    RectangleStylusShape eraser = new RectangleStylusShape(3, 3, 0);

    StrokeCollection strokes = presenter.Strokes.HitTest(points, eraser);

    foreach (Stroke s in strokes)
    {
        s.DrawingAttributes.Color = Colors.Purple;
    }
}
Private Sub HitTestWithEraser(ByVal points() As Point)
    Dim eraser As RectangleStylusShape = New RectangleStylusShape(3, 3, 0)

    Dim strokes As StrokeCollection = presenter.Strokes.HitTest(points, eraser)

    Dim s As Stroke
    For Each s In strokes
        s.DrawingAttributes.Color = Colors.Purple
    Next
End Sub

Aplica-se a

HitTest(IEnumerable<Point>, Int32)

Retorna uma coleção de traços que têm pelo menos o percentual especificado de comprimento dentro da área especificada.

public:
 System::Windows::Ink::StrokeCollection ^ HitTest(System::Collections::Generic::IEnumerable<System::Windows::Point> ^ lassoPoints, int percentageWithinLasso);
public System.Windows.Ink.StrokeCollection HitTest(System.Collections.Generic.IEnumerable<System.Windows.Point> lassoPoints, int percentageWithinLasso);
member this.HitTest : seq<System.Windows.Point> * int -> System.Windows.Ink.StrokeCollection
Public Function HitTest (lassoPoints As IEnumerable(Of Point), percentageWithinLasso As Integer) As StrokeCollection

Parâmetros

lassoPoints
IEnumerable<Point>

Uma matriz de tipo Point que representa os limites da área a ser atingida foi testada.

percentageWithinLasso
Int32

O comprimento aceitável do Stroke, como um percentual, para lassoPoints conter.

Retornos

Um StrokeCollection que tem traços com pelo menos a porcentagem especificada dentro da Point matriz.

Exceções

lassoPoints é null.

- ou -

percentageWithinLasso é null.

lassoPoints contém uma matriz vazia.

percentageWithinLasso é menor que 0 ou maior que 100.

Exemplos

O exemplo a seguir demonstra como remover todos os traços que são pelo menos 80% dentro do laço especificado de um StrokeCollection. Isso é útil quando um controle personalizado permite que o usuário selecione tinta com um laço. Para criar um controle que permite que um usuário selecione tinta com um laço, consulte Como selecionar Tinta em um Controle Personalizado.

// Remove the strokes within the lasso from the InkPresenter
public void RemoveStrokes(Point[] lasso)
{
    StrokeCollection strokes = presenter.Strokes.HitTest(lasso, 80);

    presenter.Strokes.Remove(strokes);
}
' Remove the strokes within the lasso from the InkPresenter
Public Sub RemoveStrokes(ByVal lasso As Point())

    If lasso Is Nothing Then
        Return
    End If

    Dim strokes As StrokeCollection = _
        presenter.Strokes.HitTest(lasso, 80)

    presenter.Strokes.Remove(strokes)

End Sub

Aplica-se a

HitTest(Point)

Retorna uma coleção de traços que cruzam o ponto especificado.

public:
 System::Windows::Ink::StrokeCollection ^ HitTest(System::Windows::Point point);
public System.Windows.Ink.StrokeCollection HitTest(System.Windows.Point point);
member this.HitTest : System.Windows.Point -> System.Windows.Ink.StrokeCollection
Public Function HitTest (point As Point) As StrokeCollection

Parâmetros

point
Point

O ponto a ser atingido no teste.

Retornos

Uma coleção de Stroke objetos que cruzam o ponto especificado.

Exemplos

O exemplo a seguir demonstra como obter os traços que cruzam o especificado Point. Este exemplo pressupõe que há um InkPresenter chamado presenter.

// Change the color of all the strokes at the specified position.
public void SelectStrokes(Point position)
{
    StrokeCollection selected = presenter.Strokes.HitTest(position, 5);

    foreach (Stroke s in selected)
    {
        s.DrawingAttributes.Color = Colors.Purple;
    }
}
' Change the color of all the strokes at the specified position.
Public Sub SelectStrokes(ByVal position As Point)

    Dim selected As StrokeCollection = presenter.Strokes.HitTest(position, 5)

    Dim s As Stroke
    For Each s In selected
        s.DrawingAttributes.Color = Colors.Purple
    Next s

End Sub

Aplica-se a