Partilhar via


StreamGeometryContext.BezierTo(Point, Point, Point, Boolean, Boolean) Método

Definição

Desenha uma curva de Bézier para o ponto especificado.

public:
 abstract void BezierTo(System::Windows::Point point1, System::Windows::Point point2, System::Windows::Point point3, bool isStroked, bool isSmoothJoin);
public abstract void BezierTo (System.Windows.Point point1, System.Windows.Point point2, System.Windows.Point point3, bool isStroked, bool isSmoothJoin);
abstract member BezierTo : System.Windows.Point * System.Windows.Point * System.Windows.Point * bool * bool -> unit
Public MustOverride Sub BezierTo (point1 As Point, point2 As Point, point3 As Point, isStroked As Boolean, isSmoothJoin As Boolean)

Parâmetros

point1
Point

O primeiro ponto de controle usado para especificar a forma da curva.

point2
Point

O segundo ponto de controle usado para especificar a forma da curva.

point3
Point

O ponto de destino do final da curva.

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 uma curva de Bezier usando o BezierTo método.

using System;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Media;
using System.Windows.Shapes;

namespace SDKSample
{
    public partial class StreamGeometryBezierToExample : Page
    {
        public StreamGeometryBezierToExample()
        {

            // 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 Bezier curve using the 3 specifed points where the first two points
                // are control points and the last point is the destination point for the curve.
                ctx.BezierTo(new Point(100, 0), new Point(200,200), new Point(300,100), 
                             true /* is stroked */, false /* is smooth join */);
            }

            // Create a path to draw a geometry with.
            Path myPath = new Path();
            myPath.Stroke = Brushes.Black;
            myPath.StrokeThickness = 1;

            // Freeze the geometry (make it unmodifiable)
            // for additional performance benefits.
            geometry.Freeze();

            // specify the shape (Bezier 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

Namespace SDKSample
    Partial Public Class StreamGeometryBezierToExample
        Inherits Page
        Public Sub New()

            ' 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 Bezier curve using the 3 specifed points where the first two points
                ' are control points and the last point is the destination point for the curve.
                ctx.BezierTo(New Point(100, 0), New Point(200,200), New Point(300,100), True, False) ' is smooth join  -  is stroked 

            End Using

            ' Create a path to draw a geometry with.
            Dim myPath As New Path()
            myPath.Stroke = Brushes.Black
            myPath.StrokeThickness = 1

            ' Freeze the geometry (make it unmodifiable)
            ' for additional performance benefits.
            geometry.Freeze()

            ' specify the shape (Bezier 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

Uma curva bezier cúbica é definida por um ponto de partida, ponto de extremidade e dois pontos de controle. O primeiro ponto de controle determina a curvatura da primeira metade do segmento e o segundo ponto de controle determina a curvatura da segunda metade do segmento.

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.

Aplica-se a

Confira também