OLD | NEW |
1 // Copyright 2017 The Chromium Authors. All rights reserved. | 1 // Copyright 2017 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 #ifndef CHROME_BROWSER_UI_VIEWS_TOOLBAR_APP_MENU_ANIMATION_H_ | 5 #ifndef CHROME_BROWSER_UI_VIEWS_TOOLBAR_APP_MENU_ANIMATION_H_ |
6 #define CHROME_BROWSER_UI_VIEWS_TOOLBAR_APP_MENU_ANIMATION_H_ | 6 #define CHROME_BROWSER_UI_VIEWS_TOOLBAR_APP_MENU_ANIMATION_H_ |
7 | 7 |
8 #include "base/time/time.h" | 8 #include "base/time/time.h" |
9 #include "third_party/skia/include/core/SkColor.h" | 9 #include "third_party/skia/include/core/SkColor.h" |
10 #include "ui/gfx/animation/animation_delegate.h" | 10 #include "ui/gfx/animation/animation_delegate.h" |
11 #include "ui/gfx/animation/slide_animation.h" | 11 #include "ui/gfx/animation/slide_animation.h" |
12 | 12 |
13 namespace gfx { | 13 namespace gfx { |
14 class Canvas; | 14 class Canvas; |
15 class PointF; | 15 class PointF; |
16 } // namespace gfx | 16 } // namespace gfx |
17 | 17 |
18 class AppMenuButton; | 18 class AppMenuButton; |
19 | 19 |
20 // This class is used for animating and drawing the app menu icon. | 20 // This class is used for animating and drawing the app menu icon. |
21 class AppMenuAnimation : public gfx::AnimationDelegate { | 21 class AppMenuAnimation : public gfx::AnimationDelegate { |
22 public: | 22 public: |
23 AppMenuAnimation(AppMenuButton* owner, bool should_animate_closed); | 23 AppMenuAnimation(AppMenuButton* owner, SkColor initial_color); |
24 | 24 |
25 ~AppMenuAnimation() override; | 25 ~AppMenuAnimation() override; |
26 | 26 |
27 // Paints the app menu icon. | 27 // Paints the app menu icon. |
28 void PaintAppMenu(gfx::Canvas* canvas, const gfx::Rect& bounds); | 28 void PaintAppMenu(gfx::Canvas* canvas, const gfx::Rect& bounds); |
29 | 29 |
30 // Updates the icon colors. | 30 void set_target_color(SkColor target_color) { target_color_ = target_color; } |
31 void SetIconColors(SkColor start_color, SkColor severity_color); | |
32 | 31 |
33 // Starts the animation if it's not already running. | 32 // Starts the animation if it's not already running. |
34 void StartAnimation(); | 33 void StartAnimation(); |
35 | 34 |
36 // gfx::AnimationDelegate: | 35 // gfx::AnimationDelegate: |
37 void AnimationEnded(const gfx::Animation* animation) override; | 36 void AnimationEnded(const gfx::Animation* animation) override; |
38 void AnimationProgressed(const gfx::Animation* animation) override; | 37 void AnimationProgressed(const gfx::Animation* animation) override; |
39 | 38 |
40 private: | 39 private: |
41 // This class is used to represent and paint a dot on the app menu. | 40 // This class is used to represent and paint a dot on the app menu. |
(...skipping 21 matching lines...) Expand all Loading... |
63 // The percentage of the overall animation duration it takes to animate the | 62 // The percentage of the overall animation duration it takes to animate the |
64 // width and stroke to their open state. | 63 // width and stroke to their open state. |
65 const float width_open_interval_; | 64 const float width_open_interval_; |
66 const float stroke_open_interval_; | 65 const float stroke_open_interval_; |
67 | 66 |
68 DISALLOW_COPY_AND_ASSIGN(AppMenuDot); | 67 DISALLOW_COPY_AND_ASSIGN(AppMenuDot); |
69 }; | 68 }; |
70 | 69 |
71 AppMenuButton* const owner_; | 70 AppMenuButton* const owner_; |
72 | 71 |
73 // True if the animation should close after it finishes opening. | |
74 const bool should_animate_closed_; | |
75 | |
76 std::unique_ptr<gfx::SlideAnimation> animation_; | 72 std::unique_ptr<gfx::SlideAnimation> animation_; |
77 | 73 |
78 AppMenuDot bottom_dot_; | 74 AppMenuDot bottom_dot_; |
79 AppMenuDot middle_dot_; | 75 AppMenuDot middle_dot_; |
80 AppMenuDot top_dot_; | 76 AppMenuDot top_dot_; |
81 | 77 |
82 // The starting color of the dots. The animation is expected to transition | 78 // The starting color of the dots. The animation is expected to transition |
83 // from this color to |severity_color_|. | 79 // from this color to |target_color_|. |
84 SkColor start_color_; | 80 SkColor start_color_; |
85 | 81 |
86 // The severity color of the dots. This is final color at the end of the | 82 // The severity color of the dots. This is final color at the end of the |
87 // animation. | 83 // animation. |
88 SkColor severity_color_; | 84 SkColor target_color_; |
89 | 85 |
90 DISALLOW_COPY_AND_ASSIGN(AppMenuAnimation); | 86 DISALLOW_COPY_AND_ASSIGN(AppMenuAnimation); |
91 }; | 87 }; |
92 | 88 |
93 #endif // CHROME_BROWSER_UI_VIEWS_TOOLBAR_APP_MENU_ANIMATION_H_ | 89 #endif // CHROME_BROWSER_UI_VIEWS_TOOLBAR_APP_MENU_ANIMATION_H_ |
OLD | NEW |