Daren Thomas
Daren Thomas

Reputation: 70314

How to stop an animation in C# / WPF?

I have something like this:

barProgress.BeginAnimation(RangeBase.ValueProperty, new DoubleAnimation(
    barProgress.Value, dNextProgressValue,
    new Duration(TimeSpan.FromSeconds(dDuration)));

Now, how would you stop that animation (the DoubleAnimation)? The reason I want to do this, is because I would like to start new animations (this seems to work, but it's hard to tell) and eventually stop the last animation...

Upvotes: 54

Views: 70484

Answers (8)

TheSmurf
TheSmurf

Reputation: 15568

To stop it, call BeginAnimation again with the second argument set to null.

Upvotes: 93

Fawaz
Fawaz

Reputation: 3560

<Trigger.EnterActions>
       <BeginStoryboard x:Name="myStory">
       .........
       </BeginStoryboard>
</Trigger.EnterActions>
<Trigger.ExitActions>
       <StopStoryboard BeginStoryboardName="myStory"/>
</Trigger.ExitActions>

Upvotes: 11

user3837
user3837

Reputation: 2276

When using storyboards to control an animation, make sure you set the second parameter to true in order to set the animation as controllable:

public void Begin(
    FrameworkContentElement containingObject,
    **bool isControllable**
)

Upvotes: 36

oliver
oliver

Reputation: 362

You can use this code:

[StoryBoardName].Remove([StoryBoardOwnerControl]);

Upvotes: 0

BruceLH
BruceLH

Reputation: 321

There are two ways to stop a BeginAnimation. The first is to call BeginAnimation again with the second parameter set to null. This will remove all animations on the property and revert the value back to its base value.

Depending on how you are using that value this may not be the behavior you want. The second way is to set the animations BeginTime to null then call BeginAnimation with it. This will remove that specific animation and leave the value at its current position.

DoubleAnimation myAnimation = new Animation();
// Initialize animation
...

// To start
element.BeginAnimation(Property, myAnimation);

// To stop and keep the current value of the animated property
myAnimation.BeginTime = null;
element.BeginAnimation(Property, myAnimation);

Upvotes: 18

Junior Mayhe
Junior Mayhe

Reputation: 16401

In my case I had to use two commands, my xaml has a button which fires a trigger, and its trigger fires the storyboard animation.

I've put a button to stop animation with this code behind:

MyBeginStoryboard.Storyboard.Begin(this, true);
MyBeginStoryboard.Storyboard.Stop(this);

I don't like it but it really works here. Give it a try!

Upvotes: 9

Nick
Nick

Reputation: 2575

If you want the base value to become the effective value again, you must stop the animation from influencing the property. There are three ways to do this with storyboard animations:

  • Set the animation's FillBehavior property to Stop
  • Remove the entire Storyboard
  • Remove the animation from the individual property

From MSDN

How to: Set a Property After Animating It with a Storyboard

Upvotes: 8

Brian Leahy
Brian Leahy

Reputation: 35507

Place the animation in a StoryBoard. Call Begin() and Stop() on the storyboard to start to stop the animations.

Upvotes: 4

Related Questions