| OLD | NEW |
| 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/wrench_menu.h" | 5 #include "chrome/browser/ui/views/wrench_menu.h" |
| 6 | 6 |
| 7 #include <cmath> | 7 #include <cmath> |
| 8 | 8 |
| 9 #include "base/string_number_conversions.h" | 9 #include "base/string_number_conversions.h" |
| 10 #include "base/utf_string_conversions.h" | 10 #include "base/utf_string_conversions.h" |
| (...skipping 18 matching lines...) Expand all Loading... |
| 29 #include "ui/gfx/canvas.h" | 29 #include "ui/gfx/canvas.h" |
| 30 #include "ui/gfx/canvas_skia.h" | 30 #include "ui/gfx/canvas_skia.h" |
| 31 #include "ui/gfx/skia_util.h" | 31 #include "ui/gfx/skia_util.h" |
| 32 #include "views/background.h" | 32 #include "views/background.h" |
| 33 #include "views/controls/button/image_button.h" | 33 #include "views/controls/button/image_button.h" |
| 34 #include "views/controls/button/menu_button.h" | 34 #include "views/controls/button/menu_button.h" |
| 35 #include "views/controls/button/text_button.h" | 35 #include "views/controls/button/text_button.h" |
| 36 #include "views/controls/label.h" | 36 #include "views/controls/label.h" |
| 37 #include "views/controls/menu/menu_config.h" | 37 #include "views/controls/menu/menu_config.h" |
| 38 #include "views/controls/menu/menu_item_view.h" | 38 #include "views/controls/menu/menu_item_view.h" |
| 39 #include "views/controls/menu/menu_runner.h" |
| 39 #include "views/controls/menu/menu_scroll_view_container.h" | 40 #include "views/controls/menu/menu_scroll_view_container.h" |
| 40 #include "views/controls/menu/submenu_view.h" | 41 #include "views/controls/menu/submenu_view.h" |
| 41 #include "views/widget/widget.h" | 42 #include "views/widget/widget.h" |
| 42 | 43 |
| 43 using ui::MenuModel; | 44 using ui::MenuModel; |
| 44 using views::CustomButton; | 45 using views::CustomButton; |
| 45 using views::ImageButton; | 46 using views::ImageButton; |
| 46 using views::Label; | 47 using views::Label; |
| 47 using views::MenuConfig; | 48 using views::MenuConfig; |
| 48 using views::MenuItemView; | 49 using views::MenuItemView; |
| (...skipping 509 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 558 | 559 |
| 559 // Width given to |zoom_label_|. This is the width at 100%. | 560 // Width given to |zoom_label_|. This is the width at 100%. |
| 560 int zoom_label_width_; | 561 int zoom_label_width_; |
| 561 | 562 |
| 562 DISALLOW_COPY_AND_ASSIGN(ZoomView); | 563 DISALLOW_COPY_AND_ASSIGN(ZoomView); |
| 563 }; | 564 }; |
| 564 | 565 |
| 565 // WrenchMenu ------------------------------------------------------------------ | 566 // WrenchMenu ------------------------------------------------------------------ |
| 566 | 567 |
| 567 WrenchMenu::WrenchMenu(Browser* browser) | 568 WrenchMenu::WrenchMenu(Browser* browser) |
| 568 : browser_(browser), | 569 : root_(NULL), |
| 570 browser_(browser), |
| 569 selected_menu_model_(NULL), | 571 selected_menu_model_(NULL), |
| 570 selected_index_(0), | 572 selected_index_(0), |
| 571 bookmark_menu_(NULL), | 573 bookmark_menu_(NULL), |
| 572 first_bookmark_command_id_(0) { | 574 first_bookmark_command_id_(0) { |
| 573 } | 575 } |
| 574 | 576 |
| 577 WrenchMenu::~WrenchMenu() { |
| 578 if (bookmark_menu_delegate_.get()) { |
| 579 BookmarkModel* model = browser_->profile()->GetBookmarkModel(); |
| 580 if (model) |
| 581 model->RemoveObserver(this); |
| 582 } |
| 583 } |
| 584 |
| 575 void WrenchMenu::Init(ui::MenuModel* model) { | 585 void WrenchMenu::Init(ui::MenuModel* model) { |
| 576 DCHECK(!root_.get()); | 586 DCHECK(!root_); |
| 577 root_.reset(new MenuItemView(this)); | 587 root_ = new MenuItemView(this); |
| 578 root_->set_has_icons(true); // We have checks, radios and icons, set this | 588 root_->set_has_icons(true); // We have checks, radios and icons, set this |
| 579 // so we get the taller menu style. | 589 // so we get the taller menu style. |
| 580 int next_id = 1; | 590 int next_id = 1; |
| 581 PopulateMenu(root_.get(), model, &next_id); | 591 PopulateMenu(root_, model, &next_id); |
| 582 first_bookmark_command_id_ = next_id + 1; | 592 first_bookmark_command_id_ = next_id + 1; |
| 593 menu_runner_.reset(new views::MenuRunner(root_)); |
| 583 } | 594 } |
| 584 | 595 |
| 585 void WrenchMenu::RunMenu(views::MenuButton* host) { | 596 void WrenchMenu::RunMenu(views::MenuButton* host) { |
| 586 // Up the ref count while the menu is displaying. This way if the window is | |
| 587 // deleted while we're running we won't prematurely delete the menu. | |
| 588 // TODO(sky): fix this, the menu should really take ownership of the menu | |
| 589 // (57890). | |
| 590 scoped_refptr<WrenchMenu> dont_delete_while_running(this); | |
| 591 gfx::Point screen_loc; | 597 gfx::Point screen_loc; |
| 592 views::View::ConvertPointToScreen(host, &screen_loc); | 598 views::View::ConvertPointToScreen(host, &screen_loc); |
| 593 gfx::Rect bounds(screen_loc, host->size()); | 599 gfx::Rect bounds(screen_loc, host->size()); |
| 594 UserMetrics::RecordAction(UserMetricsAction("ShowAppMenu")); | 600 UserMetrics::RecordAction(UserMetricsAction("ShowAppMenu")); |
| 595 root_->RunMenuAt(host->GetWidget(), host, bounds, | 601 if (menu_runner_->RunMenuAt(host->GetWidget(), host, bounds, |
| 596 MenuItemView::TOPRIGHT, true); | 602 MenuItemView::TOPRIGHT, views::MenuRunner::HAS_MNEMONICS) == |
| 603 views::MenuRunner::MENU_DELETED) |
| 604 return; |
| 597 if (bookmark_menu_delegate_.get()) { | 605 if (bookmark_menu_delegate_.get()) { |
| 598 BookmarkModel* model = browser_->profile()->GetBookmarkModel(); | 606 BookmarkModel* model = browser_->profile()->GetBookmarkModel(); |
| 599 if (model) | 607 if (model) |
| 600 model->RemoveObserver(this); | 608 model->RemoveObserver(this); |
| 601 } | 609 } |
| 602 if (selected_menu_model_) | 610 if (selected_menu_model_) |
| 603 selected_menu_model_->ActivatedAt(selected_index_); | 611 selected_menu_model_->ActivatedAt(selected_index_); |
| 604 } | 612 } |
| 605 | 613 |
| 606 std::wstring WrenchMenu::GetTooltipText(int id, | 614 std::wstring WrenchMenu::GetTooltipText(int id, |
| (...skipping 151 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 758 if (menu == bookmark_menu_) | 766 if (menu == bookmark_menu_) |
| 759 CreateBookmarkMenu(); | 767 CreateBookmarkMenu(); |
| 760 } | 768 } |
| 761 | 769 |
| 762 void WrenchMenu::BookmarkModelChanged() { | 770 void WrenchMenu::BookmarkModelChanged() { |
| 763 DCHECK(bookmark_menu_delegate_.get()); | 771 DCHECK(bookmark_menu_delegate_.get()); |
| 764 if (!bookmark_menu_delegate_->is_mutating_model()) | 772 if (!bookmark_menu_delegate_->is_mutating_model()) |
| 765 root_->Cancel(); | 773 root_->Cancel(); |
| 766 } | 774 } |
| 767 | 775 |
| 768 WrenchMenu::~WrenchMenu() { | |
| 769 } | |
| 770 | |
| 771 void WrenchMenu::PopulateMenu(MenuItemView* parent, | 776 void WrenchMenu::PopulateMenu(MenuItemView* parent, |
| 772 MenuModel* model, | 777 MenuModel* model, |
| 773 int* next_id) { | 778 int* next_id) { |
| 774 int index_offset = model->GetFirstItemIndex(NULL); | 779 int index_offset = model->GetFirstItemIndex(NULL); |
| 775 for (int i = 0, max = model->GetItemCount(); i < max; ++i) { | 780 for (int i = 0, max = model->GetItemCount(); i < max; ++i) { |
| 776 int index = i + index_offset; | 781 int index = i + index_offset; |
| 777 | 782 |
| 778 MenuItemView* item = | 783 MenuItemView* item = |
| 779 AppendMenuItem(parent, model, index, model->GetTypeAt(index), next_id); | 784 AppendMenuItem(parent, model, index, model->GetTypeAt(index), next_id); |
| 780 | 785 |
| (...skipping 78 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 859 browser_->window()->GetNativeHandle()); | 864 browser_->window()->GetNativeHandle()); |
| 860 bookmark_menu_delegate_.reset( | 865 bookmark_menu_delegate_.reset( |
| 861 new BookmarkMenuDelegate(browser_->profile(), | 866 new BookmarkMenuDelegate(browser_->profile(), |
| 862 NULL, | 867 NULL, |
| 863 parent, | 868 parent, |
| 864 first_bookmark_command_id_)); | 869 first_bookmark_command_id_)); |
| 865 bookmark_menu_delegate_->Init( | 870 bookmark_menu_delegate_->Init( |
| 866 this, bookmark_menu_, model->bookmark_bar_node(), 0, | 871 this, bookmark_menu_, model->bookmark_bar_node(), 0, |
| 867 BookmarkMenuDelegate::SHOW_OTHER_FOLDER); | 872 BookmarkMenuDelegate::SHOW_OTHER_FOLDER); |
| 868 } | 873 } |
| OLD | NEW |