Stroke.GetGeometry Metoda

Definicja

Geometry Pobiera bieżący Strokeelement .

Przeciążenia

GetGeometry()

Geometry Pobiera bieżący Strokeelement .

GetGeometry(DrawingAttributes)

Geometry Pobiera bieżącą Stroke wartość przy użyciu określonego DrawingAttributeselementu .

GetGeometry()

Geometry Pobiera bieżący Strokeelement .

public:
 System::Windows::Media::Geometry ^ GetGeometry();
public System.Windows.Media.Geometry GetGeometry ();
member this.GetGeometry : unit -> System.Windows.Media.Geometry
Public Function GetGeometry () As Geometry

Zwraca

Element Geometry reprezentujący element Stroke.

Uwagi

GetGeometry Użyj metody , aby uzyskać element , PathGeometry aby dostosować kształt obiektu Stroke. Rozważ buforowanie elementu Geometry , aby uniknąć wielokrotnego wywoływania GetGeometry , co może mieć wpływ na wydajność.

Dotyczy

GetGeometry(DrawingAttributes)

Geometry Pobiera bieżącą Stroke wartość przy użyciu określonego DrawingAttributeselementu .

public:
 System::Windows::Media::Geometry ^ GetGeometry(System::Windows::Ink::DrawingAttributes ^ drawingAttributes);
public System.Windows.Media.Geometry GetGeometry (System.Windows.Ink.DrawingAttributes drawingAttributes);
member this.GetGeometry : System.Windows.Ink.DrawingAttributes -> System.Windows.Media.Geometry
Public Function GetGeometry (drawingAttributes As DrawingAttributes) As Geometry

Parametry

drawingAttributes
DrawingAttributes

Element DrawingAttributes określający Geometry element Stroke.

Zwraca

Element Geometry reprezentujący element Stroke.

Przykłady

W poniższym przykładzie pokazano, jak narysować okrąg na każdym StylusPoint z elementów Stroke. Jeśli właściwość jest ustawiona FitToCurve na true, GetBezierStylusPoints jest używana do uzyskiwania punktów stylus. StylusPoints W przeciwnym razie właściwość jest używana.

protected override void DrawCore(DrawingContext context, DrawingAttributes overrides)
{
    // Draw the stroke. Calling base.DrawCore accomplishes the same thing.
    Geometry geometry = GetGeometry(overrides);
    context.DrawGeometry(new SolidColorBrush(overrides.Color), null, geometry);

    StylusPointCollection points;

    // Get the stylus points used to draw the stroke.  The points used depends on
    // the value of FitToCurve.
    if (this.DrawingAttributes.FitToCurve)
    {
        points = this.GetBezierStylusPoints();
    }
    else
    {
        points = this.StylusPoints;
    }

    // Draw a circle at each stylus point.
    foreach (StylusPoint p in points)
    {
        context.DrawEllipse(null, new Pen(Brushes.Black, 1), (Point)p, 5, 5);
    }
}
Protected Overrides Sub DrawCore(ByVal context As DrawingContext, _
        ByVal overridedAttributes As DrawingAttributes)

    ' Draw the stroke. Calling base.DrawCore accomplishes the same thing.
    Dim geometry As Geometry = GetGeometry(overridedAttributes)
    context.DrawGeometry(New SolidColorBrush(overridedAttributes.Color), Nothing, geometry)

    Dim points As StylusPointCollection

    ' Get the stylus points used to draw the stroke.  The points used depends on
    ' the value of FitToCurve.
    If Me.DrawingAttributes.FitToCurve Then
        points = Me.GetBezierStylusPoints()
    Else
        points = Me.StylusPoints
    End If

    ' Draw a circle at each stylus point.
    Dim p As StylusPoint
    For Each p In points
        context.DrawEllipse(Nothing, New Pen(Brushes.Black, 1), CType(p, Point), 5, 5)
    Next p

End Sub

Uwagi

Metoda GetGeometry używa Widthwłaściwości , Height, StylusTipFitToCurvei StylusTipTransform , drawingAttributes w celu określenia Geometrywartości . Rozważ buforowanie elementu Geometry , aby uniknąć wielokrotnego wywoływania GetGeometry , co może mieć wpływ na wydajność.

Dotyczy