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

Side by Side Diff: chrome/browser/ui/views/avatar_menu_button.cc

Issue 7003080: Change profile menu button to avatar button (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src/
Patch Set: '' Created 9 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 (c) 2011 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2011 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/profile_menu_button.h" 5 #include "chrome/browser/ui/views/avatar_menu_button.h"
6 6
7 #include "chrome/browser/ui/profile_menu_model.h" 7 #include "ui/gfx/canvas_skia.h"
8 #include "ui/base/text/text_elider.h"
9 #include "ui/gfx/color_utils.h"
10 #include "views/controls/button/button.h"
11 #include "views/controls/menu/menu_item_view.h"
12 #include "views/controls/menu/menu_model_adapter.h" 8 #include "views/controls/menu/menu_model_adapter.h"
13 #include "views/window/window.h" 9 #include "views/window/window.h"
14 10
15 // Menu should display below the profile button tag image on the frame. This 11 // Menu should display below the image on the frame. This
16 // offset size depends on whether the frame is in glass or opaque mode. 12 // offset size depends on whether the frame is in glass or opaque mode.
Peter Kasting 2011/06/10 20:37:21 This comment seems wrong. I'm also confused as to
17 const int kMenuDisplayOffset = 7; 13 const int kMenuDisplayOffset = 5;
18 14
19 // TextHover is slightly darker than enabled color, for a subtle hover shift. 15 static inline int Round(double x) {
20 const SkColor kTextHover = 0xFFDDDDDD; 16 return static_cast<int>(floor(x + 0.5));
Peter Kasting 2011/06/10 20:37:21 Nit: "floor()" is unnecessary.
21 const SkColor kTextEnabled = SK_ColorWHITE;
22 const SkColor kTextHighlighted = SK_ColorWHITE;
23
24 // Horizontal padding beside profile menu button, to center it in the
25 // underlying tag image.
26 const int kProfileButtonBorderSpacing = 10;
27
28 // Maximum width for name string in pixels.
29 const int kMaxTextWidth = 200;
30
31 ProfileMenuButton::ProfileMenuButton(const std::wstring& text, Profile* profile)
32 : MenuButton(NULL, text, this, true) {
33 // Turn off hover highlighting and position button in the center of the
34 // underlying profile tag image.
35 set_border(views::Border::CreateEmptyBorder(
36 0, kProfileButtonBorderSpacing, 0, kProfileButtonBorderSpacing));
37 SetHoverColor(kTextHover);
38 SetEnabledColor(kTextEnabled);
39 SetHighlightColor(kTextHighlighted);
40
41 profile_menu_model_.reset(new ProfileMenuModel);
42 } 17 }
43 18
44 ProfileMenuButton::~ProfileMenuButton() {} 19 AvatarMenuButton::AvatarMenuButton(const std::wstring& text,
20 ui::MenuModel* menu_model)
21 : MenuButton(NULL, text, this, false),
22 menu_model_(menu_model) {
23 // In RTL mode, the avatar icon should be looking the opposite direction.
24 EnableCanvasFlippingForRTLUI(true);
25 }
45 26
46 void ProfileMenuButton::SetText(const std::wstring& text) { 27 AvatarMenuButton::~AvatarMenuButton() {}
47 MenuButton::SetText(UTF16ToWideHack(ui::ElideText(WideToUTF16Hack(text), 28
48 font(), kMaxTextWidth, false))); 29 void AvatarMenuButton::OnPaint(gfx::Canvas* canvas) {
30 const SkBitmap& icon = GetImageToPaint();
31 if (!icon.isNull()) {
32 // Scale the image to fit the width of the button.
33 int src_width = icon.width();
34 int src_x = 0;
35 int dst_width = std::min(src_width, width());
36 int dst_x = Round((width() - dst_width) / 2.0);
37
38 // Scale the height and maintain aspect ratio. This means that the
39 // icon may not fit in the view. That's ok, we just center it vertically.
40 float scale =
41 static_cast<float>(dst_width) / static_cast<float>(icon.width());
42 int scaled_height = Round(height() / scale);
Peter Kasting 2011/06/10 20:37:21 You want "*", not "/".
sail 2011/06/10 21:23:38 scaled_height is for the image so using / works. *
43 int src_height = std::min(scaled_height, icon.height());
44 int src_y = Round((icon.height() - src_height) / 2.0);
45 int dst_height = src_height * scale;
46 int dst_y = Round((height() - dst_height) / 2.0);
47
48 canvas->DrawBitmapInt(icon, src_x, src_y, src_width, src_height,
49 dst_x, dst_y, dst_width, dst_height, false);
50 }
51 }
52
53 gfx::Size AvatarMenuButton::GetPreferredAvatarSize() {
54 return gfx::Size(38, 31);
Peter Kasting 2011/06/10 20:37:21 This seems kind of random. I think your old way o
sail 2011/06/10 21:23:38 I had to make it static because the avatar bounds
49 } 55 }
50 56
51 // views::ViewMenuDelegate implementation 57 // views::ViewMenuDelegate implementation
52 void ProfileMenuButton::RunMenu(views::View* source, const gfx::Point &pt) { 58 void AvatarMenuButton::RunMenu(views::View* source, const gfx::Point& pt) {
53 views::MenuModelAdapter menu_model_adapter(profile_menu_model_.get()); 59 if (!menu_model_.get())
60 return;
61
62 views::MenuModelAdapter menu_model_adapter(menu_model_.get());
54 views::MenuItemView menu(&menu_model_adapter); 63 views::MenuItemView menu(&menu_model_adapter);
55 menu_model_adapter.BuildMenu(&menu); 64 menu_model_adapter.BuildMenu(&menu);
56 65
57 gfx::Point menu_point(pt.x(), pt.y() + kMenuDisplayOffset); 66 gfx::Point menu_point(pt.x(), pt.y() + kMenuDisplayOffset);
58 menu.RunMenuAt(source->GetWindow()->GetNativeWindow(), NULL, 67 menu.RunMenuAt(source->GetWindow()->GetNativeWindow(), NULL,
59 gfx::Rect(pt, gfx::Size(0, 0)), 68 gfx::Rect(pt, gfx::Size(0, 0)),
60 views::MenuItemView::TOPRIGHT, 69 views::MenuItemView::TOPRIGHT,
61 true); 70 true);
62 } 71 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698