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

Side by Side Diff: chrome/browser/ui/views/toolbar/wrench_toolbar_button.cc

Issue 298813002: views: Move MenuButton from TextButton to LabelButton. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Remove stray LOG Created 6 years, 6 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
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 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 "chrome/browser/ui/views/toolbar/wrench_toolbar_button.h" 5 #include "chrome/browser/ui/views/toolbar/wrench_toolbar_button.h"
6 6
7 #include "grit/theme_resources.h" 7 #include "grit/theme_resources.h"
8 #include "ui/base/resource/resource_bundle.h" 8 #include "ui/base/resource/resource_bundle.h"
9 #include "ui/base/theme_provider.h" 9 #include "ui/base/theme_provider.h"
10 #include "ui/views/painter.h"
10 11
11 WrenchToolbarButton::WrenchToolbarButton(views::MenuButtonListener* listener) 12 WrenchToolbarButton::WrenchToolbarButton(views::MenuButtonListener* listener)
12 : views::MenuButton(NULL, base::string16(), listener, false) { 13 : views::MenuButton(NULL, base::string16(), listener, false),
14 preferred_size_(ResourceBundle::GetSharedInstance().
sky 2014/06/09 15:42:00 I say nuke the member and look up every time you n
Elliot Glaysher 2014/06/11 00:27:28 Done.
15 GetImageSkiaNamed(IDR_TOOLBAR_BEZEL_HOVER)->size()) {
13 wrench_icon_painter_.reset(new WrenchIconPainter(this)); 16 wrench_icon_painter_.reset(new WrenchIconPainter(this));
14
15 // Used for sizing only.
16 ui::ResourceBundle& rb = ResourceBundle::GetSharedInstance();
17 SetIcon(*rb.GetImageSkiaNamed(IDR_TOOLBAR_BEZEL_HOVER));
18 } 17 }
19 18
20 WrenchToolbarButton::~WrenchToolbarButton() { 19 WrenchToolbarButton::~WrenchToolbarButton() {
21 } 20 }
22 21
23 void WrenchToolbarButton::SetSeverity(WrenchIconPainter::Severity severity, 22 void WrenchToolbarButton::SetSeverity(WrenchIconPainter::Severity severity,
24 bool animate) { 23 bool animate) {
25 wrench_icon_painter_->SetSeverity(severity, animate); 24 wrench_icon_painter_->SetSeverity(severity, animate);
26 } 25 }
27 26
27 gfx::Size WrenchToolbarButton::GetPreferredSize() const {
28 return preferred_size_;
29 }
30
28 void WrenchToolbarButton::OnPaint(gfx::Canvas* canvas) { 31 void WrenchToolbarButton::OnPaint(gfx::Canvas* canvas) {
29 wrench_icon_painter_->Paint( 32 wrench_icon_painter_->Paint(
30 canvas, GetThemeProvider(), gfx::Rect(size()), GetCurrentBezelType()); 33 canvas, GetThemeProvider(), gfx::Rect(size()), GetCurrentBezelType());
31 views::Painter::PaintFocusPainter(this, canvas, focus_painter()); 34 views::Painter::PaintFocusPainter(this, canvas, focus_painter());
32 } 35 }
33 36
34 void WrenchToolbarButton::ScheduleWrenchIconPaint() { 37 void WrenchToolbarButton::ScheduleWrenchIconPaint() {
35 SchedulePaint(); 38 SchedulePaint();
36 } 39 }
37 40
38 WrenchIconPainter::BezelType WrenchToolbarButton::GetCurrentBezelType() const { 41 WrenchIconPainter::BezelType WrenchToolbarButton::GetCurrentBezelType() const {
39 switch (state()) { 42 switch (state()) {
40 case STATE_HOVERED: 43 case STATE_HOVERED:
41 return WrenchIconPainter::BEZEL_HOVER; 44 return WrenchIconPainter::BEZEL_HOVER;
42 case STATE_PRESSED: 45 case STATE_PRESSED:
43 return WrenchIconPainter::BEZEL_PRESSED; 46 return WrenchIconPainter::BEZEL_PRESSED;
44 default: 47 default:
45 return WrenchIconPainter::BEZEL_NONE; 48 return WrenchIconPainter::BEZEL_NONE;
46 } 49 }
47 } 50 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698