Как вращать конечную точку прямой вокруг круга, сохраняя начальную точку фиксированной.в WPF - PullRequest
0 голосов
/ 31 декабря 2018

Я пытаюсь повернуть конечную точку прямой (lineSweep) вокруг круга, сохраняя начальную точку фиксированной.Это код, который я написал (на примере, приведенном на веб-сайте справки MS).Ничего не происходит.Вы можете помочь мне.

//XAML
<Window x:Class="SPDisplay.MainWindow"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
        xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
        xmlns:local="clr-namespace:SPDisplay"
        mc:Ignorable="d"
        Title="Display" Height="1000" Width="1000">
    <WrapPanel Orientation="Vertical">

        <Canvas Name="sp" Height="500" Width="500">

            <Line Stroke="Black" StrokeThickness="2" Margin="0" Name="lineSweep"
                X1="0" Y1="0" X2="100" Y2="100"/>
        </Canvas>

        <Button Name="btnStartAnimation" Click="btnStartAnimation_Click">Start Animation</Button>
    </WrapPanel>
</Window>

//C#
public void btnStartAnimation_Click(object sender, EventArgs args)
{
    lineSweep.X1 = sp.Width / 2;
    lineSweep.Y1 = sp.Height / 2;
    lineSweep.X2 = sp.Width;
    lineSweep.Y2 = sp.Height / 2;

    // Create the animation path.
    PathGeometry animationPath = new PathGeometry();
    PathFigure pFigure = new PathFigure();
    pFigure.StartPoint = new Point(sp.Width, sp.Height / 2);
    PolyBezierSegment pBezierSegment = new PolyBezierSegment();
    int N = 100;            

    for (int i = 1; i < N; i++)
    {
        pBezierSegment.Points.Add(new Point(sp.Width / 2 * Math.Cos(2 * i * Math.PI / N), sp.Height / 2 * Math.Cos(2 * i * Math.PI / N)));
    }

    pFigure.Segments.Add(pBezierSegment);
    animationPath.Figures.Add(pFigure);

    PointAnimationUsingPath EndPointAnimation =
        new PointAnimationUsingPath();
    EndPointAnimation.PathGeometry = animationPath;
    EndPointAnimation.Duration = TimeSpan.FromSeconds(5);
    EndPointAnimation.RepeatBehavior = RepeatBehavior.Forever;

    animationPath.Freeze();

    Storyboard.SetTargetName(EndPointAnimation, "lineSweep");
    Storyboard.SetTargetProperty(EndPointAnimation,
        new PropertyPath(LineGeometry.EndPointProperty));

    // Create a Storyboard to contain and apply the animation.
    Storyboard pathAnimationStoryboard = new Storyboard();
    pathAnimationStoryboard.RepeatBehavior = RepeatBehavior.Forever;
    pathAnimationStoryboard.AutoReverse = true;
    pathAnimationStoryboard.Children.Add(EndPointAnimation);

    pathAnimationStoryboard.Begin(lineSweep);

}

1 Ответ

0 голосов
/ 31 декабря 2018

Используйте RotateTransform и анимируйте свойство Angle:

<Line Margin="100,100,0,0" X1="0" X2="50" Stroke="Black">
  <Line.RenderTransform>
    <RotateTransform x:Name="LineRotateTransform" CenterX="0" CenterY="0" Angle="90" />
  </Line.RenderTransform>
</Line>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...