Поделиться через


Stroke.GetEraseResult Метод

Определение

Возвращает сегменты текущего Stroke после удаления части Stroke.

Перегрузки

GetEraseResult(IEnumerable<Point>)

Возвращает сегменты текущего Stroke, которые находятся в заданных границах.

GetEraseResult(Rect)

Возвращает сегменты текущего Stroke, которые находятся вне границ заданного прямоугольника.

GetEraseResult(IEnumerable<Point>, StylusShape)

Возвращает сегменты текущего Stroke после его рассечения заданным путем с использованием указанной StylusShape.

GetEraseResult(IEnumerable<Point>)

Возвращает сегменты текущего Stroke, которые находятся в заданных границах.

public:
 System::Windows::Ink::StrokeCollection ^ GetEraseResult(System::Collections::Generic::IEnumerable<System::Windows::Point> ^ lassoPoints);
public System.Windows.Ink.StrokeCollection GetEraseResult (System.Collections.Generic.IEnumerable<System.Windows.Point> lassoPoints);
member this.GetEraseResult : seq<System.Windows.Point> -> System.Windows.Ink.StrokeCollection
Public Function GetEraseResult (lassoPoints As IEnumerable(Of Point)) As StrokeCollection

Параметры

lassoPoints
IEnumerable<Point>

Массив типа Point, определяющий область, которую необходимо стереть.

Возвращаемое значение

StrokeCollection, содержащая сегменты текущего Stroke, находящиеся вне заданных границ.

Примеры

В следующем примере удаляется рукописный ввод в пределах указанных границ.

Point[] myPoints = new Point[] {
    new Point(100, 100),
    new Point(200, 100),
    new Point(200, 200),
    new Point(100, 200)};

StrokeCollection eraseResults = aStroke.GetEraseResult(myPoints);

// inkCanvas1 is the InkCanvas on which we update the strokes
inkCanvas1.Strokes.Remove(aStroke);
inkCanvas1.Strokes.Add(eraseResults);
Dim myPoints() As System.Windows.Point = _
              {New System.Windows.Point(100, 100), _
               New System.Windows.Point(200, 100), _
               New System.Windows.Point(200, 200), _
               New System.Windows.Point(100, 200)}

Dim eraseResults As StrokeCollection = aStroke.GetEraseResult(myPoints)

' inkCanvas1 is the InkCanvas on which we update the strokes
inkCanvas1.Strokes.Remove(aStroke)
inkCanvas1.Strokes.Add(eraseResults)

Комментарии

Метод GetEraseResult возвращает объект , StrokeCollection содержащий штрихи, представляющие сегменты объекта , Stroke которые находятся за пределами lassoPoints. GetEraseResult не изменяет исходный Stroke.

GetClipResult Метод подключается в первый и последний точки в lassoPoints для создания лассо.

Применяется к

GetEraseResult(Rect)

Возвращает сегменты текущего Stroke, которые находятся вне границ заданного прямоугольника.

public:
 System::Windows::Ink::StrokeCollection ^ GetEraseResult(System::Windows::Rect bounds);
public System.Windows.Ink.StrokeCollection GetEraseResult (System.Windows.Rect bounds);
member this.GetEraseResult : System.Windows.Rect -> System.Windows.Ink.StrokeCollection
Public Function GetEraseResult (bounds As Rect) As StrokeCollection

Параметры

bounds
Rect

Rect, задающий область, в которой выполняется удаление.

Возвращаемое значение

StrokeCollection, содержащая сегменты текущего Stroke, которые находятся вне определяемых Rect границ.

Примеры

В следующем примере удаляется рукописный ввод в пределах указанных границ.

Rect myRect = new Rect(100, 100, 100, 100);

StrokeCollection eraseResults = aStroke.GetEraseResult(myRect);

// inkCanvas1 is the InkCanvas on which we update the strokes
inkCanvas1.Strokes.Remove(aStroke);
inkCanvas1.Strokes.Add(eraseResults);
Dim myRect As New Rect(100, 100, 100, 100)

Dim eraseResults As StrokeCollection = aStroke.GetEraseResult(myRect)

' inkCanvas1 is the InkCanvas on which we update the strokes
inkCanvas1.Strokes.Remove(aStroke)
inkCanvas1.Strokes.Add(eraseResults)

Комментарии

Метод GetEraseResult возвращает объект , StrokeCollection содержащий штрихи, представляющие сегменты объекта , Stroke которые находятся за пределами bounds. GetEraseResult не изменяет исходный Stroke.

Применяется к

GetEraseResult(IEnumerable<Point>, StylusShape)

Возвращает сегменты текущего Stroke после его рассечения заданным путем с использованием указанной StylusShape.

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

Параметры

eraserPath
IEnumerable<Point>

Массив типа Point, определяющий путь, который рассекает Stroke.

eraserShape
StylusShape

StylusShape, определяющий форму ластика.

Возвращаемое значение

StrokeCollection, содержащая копии сегментов текущего Stroke после его рассечения заданным путем.

Примеры

В следующем примере показано, как удалить рукописный фрагмент, пересекающий указанный путь.

Point[] myPoints = new Point[] {
    new Point(100, 100),
    new	Point(200, 100),
    new	Point(200, 200),
    new	Point(100, 200)};

EllipseStylusShape myStylus = new EllipseStylusShape(5.0, 5.0, 0.0);

StrokeCollection eraseResults = aStroke.GetEraseResult(myPoints, myStylus);

// inkCanvas1 is the InkCanvas on which we update the strokes
inkCanvas1.Strokes.Remove(aStroke);
inkCanvas1.Strokes.Add(eraseResults);
Dim myPoints() As System.Windows.Point = _
                      {New System.Windows.Point(100, 100), _
                       New System.Windows.Point(200, 100), _
                       New System.Windows.Point(200, 200), _
                       New System.Windows.Point(100, 200)}

Dim myStylus As New EllipseStylusShape(5.0, 5.0, 0.0)

Dim eraseResults As StrokeCollection = aStroke.GetEraseResult(myPoints, myStylus)

' inkCanvas1 is the InkCanvas on which we update the strokes
inkCanvas1.Strokes.Remove(aStroke)
inkCanvas1.Strokes.Add(eraseResults)

Комментарии

Метод GetEraseResult использует для eraserShape проверки удара вдоль eraserPath и возвращает StrokeCollection объект , представляющий рассеченные сегменты. GetEraseResult не изменяет исходный Stroke.

Применяется к