StreamGeometryContext.PolyQuadraticBezierTo Método
Definição
Importante
Algumas informações se referem a produtos de pré-lançamento que podem ser substancialmente modificados antes do lançamento. A Microsoft não oferece garantias, expressas ou implícitas, das informações aqui fornecidas.
Desenha uma ou mais curvas de Bézier quadráticas.
public:
abstract void PolyQuadraticBezierTo(System::Collections::Generic::IList<System::Windows::Point> ^ points, bool isStroked, bool isSmoothJoin);
public abstract void PolyQuadraticBezierTo (System.Collections.Generic.IList<System.Windows.Point> points, bool isStroked, bool isSmoothJoin);
abstract member PolyQuadraticBezierTo : System.Collections.Generic.IList<System.Windows.Point> * bool * bool -> unit
Public MustOverride Sub PolyQuadraticBezierTo (points As IList(Of Point), isStroked As Boolean, isSmoothJoin As Boolean)
Parâmetros
A coleção de pontos que especificam os pontos de controle e os pontos de destino para uma ou mais curvas de Bézier quadráticas. O primeiro ponto na lista especifica o ponto de controle da curva, o próximo ponto especifica o ponto de destino, o próximo ponto especifica o ponto de controle da próxima curva e assim por diante. A lista deve conter um número impar de pontos.
- isStroked
- Boolean
true
para deixar o segmento tracejado quando uma Pen for usada para renderizar o segmento, caso contrário, false
.
- isSmoothJoin
- Boolean
true
para tratar a junção entre esse segmento e o segmento anterior como um canto quando traçados com um Pen; caso contrário, false
.
Exceções
Foi feita uma tentativa para adicionar um segmento sem iniciar uma figura ao chamar o método BeginFigure(Point, Boolean, Boolean).
Exemplos
O exemplo a seguir mostra como desenhar várias curvas de Bezier quadráticas conectadas usando o PolyQuadraticBezierTo método.
using System;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Media;
using System.Windows.Shapes;
using System.Collections.Generic;
namespace SDKSample
{
public partial class StreamGeometryPolyQuadraticBezierToExample : Page
{
public StreamGeometryPolyQuadraticBezierToExample()
{
// Create a path to draw a geometry with.
Path myPath = new Path();
myPath.Stroke = Brushes.Black;
myPath.StrokeThickness = 1;
// Create a StreamGeometry to use to specify myPath.
StreamGeometry geometry = new StreamGeometry();
geometry.FillRule = FillRule.EvenOdd;
// Open a StreamGeometryContext that can be used to describe this StreamGeometry object's contents.
using (StreamGeometryContext ctx = geometry.Open())
{
// Set the begin point of the shape.
ctx.BeginFigure(new Point(10, 100), true /* is filled */, false /* is closed */);
// Create a collection of Point structures that will be used with the PolyQuadraticBezierTo
// Method to create two quadratic Bezier curves.
List<Point> pointList = new List<Point>();
// First quadratic Bezier curve is specified with these two points.
// Control point for first quadratic Bezier curve.
pointList.Add(new Point(100, 0));
// End point for first quadratic Bezier curve.
pointList.Add(new Point(200, 200));
// Second quadratic Bezier curve is specified with these two points.
// Control point for second quadratic Bezier curve.
pointList.Add(new Point(300, 300));
// End point for second quadratic Bezier curve.
pointList.Add(new Point(400, 100));
// Create a Bezier curve using the collection of Point Structures.
ctx.PolyQuadraticBezierTo(pointList, true /* is stroked */, false /* is smooth join */);
}
// Freeze the geometry (make it unmodifiable)
// for additional performance benefits.
geometry.Freeze();
// specify the shape (quadratic Benzier curve) of the path using the StreamGeometry.
myPath.Data = geometry;
// Add path shape to the UI.
StackPanel mainPanel = new StackPanel();
mainPanel.Children.Add(myPath);
this.Content = mainPanel;
}
}
}
Imports System.Windows
Imports System.Windows.Controls
Imports System.Windows.Media
Imports System.Windows.Shapes
Imports System.Collections.Generic
Namespace SDKSample
Partial Public Class StreamGeometryPolyQuadraticBezierToExample
Inherits Page
Public Sub New()
' Create a path to draw a geometry with.
Dim myPath As New Path()
myPath.Stroke = Brushes.Black
myPath.StrokeThickness = 1
' Create a StreamGeometry to use to specify myPath.
Dim geometry As New StreamGeometry()
geometry.FillRule = FillRule.EvenOdd
' Open a StreamGeometryContext that can be used to describe this StreamGeometry object's contents.
Using ctx As StreamGeometryContext = geometry.Open()
' Set the begin point of the shape.
ctx.BeginFigure(New Point(10, 100), True, False) ' is closed - is filled
' Create a collection of Point structures that will be used with the PolyQuadraticBezierTo
' Method to create two quadratic Bezier curves.
Dim pointList As New List(Of Point)()
' First quadratic Bezier curve is specified with these two points.
' Control point for first quadratic Bezier curve.
pointList.Add(New Point(100, 0))
' End point for first quadratic Bezier curve.
pointList.Add(New Point(200, 200))
' Second quadratic Bezier curve is specified with these two points.
' Control point for second quadratic Bezier curve.
pointList.Add(New Point(300, 300))
' End point for second quadratic Bezier curve.
pointList.Add(New Point(400, 100))
' Create a Bezier curve using the collection of Point Structures.
ctx.PolyQuadraticBezierTo(pointList, True, False) ' is smooth join - is stroked
End Using
' Freeze the geometry (make it unmodifiable)
' for additional performance benefits.
geometry.Freeze()
' specify the shape (quadratic Benzier curve) of the path using the StreamGeometry.
myPath.Data = geometry
' Add path shape to the UI.
Dim mainPanel As New StackPanel()
mainPanel.Children.Add(myPath)
Me.Content = mainPanel
End Sub
End Class
End Namespace
Comentários
Esse método usa o ponto de extremidade do segmento anterior como ponto de partida. Se esse for o primeiro segmento de uma figura, ele usará o ponto especificado pelo BeginFigure método como seu ponto de partida.
Não StreamGeometry será possível serializar se ele contiver um Transform ou qualquer segmento não acarinhado ou não preenchido.