如何在动画完成后删除动画

时间:2016-07-25 09:14:19

标签: c# wpf animation

我想从目标属性中删除动画,因为我是Unable to set the property after its animation

所以,根据上面问题的answer,我要在动画完成后删除动画。但是怎么做

这是我的代码:

public class GridLengthAnimation : AnimationTimeline {

    static GridLengthAnimation() {
        FromProperty = DependencyProperty.Register("From", typeof(GridLength), typeof(GridLengthAnimation));
        ToProperty = DependencyProperty.Register("To", typeof(GridLength), typeof(GridLengthAnimation));
    }

    public override Type TargetPropertyType {
        get { return typeof(GridLength); }
    }

    protected override Freezable CreateInstanceCore() {
        return new GridLengthAnimation();
    }

    public ContentElement Target { get; set; }

    public static readonly DependencyProperty FromProperty;
    public GridLength From {
        get { return (GridLength) GetValue(FromProperty); }
        set { SetValue(FromProperty, value); }
    }

    public static readonly DependencyProperty ToProperty;
    public GridLength To {
        get { return (GridLength) GetValue(ToProperty); }
        set { SetValue(ToProperty, value); }
    }

    public void BeginAnimation() {
        Target.BeginAnimation(ColumnDefinition.WidthProperty, null);
        Target.BeginAnimation(ColumnDefinition.WidthProperty, this);
    }

    public IEasingFunction EasingFunction { get; set; } = new CubicEase() { EasingMode = EasingMode.EaseInOut };

    public override object GetCurrentValue(object defaultOriginValue, object defaultDestinationValue, AnimationClock animationClock) {
        double fromValue = ((GridLength) GetValue(FromProperty)).Value;
        double toValue = ((GridLength) GetValue(ToProperty)).Value;
        double newValue = 0;

        if ((fromValue > toValue)) {
            newValue = (1 - EasingFunction.Ease(animationClock.CurrentProgress.Value)) * (fromValue - toValue) + toValue;
            return new GridLength(newValue, GridUnitType.Star);
        } else {
            newValue = EasingFunction.Ease(animationClock.CurrentProgress.Value) * (toValue - fromValue) + fromValue;
            return new GridLength(newValue, GridUnitType.Star);
        }
    }
}

要开始动画,我会在MainWindows.xaml.cs文件中这样做:

GridLengthAnimation gridAnim = new GridLengthAnimation() {
    Name = "gridAnim",
    Target = mainGrid.ColumnDefinitions[1],
    Duration = new Duration(TimeSpan.FromMilliseconds(1000))
};

gridAnim.From = new GridLength(1, GridUnitType.Star);
gridAnim.To = new GridLength(0, GridUnitType.Star);

gridAnim.BeginAnimation();

完成后我可以在哪里删除动画?

2 个答案:

答案 0 :(得分:1)

只需将您的使用情况更改为:

    GridLengthAnimation gridAnim = new GridLengthAnimation() {
            Name = "gridAnim",
            Target = this.MainGrid.ColumnDefinitions[1],
            Duration = new Duration(TimeSpan.FromMilliseconds(1000))
          };

          gridAnim.From = new GridLength(1, GridUnitType.Star);
          gridAnim.To = new GridLength(0, GridUnitType.Star);
//Cleanup on Complete
          gridAnim.Completed += (sender, args) => {
                                                    var xx = sender as AnimationClock;
                                                    (xx.Timeline as GridLengthAnimation).Target = null;
          };
          gridAnim.BeginAnimation();

答案 1 :(得分:0)

我找到了我的解决方案here,在" 从单个属性移除动画"一部分。

我在GridLengthAnimation

中添加了此内容
public void BeginAnimation() {
    Completed += GridLengthAnimation_Completed;
    Target.BeginAnimation(ColumnDefinition.WidthProperty, null);
    Target.BeginAnimation(ColumnDefinition.WidthProperty, this);
}

private void GridLengthAnimation_Completed(object sender, EventArgs e) {
    //unlocks the property
    Target.BeginAnimation(ColumnDefinition.WidthProperty, null);

    //holds the value at the end
    ((ColumnDefinition) Target).Width = new GridLength(((GridLength) GetValue(ToProperty)).Value, GridUnitType.Star);
}