Chromium Code Reviews| OLD | NEW |
|---|---|
| 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 #include "chrome/browser/ui/views/location_bar/action_box_button_view.h" | 5 #include "chrome/browser/ui/views/location_bar/action_box_button_view.h" |
| 6 | 6 |
| 7 #include "base/utf_string_conversions.h" | 7 #include "base/utf_string_conversions.h" |
| 8 #include "chrome/browser/ui/browser.h" | 8 #include "chrome/browser/ui/browser.h" |
| 9 #include "chrome/browser/ui/toolbar/action_box_menu_model.h" | 9 #include "chrome/browser/ui/toolbar/action_box_menu_model.h" |
| 10 #include "chrome/browser/ui/view_ids.h" | 10 #include "chrome/browser/ui/view_ids.h" |
| 11 #include "chrome/browser/ui/views/action_box_menu.h" | 11 #include "chrome/browser/ui/views/action_box_menu.h" |
| 12 #include "chrome/browser/ui/views/location_bar/location_bar_view.h" | 12 #include "chrome/browser/ui/views/location_bar/location_bar_view.h" |
| 13 #include "grit/generated_resources.h" | 13 #include "grit/generated_resources.h" |
| 14 #include "grit/theme_resources.h" | 14 #include "grit/theme_resources.h" |
| 15 #include "ui/base/accessibility/accessible_view_state.h" | 15 #include "ui/base/accessibility/accessible_view_state.h" |
| 16 #include "ui/base/l10n/l10n_util.h" | 16 #include "ui/base/l10n/l10n_util.h" |
| 17 #include "ui/base/resource/resource_bundle.h" | 17 #include "ui/base/resource/resource_bundle.h" |
| 18 #include "ui/gfx/path.h" | |
| 19 | |
| 20 | |
| 21 // Thickness of the top transparent area on a button image that overlaps | |
| 22 // location bar border. | |
|
Peter Kasting
2012/10/13 00:25:29
Nit: Don't repeat this comment
yefimt
2012/10/13 00:51:30
Done.
| |
| 23 // static | |
| 24 const int ActionBoxButtonView::kTopBorderOverlapThickness = 2; | |
| 25 | |
| 26 // Thickness of the bottom transparent area on a button image that overlaps | |
| 27 // location bar border. | |
| 28 const int kBottomBorderOverlapThickness = 2; | |
|
Peter Kasting
2012/10/13 00:25:29
Nit: Eliminate this constant and rename the other
yefimt
2012/10/13 00:51:30
Done.
| |
| 18 | 29 |
| 19 ActionBoxButtonView::ActionBoxButtonView(Browser* browser, | 30 ActionBoxButtonView::ActionBoxButtonView(Browser* browser, |
| 20 const gfx::Point& menu_offset) | 31 const gfx::Point& menu_offset) |
| 21 : views::MenuButton(NULL, string16(), this, false), | 32 : views::MenuButton(NULL, string16(), this, false), |
| 22 browser_(browser), | 33 browser_(browser), |
| 23 menu_offset_(menu_offset), | 34 menu_offset_(menu_offset), |
| 24 ALLOW_THIS_IN_INITIALIZER_LIST(controller_(browser, this)) { | 35 ALLOW_THIS_IN_INITIALIZER_LIST(controller_(browser, this)) { |
| 25 set_id(VIEW_ID_ACTION_BOX_BUTTON); | 36 set_id(VIEW_ID_ACTION_BOX_BUTTON); |
| 26 SetTooltipText(l10n_util::GetStringUTF16(IDS_TOOLTIP_ACTION_BOX_BUTTON)); | 37 SetTooltipText(l10n_util::GetStringUTF16(IDS_TOOLTIP_ACTION_BOX_BUTTON)); |
| 27 SetIcon(*ui::ResourceBundle::GetSharedInstance().GetImageSkiaNamed( | 38 SetIcon(*ui::ResourceBundle::GetSharedInstance().GetImageSkiaNamed( |
| (...skipping 13 matching lines...) Expand all Loading... | |
| 41 void ActionBoxButtonView::GetAccessibleState(ui::AccessibleViewState* state) { | 52 void ActionBoxButtonView::GetAccessibleState(ui::AccessibleViewState* state) { |
| 42 MenuButton::GetAccessibleState(state); | 53 MenuButton::GetAccessibleState(state); |
| 43 state->name = l10n_util::GetStringUTF16(IDS_ACCNAME_ACTION_BOX_BUTTON); | 54 state->name = l10n_util::GetStringUTF16(IDS_ACCNAME_ACTION_BOX_BUTTON); |
| 44 } | 55 } |
| 45 | 56 |
| 46 void ActionBoxButtonView::OnMenuButtonClicked(View* source, | 57 void ActionBoxButtonView::OnMenuButtonClicked(View* source, |
| 47 const gfx::Point& point) { | 58 const gfx::Point& point) { |
| 48 controller_.OnButtonClicked(); | 59 controller_.OnButtonClicked(); |
| 49 } | 60 } |
| 50 | 61 |
| 62 bool ActionBoxButtonView::HasHitTestMask() const { | |
| 63 return true; | |
| 64 } | |
| 65 | |
| 66 void ActionBoxButtonView::GetHitTestMask(gfx::Path* mask) const { | |
| 67 SkRect clickable_rect; | |
| 68 clickable_rect.iset(0, kTopBorderOverlapThickness, width(), | |
| 69 height() - kBottomBorderOverlapThickness); | |
| 70 mask->addRect(clickable_rect); | |
| 71 } | |
| 72 | |
| 51 void ActionBoxButtonView::ShowMenu(scoped_ptr<ActionBoxMenuModel> menu_model) { | 73 void ActionBoxButtonView::ShowMenu(scoped_ptr<ActionBoxMenuModel> menu_model) { |
| 52 menu_ = ActionBoxMenu::Create(browser_, menu_model.Pass()); | 74 menu_ = ActionBoxMenu::Create(browser_, menu_model.Pass()); |
| 53 menu_->RunMenu(this, menu_offset_); | 75 menu_->RunMenu(this, menu_offset_); |
| 54 } | 76 } |
| OLD | NEW |