Stroke.GetGeometry Método
Definición
Importante
Parte de la información hace referencia a la versión preliminar del producto, que puede haberse modificado sustancialmente antes de lanzar la versión definitiva. Microsoft no otorga ninguna garantía, explícita o implícita, con respecto a la información proporcionada aquí.
Sobrecargas
| Nombre | Description |
|---|---|
| GetGeometry() | |
| GetGeometry(DrawingAttributes) |
Obtiene el Geometry del objeto actual Stroke mediante el especificado DrawingAttributes. |
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
Devoluciones
que Geometry representa el Strokeobjeto .
Comentarios
Use el GetGeometry método para obtener un PathGeometry para personalizar la forma de .Stroke Considere la posibilidad de almacenar en caché el Geometry para evitar llamar a GetGeometry varias veces, lo que puede afectar al rendimiento.
Se aplica a
GetGeometry(DrawingAttributes)
Obtiene el Geometry del objeto actual Stroke mediante el especificado DrawingAttributes.
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
Parámetros
- drawingAttributes
- DrawingAttributes
DrawingAttributes que determina el Geometry de .Stroke
Devoluciones
que Geometry representa el Strokeobjeto .
Ejemplos
En el ejemplo siguiente se muestra cómo dibujar un círculo en cada StylusPoint uno de los Strokeelementos . Si la FitToCurve propiedad se establece trueen , GetBezierStylusPoints se usa para obtener los puntos del lápiz óptico. De lo contrario, se usa la StylusPoints propiedad .
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
Comentarios
El GetGeometry método usa las Widthpropiedades , Height, FitToCurvey StylusTipTransformStylusTip de drawingAttributes para determinar .Geometry Considere la posibilidad de almacenar en caché el Geometry para evitar llamar a GetGeometry varias veces, lo que puede afectar al rendimiento.