silverlight中 Storyboard(动画)的使用,实现球的上下循环移动,左右移动,及旋转功能

  话说,总结应该是个收获的心情,可现在的自己似乎没感觉到哪个喜悦的心情,说明自己做得还不够好,现在还是把一些做好的东西总结下。“总结”是学习,工作中必须的,不能偷这个懒 o(╯□╰)o

实现上下循环移动的关键代码是:

  首先创建一个计时器

            rollTimer = new DispatcherTimer();

            rollTimer.Interval = TimeSpan.FromMilliseconds(1000);

            rollTimer.Tick += new EventHandler(rollTimer_Tick);

            rollTimer.Start();

   此计时器设置的间隔期是1秒 也就是说1秒后会触发此事件rollTimer_Tick,然后我在此事件中,让球从上往下移动(用时0.5秒),然后此动画(故事板Storyboard)结束后,触发另一个事件(这个事件的控制是,让球从下往上移动,用时0.5秒),这样在这1秒中,球就实现了,上下循环移动。然后计时器的控制,可隔1秒后触发rollTimer_Tick事件,也就是说能让它循环。到一定的时间,将计时器停止就可将该事件停止。

  rollTimer_Tick中的关键代码为:

 public void rollTimer_Tick(object sender,EventArgs e)

        {

            DoubleAnimation da = new DoubleAnimation();

            da.From = 55;

            da.To = 65;

            da.Duration = new Duration(TimeSpan.FromSeconds(0.5));

            Storyboard.SetTarget(da, ellipse);

            sbd.Completed += new EventHandler(sbd_Completed);

            sbd.FillBehavior = FillBehavior.HoldEnd;

            sbd.Children.Add(da);

            sbd.Begin();

        }

 

  故事板结束后触发的事件sbd_Completed为:

  #region 下半部分,使其由下往上移动

        private void sbd_Completed(object sender, EventArgs e)

        {

            if (i == 10)

            {

                rollTimer.Stop();

                NumTimer.Stop();

            }

            else

            {

                sbd.Stop();

                sbd.Children.Clear();

                DoubleAnimation da = new DoubleAnimation();

                da.From = 65;

                da.To = 55;

                da.Duration = new Duration(TimeSpan.FromSeconds(0.5));

                Storyboard.SetTarget(da, ellipse);



                Storyboard.SetTargetProperty(da, new PropertyPath(Canvas.TopProperty));

                sbd.FillBehavior = FillBehavior.HoldEnd;

                sbd.Children.Add(da);

                sbd.Children.Add(da11);

                sbd.Begin();

            }

        }

实现左右移动的关键代码是:

 能实现上下移动,左右移动也就同理了,只要改变一下  Storyboard.SetTargetProperty(da11, new PropertyPath(Canvas.TopProperty));  这个代码,让Canvas.TopProperty Canvas.LeftProperty即可。

 

            Storyboard sbd = new Storyboard();

            DoubleAnimation da = new DoubleAnimation();

            da.From = 60;

            da.To = 340;

            da.Duration = new Duration(TimeSpan.FromSeconds(2));

            Storyboard.SetTarget(da, ellipse5);

            Storyboard.SetTargetProperty(da, new PropertyPath (Canvas.LeftProperty));

            sbd.Children.Add(da);

 

实现旋转的关键代码是:
 首先看下我xaml的布局,对球是这样设计的

<Ellipse x:Name="ellipse5" Canvas.Top="60" Canvas.Left="340" Width="55" Height="55"  Stroke="Black" StrokeThickness="1" >

                    <Ellipse.Fill>

                        <LinearGradientBrush StartPoint="0,0" EndPoint="0,1">

                            <GradientStop Offset="0" Color="#E2E0C8"   />

                            <GradientStop Offset="1" Color="#FFFF00"  />

                            <GradientStop Offset="0.4" Color="#978B00"/>

                            <GradientStop Offset="0.6" Color="#686001"/>

                            <GradientStop Offset="0.8" Color="#978B00"/>

                        </LinearGradientBrush>

                    </Ellipse.Fill>

                    <Ellipse.RenderTransform>

                        <RotateTransform Angle="0" CenterX="25" CenterY="25"></RotateTransform>

                    </Ellipse.RenderTransform>

                </Ellipse>

这一行代码 <RotateTransform Angle="0" CenterX="25" CenterY="25"></RotateTransform> 是设置球的旋转中心,旋转中心的设置为 CenterX=25,CenterY=25 而这个的设置又是球的Width="55" Height="55",照理来说应该是其一半,所以其实25是有点不精确的 \(^o^)/~

后台控制其旋转的代码为:

 

            DoubleAnimation da11 = new DoubleAnimation();

            da11.From = 0;

            da11.To = 360;

            da11.Duration = new Duration(TimeSpan.FromSeconds(2));

            Storyboard.SetTarget(da11, ellipse5);

            Storyboard.SetTargetProperty(da11, new PropertyPath("(Ellipse.RenderTransform).(RotateTransform.Angle)"));

 

注意不同的点: From=0,To=360  和 Storyboard.SetTargetProperty(da11, new PropertyPath("(Ellipse.RenderTransform).(RotateTransform.Angle)")); 这样也就控制了其角度从0度旋转到360度,看起来也就像是圆的旋转咯。

最后效果图:

 

虽然看不出动画效果,嗯,我是想纪念下我实现了我想要的效果,O(∩_∩)O哈哈~

你可能感兴趣的:(silverlight)