Stroke.GetGeometry Metoda
Definicja
Ważne
Niektóre informacje odnoszą się do produktu w wersji wstępnej, który może zostać znacząco zmodyfikowany przed wydaniem. Firma Microsoft nie udziela żadnych gwarancji, jawnych lub domniemanych, w odniesieniu do informacji podanych w tym miejscu.
Przeciążenia
GetGeometry() | |
GetGeometry(DrawingAttributes) |
Geometry Pobiera bieżącą Stroke wartość przy użyciu określonego DrawingAttributeselementu . |
GetGeometry()
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ść.