Chromium Code Reviews| OLD | NEW |
|---|---|
| 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 "ash/common/system/tray/tray_popup_header_button.h" | 5 #include "ash/common/system/tray/tray_popup_header_button.h" |
| 6 | 6 |
| 7 #include "ash/common/ash_constants.h" | 7 #include "ash/common/ash_constants.h" |
| 8 #include "ash/common/system/tray/tray_constants.h" | 8 #include "ash/common/system/tray/tray_constants.h" |
| 9 #include "ui/base/resource/resource_bundle.h" | 9 #include "ui/base/resource/resource_bundle.h" |
| 10 #include "ui/views/background.h" | 10 #include "ui/views/background.h" |
| 11 #include "ui/views/painter.h" | 11 #include "ui/views/painter.h" |
| 12 | 12 |
| 13 namespace ash { | 13 namespace ash { |
| 14 | 14 |
| 15 namespace { | |
| 16 | |
| 17 const gfx::ImageSkia* GetImageForResourceId(int resource_id) { | |
| 18 ui::ResourceBundle& bundle = ui::ResourceBundle::GetSharedInstance(); | |
| 19 return bundle.GetImageNamed(resource_id).ToImageSkia(); | |
| 20 } | |
| 21 | |
| 22 } // namespace | |
| 23 | |
| 15 // static | 24 // static |
| 16 const char TrayPopupHeaderButton::kViewClassName[] = | 25 const char TrayPopupHeaderButton::kViewClassName[] = |
| 17 "tray/TrayPopupHeaderButton"; | 26 "tray/TrayPopupHeaderButton"; |
| 18 | 27 |
| 19 TrayPopupHeaderButton::TrayPopupHeaderButton(views::ButtonListener* listener, | 28 TrayPopupHeaderButton::TrayPopupHeaderButton(views::ButtonListener* listener, |
| 20 int icon_resource_id, | 29 const gfx::ImageSkia& icon, |
| 21 int accessible_name_id) | 30 int accessible_name_id) |
| 22 : views::ToggleImageButton(listener) { | 31 : views::ToggleImageButton(listener) { |
| 23 ui::ResourceBundle& bundle = ui::ResourceBundle::GetSharedInstance(); | 32 ui::ResourceBundle& bundle = ui::ResourceBundle::GetSharedInstance(); |
| 24 SetImage(views::Button::STATE_NORMAL, | 33 SetImage(views::Button::STATE_NORMAL, &icon); |
| 25 bundle.GetImageNamed(icon_resource_id).ToImageSkia()); | |
| 26 SetImageAlignment(views::ImageButton::ALIGN_CENTER, | 34 SetImageAlignment(views::ImageButton::ALIGN_CENTER, |
| 27 views::ImageButton::ALIGN_MIDDLE); | 35 views::ImageButton::ALIGN_MIDDLE); |
| 28 SetAccessibleName(bundle.GetLocalizedString(accessible_name_id)); | 36 SetAccessibleName(bundle.GetLocalizedString(accessible_name_id)); |
| 29 SetFocusForPlatform(); | 37 SetFocusForPlatform(); |
| 30 | 38 |
| 31 SetFocusPainter(views::Painter::CreateSolidFocusPainter( | 39 SetFocusPainter(views::Painter::CreateSolidFocusPainter( |
| 32 kFocusBorderColor, gfx::Insets(1, 2, 2, 3))); | 40 kFocusBorderColor, gfx::Insets(1, 2, 2, 3))); |
| 33 } | 41 } |
| 34 | 42 |
| 35 TrayPopupHeaderButton::TrayPopupHeaderButton(views::ButtonListener* listener, | 43 TrayPopupHeaderButton::TrayPopupHeaderButton(views::ButtonListener* listener, |
| 36 int enabled_resource_id, | 44 int enabled_resource_id, |
| 37 int disabled_resource_id, | 45 int disabled_resource_id, |
| 38 int enabled_resource_id_hover, | 46 int enabled_resource_id_hover, |
| 39 int disabled_resource_id_hover, | 47 int disabled_resource_id_hover, |
| 40 int accessible_name_id) | 48 int accessible_name_id) |
| 41 : TrayPopupHeaderButton(listener, enabled_resource_id, accessible_name_id) { | 49 : TrayPopupHeaderButton(listener, |
| 50 *GetImageForResourceId(enabled_resource_id), | |
| 51 accessible_name_id) { | |
|
stevenjb
2016/08/24 15:58:57
This is awkward and may be tricky to debug if GetI
jdufault
2016/08/24 18:48:06
Done.
| |
| 42 ui::ResourceBundle& bundle = ui::ResourceBundle::GetSharedInstance(); | 52 ui::ResourceBundle& bundle = ui::ResourceBundle::GetSharedInstance(); |
| 43 SetToggledImage(views::Button::STATE_NORMAL, | 53 SetToggledImage(views::Button::STATE_NORMAL, |
| 44 bundle.GetImageNamed(disabled_resource_id).ToImageSkia()); | 54 bundle.GetImageNamed(disabled_resource_id).ToImageSkia()); |
| 45 SetImage(views::Button::STATE_HOVERED, | 55 SetImage(views::Button::STATE_HOVERED, |
| 46 bundle.GetImageNamed(enabled_resource_id_hover).ToImageSkia()); | 56 bundle.GetImageNamed(enabled_resource_id_hover).ToImageSkia()); |
| 47 SetToggledImage( | 57 SetToggledImage( |
| 48 views::Button::STATE_HOVERED, | 58 views::Button::STATE_HOVERED, |
| 49 bundle.GetImageNamed(disabled_resource_id_hover).ToImageSkia()); | 59 bundle.GetImageNamed(disabled_resource_id_hover).ToImageSkia()); |
| 50 } | 60 } |
| 51 | 61 |
| (...skipping 12 matching lines...) Expand all Loading... | |
| 64 if (state() == STATE_HOVERED || state() == STATE_PRESSED) { | 74 if (state() == STATE_HOVERED || state() == STATE_PRESSED) { |
| 65 set_background(views::Background::CreateSolidBackground( | 75 set_background(views::Background::CreateSolidBackground( |
| 66 kTrayPopupHoverBackgroundColor)); | 76 kTrayPopupHoverBackgroundColor)); |
| 67 } else { | 77 } else { |
| 68 set_background(nullptr); | 78 set_background(nullptr); |
| 69 } | 79 } |
| 70 SchedulePaint(); | 80 SchedulePaint(); |
| 71 } | 81 } |
| 72 | 82 |
| 73 } // namespace ash | 83 } // namespace ash |
| OLD | NEW |