1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef UI_GFX_ANIMATION_SLIDE_ANIMATION_H_
6 #define UI_GFX_ANIMATION_SLIDE_ANIMATION_H_
8 #include "ui/gfx/animation/linear_animation.h"
9 #include "ui/gfx/animation/tween.h"
15 // Used for reversible animations and as a general helper class. Typical usage:
17 // #include "ui/gfx/animation/slide_animation.h"
19 // class MyClass : public AnimationDelegate {
22 // animation_.reset(new SlideAnimation(this));
23 // animation_->SetSlideDuration(500);
25 // void OnMouseOver() {
26 // animation_->Show();
28 // void OnMouseOut() {
29 // animation_->Hide();
31 // void AnimationProgressed(const Animation* animation) {
32 // if (animation == animation_.get()) {
35 // } else if (animation == other_animation_.get()) {
40 // if (animation_->is_animating()) {
41 // hover_image_.SetOpacity(animation_->GetCurrentValue());
45 // scoped_ptr<SlideAnimation> animation_;
47 class GFX_EXPORT SlideAnimation
: public LinearAnimation
{
49 explicit SlideAnimation(AnimationDelegate
* target
);
50 ~SlideAnimation() override
;
52 // Set the animation back to the 0 state.
54 virtual void Reset(double value
);
56 // Begin a showing animation or reverse a hiding animation in progress.
59 // Begin a hiding animation or reverse a showing animation in progress.
62 // Sets the time a slide will take. Note that this isn't actually
63 // the amount of time an animation will take as the current value of
64 // the slide is considered.
65 virtual void SetSlideDuration(int duration
);
66 int GetSlideDuration() const { return slide_duration_
; }
67 void SetTweenType(Tween::Type tween_type
) { tween_type_
= tween_type
; }
69 double GetCurrentValue() const override
;
70 bool IsShowing() const { return showing_
; }
71 bool IsClosing() const { return !showing_
&& value_end_
< value_current_
; }
76 // Overridden from Animation.
77 void AnimateToState(double state
) override
;
79 AnimationDelegate
* target_
;
81 Tween::Type tween_type_
;
83 // Used to determine which way the animation is going.
86 // Animation values. These are a layer on top of Animation::state_ to
87 // provide the reversability.
90 double value_current_
;
92 // How long a hover in/out animation will last for. This defaults to
93 // kHoverFadeDurationMS, but can be overridden with SetDuration.
96 DISALLOW_COPY_AND_ASSIGN(SlideAnimation
);
101 #endif // UI_GFX_ANIMATION_SLIDE_ANIMATION_H_