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

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

Issue 82113004: Fix key navigation to cut/copy/paste zoom button on wrench menu (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 7 years 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 | « no previous file | ui/views/controls/button/custom_button.h » ('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 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_menu.h" 5 #include "chrome/browser/ui/views/toolbar/wrench_menu.h"
6 6
7 #include <algorithm> 7 #include <algorithm>
8 #include <cmath> 8 #include <cmath>
9 #include <set> 9 #include <set>
10 10
(...skipping 56 matching lines...) Expand 10 before | Expand all | Expand 10 after
67 using views::CustomButton; 67 using views::CustomButton;
68 using views::ImageButton; 68 using views::ImageButton;
69 using views::Label; 69 using views::Label;
70 using views::LabelButton; 70 using views::LabelButton;
71 using views::MenuConfig; 71 using views::MenuConfig;
72 using views::MenuItemView; 72 using views::MenuItemView;
73 using views::View; 73 using views::View;
74 74
75 namespace { 75 namespace {
76 76
77 // Colors used for buttons.
78 const SkColor kEnabledTouchBackgroundColor = SkColorSetARGB(247, 255, 255, 255);
79 const SkColor kHoverTouchBackgroundColor = SkColorSetARGB(247, 242, 242, 242);
80 const SkColor kFocusedTouchBackgroundColor = SkColorSetARGB(247, 235, 235, 235);
81
82 const SkColor kTouchButtonText = 0xff5a5a5a;
83
84 // Horizontal padding on the edges of the buttons. 77 // Horizontal padding on the edges of the buttons.
85 const int kHorizontalPadding = 6; 78 const int kHorizontalPadding = 6;
86 // Horizontal padding for a touch enabled menu. 79 // Horizontal padding for a touch enabled menu.
87 const int kHorizontalTouchPadding = 15; 80 const int kHorizontalTouchPadding = 15;
88 81
89 // Menu items which have embedded buttons should have this height in pixel. 82 // Menu items which have embedded buttons should have this height in pixel.
90 const int kMenuItemContainingButtonsHeight = 43; 83 const int kMenuItemContainingButtonsHeight = 43;
91 84
92 // Returns true if |command_id| identifies a bookmark menu item. 85 // Returns true if |command_id| identifies a bookmark menu item.
93 bool IsBookmarkCommand(int command_id) { 86 bool IsBookmarkCommand(int command_id) {
(...skipping 87 matching lines...) Expand 10 before | Expand all | Expand 10 after
181 left_button_ = right_button; 174 left_button_ = right_button;
182 right_button_ = left_button; 175 right_button_ = left_button;
183 } else { 176 } else {
184 left_button_ = left_button; 177 left_button_ = left_button;
185 right_button_ = right_button; 178 right_button_ = right_button;
186 } 179 }
187 } 180 }
188 181
189 // Overridden from views::Background. 182 // Overridden from views::Background.
190 virtual void Paint(gfx::Canvas* canvas, View* view) const OVERRIDE { 183 virtual void Paint(gfx::Canvas* canvas, View* view) const OVERRIDE {
191 CustomButton::ButtonState state = 184 CustomButton* button = CustomButton::AsCustomButton(view);
192 (!strcmp(view->GetClassName(), views::Label::kViewClassName)) ? 185 views::Button::ButtonState state =
193 CustomButton::STATE_NORMAL : static_cast<CustomButton*>(view)->state(); 186 button ? button->state() : views::Button::STATE_NORMAL;
194 int w = view->width(); 187 int w = view->width();
195 int h = view->height(); 188 int h = view->height();
196 #if defined(USE_AURA) 189 #if defined(USE_AURA)
197 if (use_new_menu_ && 190 // Normal buttons get a border drawn on the right side and the rest gets
198 view->GetNativeTheme() == ui::NativeThemeAura::instance()) { 191 // filled in. The left button however does not get a line to combine
199 // Normal buttons get a border drawn on the right side and the rest gets 192 // buttons.
200 // filled in. The left button however does not get a line to combine 193 int border = 0;
201 // buttons. 194 if (type_ != RIGHT_BUTTON) {
202 int border = 0; 195 border = 1;
203 if (type_ != RIGHT_BUTTON) { 196 canvas->FillRect(gfx::Rect(0, 0, border, h),
204 border = 1; 197 BorderColor(view, views::Button::STATE_NORMAL));
205 canvas->FillRect(gfx::Rect(0, 0, border, h), 198 }
206 BorderColor(view, CustomButton::STATE_NORMAL)); 199 if (use_new_menu_) {
207 } 200 gfx::Rect bounds(view->GetLocalBounds());
208 canvas->FillRect(gfx::Rect(border, 0, w - border, h), 201 bounds.set_x(view->GetMirroredXForRect(bounds));
209 touch_background_color(state)); 202 DrawBackground(canvas, view, bounds, state);
210 return; 203 return;
211 } 204 }
205 if (use_new_menu_)
206 return;
212 #endif 207 #endif
213 const SkColor background = BackgroundColor(view, state); 208 const SkColor border_color = BorderColor(view, state);
214 const SkColor border = BorderColor(view, state);
215 switch (TypeAdjustedForRTL()) { 209 switch (TypeAdjustedForRTL()) {
216 // TODO(pkasting): Why don't all the following use SkPaths with rounded 210 // TODO(pkasting): Why don't all the following use SkPaths with rounded
217 // corners? 211 // corners?
218 case LEFT_BUTTON: 212 case LEFT_BUTTON:
219 canvas->FillRect(gfx::Rect(1, 1, w, h - 2), background); 213 DrawBackground(canvas, view, gfx::Rect(1, 1, w, h - 2), state);
220 canvas->FillRect(gfx::Rect(2, 0, w, 1), border); 214 canvas->FillRect(gfx::Rect(2, 0, w, 1), border_color);
221 canvas->FillRect(gfx::Rect(1, 1, 1, 1), border); 215 canvas->FillRect(gfx::Rect(1, 1, 1, 1), border_color);
222 canvas->FillRect(gfx::Rect(0, 2, 1, h - 4), border); 216 canvas->FillRect(gfx::Rect(0, 2, 1, h - 4), border_color);
223 canvas->FillRect(gfx::Rect(1, h - 2, 1, 1), border); 217 canvas->FillRect(gfx::Rect(1, h - 2, 1, 1), border_color);
224 canvas->FillRect(gfx::Rect(2, h - 1, w, 1), border); 218 canvas->FillRect(gfx::Rect(2, h - 1, w, 1), border_color);
225 break; 219 break;
226 220
227 case CENTER_BUTTON: { 221 case CENTER_BUTTON: {
228 canvas->FillRect(gfx::Rect(1, 1, w - 2, h - 2), background); 222 DrawBackground(canvas, view, gfx::Rect(1, 1, w - 2, h - 2), state);
229 SkColor left_color = state != CustomButton::STATE_NORMAL ? 223 SkColor left_color = state != views::Button::STATE_NORMAL ?
230 border : BorderColor(view, left_button_->state()); 224 border_color : BorderColor(view, left_button_->state());
231 canvas->FillRect(gfx::Rect(0, 0, 1, h), left_color); 225 canvas->FillRect(gfx::Rect(0, 0, 1, h), left_color);
232 canvas->FillRect(gfx::Rect(1, 0, w - 2, 1), border); 226 canvas->FillRect(gfx::Rect(1, 0, w - 2, 1), border_color);
233 canvas->FillRect(gfx::Rect(1, h - 1, w - 2, 1), 227 canvas->FillRect(gfx::Rect(1, h - 1, w - 2, 1),
234 border); 228 border_color);
235 SkColor right_color = state != CustomButton::STATE_NORMAL ? 229 SkColor right_color = state != views::Button::STATE_NORMAL ?
236 border : BorderColor(view, right_button_->state()); 230 border_color : BorderColor(view, right_button_->state());
237 canvas->FillRect(gfx::Rect(w - 1, 0, 1, h), right_color); 231 canvas->FillRect(gfx::Rect(w - 1, 0, 1, h), right_color);
238 break; 232 break;
239 } 233 }
240 234
241 case RIGHT_BUTTON: 235 case RIGHT_BUTTON:
242 canvas->FillRect(gfx::Rect(0, 1, w - 1, h - 2), background); 236 DrawBackground(canvas, view, gfx::Rect(0, 1, w - 1, h - 2), state);
243 canvas->FillRect(gfx::Rect(0, 0, w - 2, 1), border); 237 canvas->FillRect(gfx::Rect(0, 0, w - 2, 1), border_color);
244 canvas->FillRect(gfx::Rect(w - 2, 1, 1, 1), border); 238 canvas->FillRect(gfx::Rect(w - 2, 1, 1, 1), border_color);
245 canvas->FillRect(gfx::Rect(w - 1, 2, 1, h - 4), border); 239 canvas->FillRect(gfx::Rect(w - 1, 2, 1, h - 4), border_color);
246 canvas->FillRect(gfx::Rect(w - 2, h - 2, 1, 1), border); 240 canvas->FillRect(gfx::Rect(w - 2, h - 2, 1, 1), border_color);
247 canvas->FillRect(gfx::Rect(0, h - 1, w - 2, 1), border); 241 canvas->FillRect(gfx::Rect(0, h - 1, w - 2, 1), border_color);
248 break; 242 break;
249 243
250 case SINGLE_BUTTON: 244 case SINGLE_BUTTON:
251 canvas->FillRect(gfx::Rect(1, 1, w - 2, h - 2), background); 245 DrawBackground(canvas, view, gfx::Rect(1, 1, w - 2, h - 2), state);
252 canvas->FillRect(gfx::Rect(2, 0, w - 4, 1), border); 246 canvas->FillRect(gfx::Rect(2, 0, w - 4, 1), border_color);
253 canvas->FillRect(gfx::Rect(1, 1, 1, 1), border); 247 canvas->FillRect(gfx::Rect(1, 1, 1, 1), border_color);
254 canvas->FillRect(gfx::Rect(0, 2, 1, h - 4), border); 248 canvas->FillRect(gfx::Rect(0, 2, 1, h - 4), border_color);
255 canvas->FillRect(gfx::Rect(1, h - 2, 1, 1), border); 249 canvas->FillRect(gfx::Rect(1, h - 2, 1, 1), border_color);
256 canvas->FillRect(gfx::Rect(2, h - 1, w - 4, 1), border); 250 canvas->FillRect(gfx::Rect(2, h - 1, w - 4, 1), border_color);
257 canvas->FillRect(gfx::Rect(w - 2, 1, 1, 1), border); 251 canvas->FillRect(gfx::Rect(w - 2, 1, 1, 1), border_color);
258 canvas->FillRect(gfx::Rect(w - 1, 2, 1, h - 4), border); 252 canvas->FillRect(gfx::Rect(w - 1, 2, 1, h - 4), border_color);
259 canvas->FillRect(gfx::Rect(w - 2, h - 2, 1, 1), border); 253 canvas->FillRect(gfx::Rect(w - 2, h - 2, 1, 1), border_color);
260 break; 254 break;
261 255
262 default: 256 default:
263 NOTREACHED(); 257 NOTREACHED();
264 break; 258 break;
265 } 259 }
266 } 260 }
267 261
268 private: 262 private:
269 static SkColor BorderColor(View* view, CustomButton::ButtonState state) { 263 static SkColor BorderColor(View* view, views::Button::ButtonState state) {
270 ui::NativeTheme* theme = view->GetNativeTheme(); 264 ui::NativeTheme* theme = view->GetNativeTheme();
271 switch (state) { 265 switch (state) {
272 case CustomButton::STATE_HOVERED: 266 case views::Button::STATE_HOVERED:
273 return theme->GetSystemColor( 267 return theme->GetSystemColor(
274 ui::NativeTheme::kColorId_HoverMenuButtonBorderColor); 268 ui::NativeTheme::kColorId_HoverMenuButtonBorderColor);
275 case CustomButton::STATE_PRESSED: 269 case views::Button::STATE_PRESSED:
276 return theme->GetSystemColor( 270 return theme->GetSystemColor(
277 ui::NativeTheme::kColorId_FocusedMenuButtonBorderColor); 271 ui::NativeTheme::kColorId_FocusedMenuButtonBorderColor);
278 default: 272 default:
279 return theme->GetSystemColor( 273 return theme->GetSystemColor(
280 ui::NativeTheme::kColorId_EnabledMenuButtonBorderColor); 274 ui::NativeTheme::kColorId_EnabledMenuButtonBorderColor);
281 } 275 }
282 } 276 }
283 277
284 static SkColor BackgroundColor(View* view, CustomButton::ButtonState state) { 278 static SkColor BackgroundColor(const View* view, views::Button::ButtonState st ate) {
285 ui::NativeTheme* theme = view->GetNativeTheme(); 279 const ui::NativeTheme* theme = view->GetNativeTheme();
286 switch (state) { 280 switch (state) {
287 case CustomButton::STATE_HOVERED: 281 case views::Button::STATE_HOVERED:
282 NOTREACHED();
288 return theme->GetSystemColor( 283 return theme->GetSystemColor(
289 ui::NativeTheme::kColorId_HoverMenuItemBackgroundColor); 284 ui::NativeTheme::kColorId_HoverMenuItemBackgroundColor);
290 case CustomButton::STATE_PRESSED: 285 case views::Button::STATE_PRESSED:
291 return theme->GetSystemColor( 286 return theme->GetSystemColor(
292 ui::NativeTheme::kColorId_FocusedMenuItemBackgroundColor); 287 ui::NativeTheme::kColorId_FocusedMenuItemBackgroundColor);
293 default: 288 default:
294 return theme->GetSystemColor( 289 return theme->GetSystemColor(
295 ui::NativeTheme::kColorId_MenuBackgroundColor); 290 ui::NativeTheme::kColorId_MenuBackgroundColor);
296 } 291 }
297 } 292 }
298 293
299 static SkColor touch_background_color(CustomButton::ButtonState state) { 294 void DrawBackground(gfx::Canvas* canvas,
300 switch (state) { 295 const views::View* view,
301 case CustomButton::STATE_HOVERED: return kHoverTouchBackgroundColor; 296 const gfx::Rect& bounds,
302 case CustomButton::STATE_PRESSED: return kFocusedTouchBackgroundColor; 297 views::Button::ButtonState state) const {
303 default: return kEnabledTouchBackgroundColor; 298 if (state == views::Button::STATE_HOVERED) {
299 view->GetNativeTheme()->Paint(canvas->sk_canvas(),
300 ui::NativeTheme::kMenuItemBackground,
301 ui::NativeTheme::kHovered,
302 bounds,
303 ui::NativeTheme::ExtraParams());
304 return;
304 } 305 }
306 if (use_new_menu_)
307 return;
308 canvas->FillRect(bounds, BackgroundColor(view, state));
oshima 2013/11/25 21:59:01 I wonder if this is correct/intentional. MenuItemv
305 } 309 }
306 310
307 ButtonType TypeAdjustedForRTL() const { 311 ButtonType TypeAdjustedForRTL() const {
308 if (!base::i18n::IsRTL()) 312 if (!base::i18n::IsRTL())
309 return type_; 313 return type_;
310 314
311 switch (type_) { 315 switch (type_) {
312 case LEFT_BUTTON: return RIGHT_BUTTON; 316 case LEFT_BUTTON: return RIGHT_BUTTON;
313 case RIGHT_BUTTON: return LEFT_BUTTON; 317 case RIGHT_BUTTON: return LEFT_BUTTON;
314 default: break; 318 default: break;
(...skipping 46 matching lines...) Expand 10 before | Expand all | Expand 10 after
361 // Overridden from views::View. 365 // Overridden from views::View.
362 virtual void SchedulePaintInRect(const gfx::Rect& r) OVERRIDE { 366 virtual void SchedulePaintInRect(const gfx::Rect& r) OVERRIDE {
363 // Normally when the mouse enters/exits a button the buttons invokes 367 // Normally when the mouse enters/exits a button the buttons invokes
364 // SchedulePaint. As part of the button border (MenuButtonBackground) is 368 // SchedulePaint. As part of the button border (MenuButtonBackground) is
365 // rendered by the button to the left/right of it SchedulePaint on the the 369 // rendered by the button to the left/right of it SchedulePaint on the the
366 // button may not be enough, so this forces a paint all. 370 // button may not be enough, so this forces a paint all.
367 View::SchedulePaintInRect(gfx::Rect(size())); 371 View::SchedulePaintInRect(gfx::Rect(size()));
368 } 372 }
369 373
370 LabelButton* CreateAndConfigureButton(int string_id, 374 LabelButton* CreateAndConfigureButton(int string_id,
371 MenuButtonBackground::ButtonType type, 375 MenuButtonBackground::ButtonType type,
372 int index, 376 int index,
373 MenuButtonBackground** background) { 377 MenuButtonBackground** background) {
374 return CreateButtonWithAccName( 378 return CreateButtonWithAccName(
375 string_id, type, index, background, string_id); 379 string_id, type, index, background, string_id);
376 } 380 }
377 381
378 LabelButton* CreateButtonWithAccName(int string_id, 382 LabelButton* CreateButtonWithAccName(int string_id,
379 MenuButtonBackground::ButtonType type, 383 MenuButtonBackground::ButtonType type,
380 int index, 384 int index,
381 MenuButtonBackground** background, 385 MenuButtonBackground** background,
382 int acc_string_id) { 386 int acc_string_id) {
383 // Should only be invoked during construction when |menu_| is valid. 387 // Should only be invoked during construction when |menu_| is valid.
(...skipping 10 matching lines...) Expand all
394 new MenuButtonBackground(type, menu_->use_new_menu()); 398 new MenuButtonBackground(type, menu_->use_new_menu());
395 button->set_background(bg); 399 button->set_background(bg);
396 const MenuConfig& menu_config = menu_->GetMenuConfig(); 400 const MenuConfig& menu_config = menu_->GetMenuConfig();
397 button->SetTextColor(views::Button::STATE_NORMAL, menu_config.text_color); 401 button->SetTextColor(views::Button::STATE_NORMAL, menu_config.text_color);
398 if (background) 402 if (background)
399 *background = bg; 403 *background = bg;
400 button->set_border( 404 button->set_border(
401 new MenuButtonBorder(menu_config, menu_->use_new_menu())); 405 new MenuButtonBorder(menu_config, menu_->use_new_menu()));
402 button->SetHorizontalAlignment(gfx::ALIGN_CENTER); 406 button->SetHorizontalAlignment(gfx::ALIGN_CENTER);
403 button->SetFont(menu_config.font); 407 button->SetFont(menu_config.font);
408 ui::NativeTheme* native_theme = button->GetNativeTheme();
409
410 button->SetTextColor(
411 views::Button::STATE_DISABLED,
412 native_theme->GetSystemColor(
413 ui::NativeTheme::kColorId_DisabledMenuItemForegroundColor));
414 button->SetTextColor(
415 views::Button::STATE_HOVERED,
416 native_theme->GetSystemColor(
417 ui::NativeTheme::kColorId_SelectedMenuItemForegroundColor));
418 button->SetTextColor(
419 views::Button::STATE_PRESSED,
420 native_theme->GetSystemColor(
421 ui::NativeTheme::kColorId_SelectedMenuItemForegroundColor));
422 button->SetTextColor(
423 views::Button::STATE_NORMAL,
424 native_theme->GetSystemColor(
425 ui::NativeTheme::kColorId_EnabledMenuItemForegroundColor));
404 AddChildView(button); 426 AddChildView(button);
405 return button; 427 return button;
406 } 428 }
407 429
408 // Overridden from WrenchMenuObserver: 430 // Overridden from WrenchMenuObserver:
409 virtual void WrenchMenuDestroyed() OVERRIDE { 431 virtual void WrenchMenuDestroyed() OVERRIDE {
410 menu_->RemoveObserver(this); 432 menu_->RemoveObserver(this);
411 menu_ = NULL; 433 menu_ = NULL;
412 menu_model_ = NULL; 434 menu_model_ = NULL;
413 } 435 }
(...skipping 63 matching lines...) Expand 10 before | Expand all | Expand 10 after
477 IDS_COPY, MenuButtonBackground::CENTER_BUTTON, copy_index, 499 IDS_COPY, MenuButtonBackground::CENTER_BUTTON, copy_index,
478 &copy_background); 500 &copy_background);
479 501
480 LabelButton* paste = CreateAndConfigureButton( 502 LabelButton* paste = CreateAndConfigureButton(
481 IDS_PASTE, 503 IDS_PASTE,
482 menu->use_new_menu() && menu->supports_new_separators_ ? 504 menu->use_new_menu() && menu->supports_new_separators_ ?
483 MenuButtonBackground::CENTER_BUTTON : 505 MenuButtonBackground::CENTER_BUTTON :
484 MenuButtonBackground::RIGHT_BUTTON, 506 MenuButtonBackground::RIGHT_BUTTON,
485 paste_index, 507 paste_index,
486 NULL); 508 NULL);
487 if (menu->use_new_menu()) { 509 SkColor text_color = native_theme->GetSystemColor(
488 cut->SetTextColor(views::Button::STATE_NORMAL, kTouchButtonText); 510 ui::NativeTheme::kColorId_EnabledMenuItemForegroundColor);
489 copy->SetTextColor(views::Button::STATE_NORMAL, kTouchButtonText); 511 cut->SetTextColor(views::Button::STATE_NORMAL, text_color);
490 paste->SetTextColor(views::Button::STATE_NORMAL, kTouchButtonText); 512 copy->SetTextColor(views::Button::STATE_NORMAL, text_color);
491 } else { 513 paste->SetTextColor(views::Button::STATE_NORMAL, text_color);
492 SkColor text_color = native_theme->GetSystemColor(
493 ui::NativeTheme::kColorId_EnabledMenuItemForegroundColor);
494 cut->SetTextColor(views::Button::STATE_NORMAL, text_color);
495 copy->SetTextColor(views::Button::STATE_NORMAL, text_color);
496 paste->SetTextColor(views::Button::STATE_NORMAL, text_color);
497 }
498 copy_background->SetOtherButtons(cut, paste); 514 copy_background->SetOtherButtons(cut, paste);
499 } 515 }
500 516
501 // Overridden from View. 517 // Overridden from View.
502 virtual gfx::Size GetPreferredSize() OVERRIDE { 518 virtual gfx::Size GetPreferredSize() OVERRIDE {
503 // Returned height doesn't matter as MenuItemView forces everything to the 519 // Returned height doesn't matter as MenuItemView forces everything to the
504 // height of the menuitemview. 520 // height of the menuitemview.
505 return gfx::Size(GetMaxChildViewPreferredWidth() * child_count(), 0); 521 return gfx::Size(GetMaxChildViewPreferredWidth() * child_count(), 0);
506 } 522 }
507 523
(...skipping 78 matching lines...) Expand 10 before | Expand all | Expand 10 after
586 IDS_ZOOM_PLUS2, MenuButtonBackground::RIGHT_BUTTON, increment_index, 602 IDS_ZOOM_PLUS2, MenuButtonBackground::RIGHT_BUTTON, increment_index,
587 NULL, IDS_ACCNAME_ZOOM_PLUS2); 603 NULL, IDS_ACCNAME_ZOOM_PLUS2);
588 604
589 center_bg->SetOtherButtons(decrement_button_, increment_button_); 605 center_bg->SetOtherButtons(decrement_button_, increment_button_);
590 606
591 fullscreen_button_ = new FullscreenButton(this); 607 fullscreen_button_ = new FullscreenButton(this);
592 gfx::ImageSkia* full_screen_image = 608 gfx::ImageSkia* full_screen_image =
593 ui::ResourceBundle::GetSharedInstance().GetImageSkiaNamed( 609 ui::ResourceBundle::GetSharedInstance().GetImageSkiaNamed(
594 IDR_FULLSCREEN_MENU_BUTTON); 610 IDR_FULLSCREEN_MENU_BUTTON);
595 fullscreen_button_->SetImage(ImageButton::STATE_NORMAL, full_screen_image); 611 fullscreen_button_->SetImage(ImageButton::STATE_NORMAL, full_screen_image);
596 if (menu->use_new_menu()) { 612 SkColor enabled_text_color = native_theme->GetSystemColor(
597 zoom_label_->SetEnabledColor(kTouchButtonText); 613 ui::NativeTheme::kColorId_EnabledMenuItemForegroundColor);
598 decrement_button_->SetTextColor(views::Button::STATE_NORMAL, 614 zoom_label_->SetEnabledColor(enabled_text_color);
599 kTouchButtonText); 615 decrement_button_->SetTextColor(views::Button::STATE_NORMAL,
600 increment_button_->SetTextColor(views::Button::STATE_NORMAL, 616 enabled_text_color);
601 kTouchButtonText); 617 increment_button_->SetTextColor(views::Button::STATE_NORMAL,
602 } else { 618 enabled_text_color);
603 SkColor enabled_text_color = native_theme->GetSystemColor( 619 SkColor disabled_text_color = native_theme->GetSystemColor(
604 ui::NativeTheme::kColorId_EnabledMenuItemForegroundColor); 620 ui::NativeTheme::kColorId_DisabledMenuItemForegroundColor);
605 zoom_label_->SetEnabledColor(enabled_text_color); 621 decrement_button_->SetTextColor(views::Button::STATE_DISABLED,
606 decrement_button_->SetTextColor(views::Button::STATE_NORMAL, 622 disabled_text_color);
607 enabled_text_color); 623 increment_button_->SetTextColor(views::Button::STATE_DISABLED,
608 increment_button_->SetTextColor(views::Button::STATE_NORMAL, 624 disabled_text_color);
609 enabled_text_color);
610 SkColor disabled_text_color = native_theme->GetSystemColor(
611 ui::NativeTheme::kColorId_DisabledMenuItemForegroundColor);
612 decrement_button_->SetTextColor(views::Button::STATE_DISABLED,
613 disabled_text_color);
614 increment_button_->SetTextColor(views::Button::STATE_DISABLED,
615 disabled_text_color);
616 }
617
618 fullscreen_button_->set_focusable(true); 625 fullscreen_button_->set_focusable(true);
619 fullscreen_button_->set_request_focus_on_press(false); 626 fullscreen_button_->set_request_focus_on_press(false);
620 fullscreen_button_->set_tag(fullscreen_index); 627 fullscreen_button_->set_tag(fullscreen_index);
621 fullscreen_button_->SetImageAlignment( 628 fullscreen_button_->SetImageAlignment(
622 ImageButton::ALIGN_CENTER, ImageButton::ALIGN_MIDDLE); 629 ImageButton::ALIGN_CENTER, ImageButton::ALIGN_MIDDLE);
623 int horizontal_padding = 630 int horizontal_padding =
624 menu->use_new_menu() ? kHorizontalTouchPadding : kHorizontalPadding; 631 menu->use_new_menu() ? kHorizontalTouchPadding : kHorizontalPadding;
625 fullscreen_button_->set_border(views::Border::CreateEmptyBorder( 632 fullscreen_button_->set_border(views::Border::CreateEmptyBorder(
626 0, horizontal_padding, 0, horizontal_padding)); 633 0, horizontal_padding, 0, horizontal_padding));
627 fullscreen_button_->set_background( 634 fullscreen_button_->set_background(
(...skipping 683 matching lines...) Expand 10 before | Expand all | Expand 10 after
1311 0, 1318 0,
1312 BookmarkMenuDelegate::SHOW_PERMANENT_FOLDERS, 1319 BookmarkMenuDelegate::SHOW_PERMANENT_FOLDERS,
1313 BOOKMARK_LAUNCH_LOCATION_WRENCH_MENU); 1320 BOOKMARK_LAUNCH_LOCATION_WRENCH_MENU);
1314 } 1321 }
1315 1322
1316 int WrenchMenu::ModelIndexFromCommandId(int command_id) const { 1323 int WrenchMenu::ModelIndexFromCommandId(int command_id) const {
1317 CommandIDToEntry::const_iterator ix = command_id_to_entry_.find(command_id); 1324 CommandIDToEntry::const_iterator ix = command_id_to_entry_.find(command_id);
1318 DCHECK(ix != command_id_to_entry_.end()); 1325 DCHECK(ix != command_id_to_entry_.end());
1319 return ix->second.second; 1326 return ix->second.second;
1320 } 1327 }
OLDNEW
« no previous file with comments | « no previous file | ui/views/controls/button/custom_button.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698