Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(815)

Side by Side Diff: ui/views/controls/button/image_button.h

Issue 10382144: Change SetImage, SetBackground, and SetToggledImage to take in a gfx::ImageSkia (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Rebased Created 8 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « chrome/browser/ui/views/wrench_menu.cc ('k') | ui/views/controls/button/image_button.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
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 UI_VIEWS_CONTROLS_BUTTON_IMAGE_BUTTON_H_ 5 #ifndef UI_VIEWS_CONTROLS_BUTTON_IMAGE_BUTTON_H_
6 #define UI_VIEWS_CONTROLS_BUTTON_IMAGE_BUTTON_H_ 6 #define UI_VIEWS_CONTROLS_BUTTON_IMAGE_BUTTON_H_
7 #pragma once 7 #pragma once
8 8
9 #include "base/gtest_prod_util.h" 9 #include "base/gtest_prod_util.h"
10 #include "third_party/skia/include/core/SkBitmap.h" 10 #include "third_party/skia/include/core/SkBitmap.h"
11 #include "ui/gfx/image/image_skia.h"
11 #include "ui/views/controls/button/custom_button.h" 12 #include "ui/views/controls/button/custom_button.h"
12 13
13 namespace views { 14 namespace views {
14 15
15 // An image button. 16 // An image button.
16 17
17 // Note that this type of button is not focusable by default and will not be 18 // Note that this type of button is not focusable by default and will not be
18 // part of the focus chain. Call set_focusable(true) to make it part of the 19 // part of the focus chain. Call set_focusable(true) to make it part of the
19 // focus chain. 20 // focus chain.
20 21
21 class VIEWS_EXPORT ImageButton : public CustomButton { 22 class VIEWS_EXPORT ImageButton : public CustomButton {
22 public: 23 public:
23 enum HorizontalAlignment { 24 enum HorizontalAlignment {
24 ALIGN_LEFT = 0, 25 ALIGN_LEFT = 0,
25 ALIGN_CENTER, 26 ALIGN_CENTER,
26 ALIGN_RIGHT 27 ALIGN_RIGHT
27 }; 28 };
28 29
29 enum VerticalAlignment { 30 enum VerticalAlignment {
30 ALIGN_TOP = 0, 31 ALIGN_TOP = 0,
31 ALIGN_MIDDLE, 32 ALIGN_MIDDLE,
32 ALIGN_BOTTOM 33 ALIGN_BOTTOM
33 }; 34 };
34 35
35 explicit ImageButton(ButtonListener* listener); 36 explicit ImageButton(ButtonListener* listener);
36 virtual ~ImageButton(); 37 virtual ~ImageButton();
37 38
38 // Set the image the button should use for the provided state. 39 // Set the image the button should use for the provided state.
39 virtual void SetImage(ButtonState state, const SkBitmap* image); 40 virtual void SetImage(ButtonState state, const gfx::ImageSkia* image);
40 41
41 // Set the background details. 42 // Set the background details.
42 void SetBackground(SkColor color, 43 void SetBackground(SkColor color,
43 const SkBitmap* image, 44 const gfx::ImageSkia* image,
44 const SkBitmap* mask); 45 const gfx::ImageSkia* mask);
45 46
46 // Set an |image| to draw on top of the normal / hot / pushed image. 47 // Set an |image| to draw on top of the normal / hot / pushed image.
47 // Pass NULL for no image. 48 // Pass NULL for no image.
48 void SetOverlayImage(const SkBitmap* image); 49 void SetOverlayImage(const SkBitmap* image);
49 50
50 // Sets how the image is laid out within the button's bounds. 51 // Sets how the image is laid out within the button's bounds.
51 void SetImageAlignment(HorizontalAlignment h_align, 52 void SetImageAlignment(HorizontalAlignment h_align,
52 VerticalAlignment v_align); 53 VerticalAlignment v_align);
53 54
54 // Overridden from View: 55 // Overridden from View:
(...skipping 42 matching lines...) Expand 10 before | Expand all | Expand 10 after
97 public: 98 public:
98 explicit ToggleImageButton(ButtonListener* listener); 99 explicit ToggleImageButton(ButtonListener* listener);
99 virtual ~ToggleImageButton(); 100 virtual ~ToggleImageButton();
100 101
101 // Change the toggled state. 102 // Change the toggled state.
102 void SetToggled(bool toggled); 103 void SetToggled(bool toggled);
103 104
104 // Like ImageButton::SetImage(), but to set the graphics used for the 105 // Like ImageButton::SetImage(), but to set the graphics used for the
105 // "has been toggled" state. Must be called for each button state 106 // "has been toggled" state. Must be called for each button state
106 // before the button is toggled. 107 // before the button is toggled.
107 void SetToggledImage(ButtonState state, const SkBitmap* image); 108 void SetToggledImage(ButtonState state, const gfx::ImageSkia* image);
108 109
109 // Set the tooltip text displayed when the button is toggled. 110 // Set the tooltip text displayed when the button is toggled.
110 void SetToggledTooltipText(const string16& tooltip); 111 void SetToggledTooltipText(const string16& tooltip);
111 112
112 // Overridden from ImageButton: 113 // Overridden from ImageButton:
113 virtual void SetImage(ButtonState state, const SkBitmap* image) OVERRIDE; 114 virtual void SetImage(ButtonState state,
115 const gfx::ImageSkia* image) OVERRIDE;
114 116
115 // Overridden from View: 117 // Overridden from View:
116 virtual bool GetTooltipText(const gfx::Point& p, 118 virtual bool GetTooltipText(const gfx::Point& p,
117 string16* tooltip) const OVERRIDE; 119 string16* tooltip) const OVERRIDE;
118 120
119 private: 121 private:
120 // The parent class's images_ member is used for the current images, 122 // The parent class's images_ member is used for the current images,
121 // and this array is used to hold the alternative images. 123 // and this array is used to hold the alternative images.
122 // We swap between the two when toggling. 124 // We swap between the two when toggling.
123 SkBitmap alternate_images_[BS_COUNT]; 125 SkBitmap alternate_images_[BS_COUNT];
124 126
125 // True if the button is currently toggled. 127 // True if the button is currently toggled.
126 bool toggled_; 128 bool toggled_;
127 129
128 // The parent class's tooltip_text_ is displayed when not toggled, and 130 // The parent class's tooltip_text_ is displayed when not toggled, and
129 // this one is shown when toggled. 131 // this one is shown when toggled.
130 string16 toggled_tooltip_text_; 132 string16 toggled_tooltip_text_;
131 133
132 DISALLOW_COPY_AND_ASSIGN(ToggleImageButton); 134 DISALLOW_COPY_AND_ASSIGN(ToggleImageButton);
133 }; 135 };
134 136
135 } // namespace views 137 } // namespace views
136 138
137 #endif // UI_VIEWS_CONTROLS_BUTTON_IMAGE_BUTTON_H_ 139 #endif // UI_VIEWS_CONTROLS_BUTTON_IMAGE_BUTTON_H_
OLDNEW
« no previous file with comments | « chrome/browser/ui/views/wrench_menu.cc ('k') | ui/views/controls/button/image_button.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698