如何在保持起点不变的情况下围绕直线旋转直线的终点。在WPF中

时间:2018-12-31 12:10:22

标签: wpf animation graphics

我正在尝试使直线的(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 :(得分:1)

使用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>