wpf storyboard stop

Storyboard BeginStory = (Storyboard)this.FindResource("StarAnimation");
BeginStory.Begin(this,true);
.
.
.
BeginStory.Stop(this);



真麻烦 参数的问题

iscontrolable 中的true少不了 this也少不了,this是做动画的uielement

动画的属性传递信息

doubleAnimation = new DoubleAnimation(line1.Y1, line1.Y2, new System.Windows.Duration(TimeSpan.FromSeconds(secs)))
            {
                AccelerationRatio = 0,
                BeginTime = TimeSpan.FromSeconds(bsecs),
            };
            doubleAnimation.Completed += (sender, e) => { //do complete thing  };
            //这样简单点 但是不知道怎么控制 line1.BeginAnimation(Line.Y1Property, doubleAnimation);
            StoryboardLine1 = new Storyboard();
            //Storyboard.SetTargetProperty(doubleAnimation, new PropertyPath("(UIElement.RenderTransform).(TranslateTransform.Y)"));
            Storyboard.SetTargetProperty(doubleAnimation, new PropertyPath(Line.Y1Property));
            Storyboard.SetTarget(doubleAnimation, this.line1);
            StoryboardLine1.Children.Add(doubleAnimation);
            

以下转载:https://blog.csdn.net/xwlyun/article/details/9156897
在wpf中我们常用storyboard故事板装载很多的动画处理Animation,我们需要用Storyboard.SetTarget设置操作的对象,需要用Storyboard.SetTargetProperty设置操作对象的操作属性PropertyPath,本例将说明一种操作属性PropertyPath的便利方法:

效果:点击button,button的横坐标x由12到300,播放过程动画

			 this.button1.RenderTransform = new TranslateTransform();

            Storyboard sb = new Storyboard();
            DoubleAnimation da = new DoubleAnimation();
            da.From = 12;
            da.To = 300;
            da.Duration = TimeSpan.FromSeconds(3);
            sb.Children.Add(da);

            DependencyProperty[] propertyChain = new DependencyProperty[]
            {
                Button.RenderTransformProperty,
                TranslateTransform.XProperty
            };

            Storyboard.SetTarget(da, this.button1);
            Storyboard.SetTargetProperty(da, new PropertyPath("(0).(1)", propertyChain));

            sb.Completed += new EventHandler((object sender1, EventArgs e1) => { MessageBox.Show("completed"); });
            sb.Begin();


一般我们在写到Storyboard.SetTargetProperty时遇到new PropertyPath,

如果是简单的属性,例如Button.WidthProperty,我们可以直接new PropertyPath(Button.WidthProperty)达到目的,
但如果你发现你需要操作到的属性无法在Button中直接’.'出来,就需要用到上例用到的属性链方法:

首先定义一个属性链:

        DependencyProperty[] propertyChain = new DependencyProperty[]
        {
            Button.RenderTransformProperty,
            TranslateTransform.XProperty
        };

属性链的写法,定义一个DependencyProperty属性的数组,该数组中的元素均是Property属性,且按照从属关系先后排列,例如上例中,我们需要先将button的RenderTransform设置为TranslateTransform,然后通过TranslateTransform的XProperty来更改button的x坐标,

当然,别忘了初始化button的RenderTransform属性= new TranslateTransform(),否则动画将没有效果。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值