OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 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 | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "ui/gfx/compositor/scoped_layer_animation_settings.h" | 5 #include "ui/gfx/compositor/scoped_layer_animation_settings.h" |
6 | 6 |
7 #include "ui/gfx/compositor/layer_animation_observer.h" | 7 #include "ui/gfx/compositor/layer_animation_observer.h" |
8 #include "ui/gfx/compositor/layer_animator.h" | 8 #include "ui/gfx/compositor/layer_animator.h" |
9 | 9 |
10 namespace { | 10 namespace { |
11 | 11 |
12 static const base::TimeDelta kDefaultTransitionDuration = | 12 static const base::TimeDelta kDefaultTransitionDuration = |
13 base::TimeDelta::FromMilliseconds(200); | 13 base::TimeDelta::FromMilliseconds(200); |
14 | 14 |
15 } // namespace; | 15 } // namespace; |
16 | 16 |
17 namespace ui { | 17 namespace ui { |
18 | 18 |
19 ScopedLayerAnimationSettings::ScopedLayerAnimationSettings( | 19 ScopedLayerAnimationSettings::ScopedLayerAnimationSettings( |
20 LayerAnimator* animator) | 20 LayerAnimator* animator) |
21 : animator_(animator), | 21 : animator_(animator), |
22 old_transition_duration_(animator->transition_duration_) { | 22 old_transition_duration_(animator->transition_duration_) { |
23 SetTransitionDuration(kDefaultTransitionDuration); | 23 SetTransitionDuration(kDefaultTransitionDuration); |
24 } | 24 } |
25 | 25 |
26 ScopedLayerAnimationSettings::~ScopedLayerAnimationSettings() { | 26 ScopedLayerAnimationSettings::~ScopedLayerAnimationSettings() { |
27 animator_->transition_duration_ = old_transition_duration_; | 27 animator_->transition_duration_ = old_transition_duration_; |
28 | 28 |
29 for (std::set<LayerAnimationObserver*>::const_iterator i = | |
30 observers_.begin(); i != observers_.end(); ++i) | |
31 animator_->observers_.RemoveObserver(*i); | |
32 | |
33 for (std::set<ImplicitAnimationObserver*>::const_iterator i = | 29 for (std::set<ImplicitAnimationObserver*>::const_iterator i = |
34 implicit_observers_.begin(); i != implicit_observers_.end(); ++i) | 30 observers_.begin(); i != observers_.end(); ++i) { |
35 (*i)->SetActive(true); | 31 animator_->observers_.RemoveObserver(*i); |
| 32 (*i)->SetActive(true); |
| 33 } |
36 } | 34 } |
37 | 35 |
38 void ScopedLayerAnimationSettings::AddObserver( | 36 void ScopedLayerAnimationSettings::AddObserver( |
39 LayerAnimationObserver* observer) { | 37 ImplicitAnimationObserver* observer) { |
40 observers_.insert(observer); | 38 observers_.insert(observer); |
41 animator_->AddObserver(observer); | 39 animator_->AddObserver(observer); |
42 } | 40 } |
43 | 41 |
44 void ScopedLayerAnimationSettings::AddImplicitObserver( | |
45 ImplicitAnimationObserver* observer) { | |
46 implicit_observers_.insert(observer); | |
47 AddObserver(observer); | |
48 } | |
49 | |
50 void ScopedLayerAnimationSettings::SetTransitionDuration( | 42 void ScopedLayerAnimationSettings::SetTransitionDuration( |
51 base::TimeDelta duration) { | 43 base::TimeDelta duration) { |
52 animator_->transition_duration_ = duration; | 44 animator_->transition_duration_ = duration; |
53 } | 45 } |
54 | 46 |
55 } // namespace ui | 47 } // namespace ui |
56 | 48 |
OLD | NEW |