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 #ifndef CHROME_BROWSER_UI_VIEWS_DROPDOWN_BAR_VIEW_H_ | 5 #ifndef CHROME_BROWSER_UI_VIEWS_DROPDOWN_BAR_VIEW_H_ |
6 #define CHROME_BROWSER_UI_VIEWS_DROPDOWN_BAR_VIEW_H_ | 6 #define CHROME_BROWSER_UI_VIEWS_DROPDOWN_BAR_VIEW_H_ |
7 #pragma once | 7 #pragma once |
8 | 8 |
9 #include "chrome/browser/ui/views/dropdown_bar_host.h" | 9 #include "chrome/browser/ui/views/dropdown_bar_host.h" |
10 #include "chrome/browser/ui/views/dropdown_bar_host_delegate.h" | 10 #include "chrome/browser/ui/views/dropdown_bar_host_delegate.h" |
11 #include "ui/views/accessible_pane_view.h" | 11 #include "ui/views/accessible_pane_view.h" |
12 | 12 |
13 namespace gfx { | 13 namespace gfx { |
14 class Canvas; | 14 class Canvas; |
| 15 class ImageSkia; |
15 } // namespace gfx | 16 } // namespace gfx |
16 | 17 |
17 //////////////////////////////////////////////////////////////////////////////// | 18 //////////////////////////////////////////////////////////////////////////////// |
18 // | 19 // |
19 // The DropdownBarView is an abstract view to draw the UI controls of the | 20 // The DropdownBarView is an abstract view to draw the UI controls of the |
20 // DropdownBarHost. | 21 // DropdownBarHost. |
21 // | 22 // |
22 //////////////////////////////////////////////////////////////////////////////// | 23 //////////////////////////////////////////////////////////////////////////////// |
23 class DropdownBarView : public views::AccessiblePaneView, | 24 class DropdownBarView : public views::AccessiblePaneView, |
24 public DropdownBarHostDelegate { | 25 public DropdownBarHostDelegate { |
25 public: | 26 public: |
26 explicit DropdownBarView(DropdownBarHost* host); | 27 explicit DropdownBarView(DropdownBarHost* host); |
27 virtual ~DropdownBarView(); | 28 virtual ~DropdownBarView(); |
28 | 29 |
29 // Updates the view to let it know where the host is clipping the | 30 // Updates the view to let it know where the host is clipping the |
30 // dropdown widget (while animating the opening or closing of the widget). | 31 // dropdown widget (while animating the opening or closing of the widget). |
31 virtual void SetAnimationOffset(int offset) OVERRIDE; | 32 virtual void SetAnimationOffset(int offset) OVERRIDE; |
32 | 33 |
33 // Returns the offset used while animating. | 34 // Returns the offset used while animating. |
34 int animation_offset() const { return animation_offset_; } | 35 int animation_offset() const { return animation_offset_; } |
35 | 36 |
36 protected: | 37 protected: |
37 // views::View: | 38 // views::View: |
38 virtual void OnPaint(gfx::Canvas* canvas) OVERRIDE; | 39 virtual void OnPaint(gfx::Canvas* canvas) OVERRIDE; |
39 | 40 |
40 // Returns the DropdownBarHost that manages this view. | 41 // Returns the DropdownBarHost that manages this view. |
41 DropdownBarHost* host() const { return host_; } | 42 DropdownBarHost* host() const { return host_; } |
42 | 43 |
43 void SetBackground(const SkBitmap* left_alpha_mask, | 44 void SetBackground(const gfx::ImageSkia* left_alpha_mask, |
44 const SkBitmap* right_alpha_mask); | 45 const gfx::ImageSkia* right_alpha_mask); |
45 void SetBorder(int left_border_bitmap_id, int middle_border_bitmap_id, | 46 void SetBorder(int left_border_bitmap_id, int middle_border_bitmap_id, |
46 int right_border_bitmap_id); | 47 int right_border_bitmap_id); |
47 | 48 |
48 private: | 49 private: |
49 // The dropdown bar host that controls this view. | 50 // The dropdown bar host that controls this view. |
50 DropdownBarHost* host_; | 51 DropdownBarHost* host_; |
51 | 52 |
52 // While animating, the host clips the widget and draws only the bottom | 53 // While animating, the host clips the widget and draws only the bottom |
53 // part of it. The view needs to know the pixel offset at which we are drawing | 54 // part of it. The view needs to know the pixel offset at which we are drawing |
54 // the widget so that we can draw the curved edges that attach to the toolbar | 55 // the widget so that we can draw the curved edges that attach to the toolbar |
55 // in the right location. | 56 // in the right location. |
56 int animation_offset_; | 57 int animation_offset_; |
57 | 58 |
58 DISALLOW_COPY_AND_ASSIGN(DropdownBarView); | 59 DISALLOW_COPY_AND_ASSIGN(DropdownBarView); |
59 }; | 60 }; |
60 #endif // CHROME_BROWSER_UI_VIEWS_DROPDOWN_BAR_VIEW_H_ | 61 #endif // CHROME_BROWSER_UI_VIEWS_DROPDOWN_BAR_VIEW_H_ |
OLD | NEW |