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 "chrome/browser/ui/views/toolbar/app_menu.h" | 5 #include "chrome/browser/ui/views/toolbar/app_menu.h" |
| 6 | 6 |
| 7 #include <stdint.h> | 7 #include <stdint.h> |
| 8 | 8 |
| 9 #include <algorithm> | 9 #include <algorithm> |
| 10 #include <cmath> | 10 #include <cmath> |
| 11 #include <set> | 11 #include <set> |
| 12 | 12 |
| 13 #include "base/i18n/number_formatting.h" | |
| 13 #include "base/macros.h" | 14 #include "base/macros.h" |
| 14 #include "base/metrics/histogram.h" | 15 #include "base/metrics/histogram.h" |
| 15 #include "base/strings/string_number_conversions.h" | |
| 16 #include "base/strings/utf_string_conversions.h" | 16 #include "base/strings/utf_string_conversions.h" |
| 17 #include "build/build_config.h" | 17 #include "build/build_config.h" |
| 18 #include "chrome/app/chrome_command_ids.h" | 18 #include "chrome/app/chrome_command_ids.h" |
| 19 #include "chrome/browser/bookmarks/bookmark_model_factory.h" | 19 #include "chrome/browser/bookmarks/bookmark_model_factory.h" |
| 20 #include "chrome/browser/bookmarks/bookmark_stats.h" | 20 #include "chrome/browser/bookmarks/bookmark_stats.h" |
| 21 #include "chrome/browser/chrome_notification_types.h" | 21 #include "chrome/browser/chrome_notification_types.h" |
| 22 #include "chrome/browser/profiles/profile.h" | 22 #include "chrome/browser/profiles/profile.h" |
| 23 #include "chrome/browser/search/search.h" | 23 #include "chrome/browser/search/search.h" |
| 24 #include "chrome/browser/ui/browser.h" | 24 #include "chrome/browser/ui/browser.h" |
| 25 #include "chrome/browser/ui/browser_window.h" | 25 #include "chrome/browser/ui/browser_window.h" |
| (...skipping 493 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 519 ui_zoom::ZoomEventManager::GetForBrowserContext( | 519 ui_zoom::ZoomEventManager::GetForBrowserContext( |
| 520 menu->browser_->profile()) | 520 menu->browser_->profile()) |
| 521 ->AddZoomLevelChangedCallback( | 521 ->AddZoomLevelChangedCallback( |
| 522 base::Bind(&AppMenu::ZoomView::OnZoomLevelChanged, | 522 base::Bind(&AppMenu::ZoomView::OnZoomLevelChanged, |
| 523 base::Unretained(this))); | 523 base::Unretained(this))); |
| 524 | 524 |
| 525 decrement_button_ = CreateButtonWithAccName( | 525 decrement_button_ = CreateButtonWithAccName( |
| 526 IDS_ZOOM_MINUS2, InMenuButtonBackground::LEFT_BUTTON, | 526 IDS_ZOOM_MINUS2, InMenuButtonBackground::LEFT_BUTTON, |
| 527 decrement_index, IDS_ACCNAME_ZOOM_MINUS2); | 527 decrement_index, IDS_ACCNAME_ZOOM_MINUS2); |
| 528 | 528 |
| 529 zoom_label_ = new Label( | 529 zoom_label_ = new Label(base::FormatPercent(100)); |
| 530 l10n_util::GetStringFUTF16Int(IDS_ZOOM_PERCENT, 100)); | |
|
jungshik at Google
2016/05/17 23:58:43
Please, drop IDS_ZOOM_PERCENT from a grd file.
Greg Levin
2016/05/18 21:33:44
Done.
| |
| 531 zoom_label_->SetAutoColorReadabilityEnabled(false); | 530 zoom_label_->SetAutoColorReadabilityEnabled(false); |
| 532 zoom_label_->SetHorizontalAlignment(gfx::ALIGN_RIGHT); | 531 zoom_label_->SetHorizontalAlignment(gfx::ALIGN_RIGHT); |
| 533 | 532 |
| 534 InMenuButtonBackground* center_bg = | 533 InMenuButtonBackground* center_bg = |
| 535 new InMenuButtonBackground(InMenuButtonBackground::RIGHT_BUTTON); | 534 new InMenuButtonBackground(InMenuButtonBackground::RIGHT_BUTTON); |
| 536 zoom_label_->set_background(center_bg); | 535 zoom_label_->set_background(center_bg); |
| 537 | 536 |
| 538 AddChildView(zoom_label_); | 537 AddChildView(zoom_label_); |
| 539 zoom_label_max_width_valid_ = false; | 538 zoom_label_max_width_valid_ = false; |
| 540 | 539 |
| (...skipping 123 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 664 if (selected_tab) { | 663 if (selected_tab) { |
| 665 auto zoom_controller = | 664 auto zoom_controller = |
| 666 ui_zoom::ZoomController::FromWebContents(selected_tab); | 665 ui_zoom::ZoomController::FromWebContents(selected_tab); |
| 667 if (zoom_controller) | 666 if (zoom_controller) |
| 668 zoom = zoom_controller->GetZoomPercent(); | 667 zoom = zoom_controller->GetZoomPercent(); |
| 669 increment_button_->SetEnabled(zoom < | 668 increment_button_->SetEnabled(zoom < |
| 670 selected_tab->GetMaximumZoomPercent()); | 669 selected_tab->GetMaximumZoomPercent()); |
| 671 decrement_button_->SetEnabled(zoom > | 670 decrement_button_->SetEnabled(zoom > |
| 672 selected_tab->GetMinimumZoomPercent()); | 671 selected_tab->GetMinimumZoomPercent()); |
| 673 } | 672 } |
| 674 zoom_label_->SetText( | 673 zoom_label_->SetText(base::FormatPercent(zoom)); |
| 675 l10n_util::GetStringFUTF16Int(IDS_ZOOM_PERCENT, zoom)); | |
| 676 | |
| 677 zoom_label_max_width_valid_ = false; | 674 zoom_label_max_width_valid_ = false; |
| 678 } | 675 } |
| 679 | 676 |
| 680 // Returns the max width the zoom string can be. | 677 // Returns the max width the zoom string can be. |
| 681 int ZoomLabelMaxWidth() const { | 678 int ZoomLabelMaxWidth() const { |
| 682 if (!zoom_label_max_width_valid_) { | 679 if (!zoom_label_max_width_valid_) { |
| 683 const gfx::FontList& font_list = zoom_label_->font_list(); | 680 const gfx::FontList& font_list = zoom_label_->font_list(); |
| 684 int border_width = zoom_label_->border() | 681 int border_width = zoom_label_->border() |
| 685 ? zoom_label_->border()->GetInsets().width() | 682 ? zoom_label_->border()->GetInsets().width() |
| 686 : 0; | 683 : 0; |
| 687 | 684 |
| 688 int max_w = 0; | 685 int max_w = 0; |
| 689 | 686 |
| 690 WebContents* selected_tab = GetActiveWebContents(); | 687 WebContents* selected_tab = GetActiveWebContents(); |
| 691 if (selected_tab) { | 688 if (selected_tab) { |
| 692 auto zoom_controller = | 689 auto zoom_controller = |
| 693 ui_zoom::ZoomController::FromWebContents(selected_tab); | 690 ui_zoom::ZoomController::FromWebContents(selected_tab); |
| 694 DCHECK(zoom_controller); | 691 DCHECK(zoom_controller); |
| 695 // Enumerate all zoom factors that can be used in PageZoom::Zoom. | 692 // Enumerate all zoom factors that can be used in PageZoom::Zoom. |
| 696 std::vector<double> zoom_factors = ui_zoom::PageZoom::PresetZoomFactors( | 693 std::vector<double> zoom_factors = ui_zoom::PageZoom::PresetZoomFactors( |
| 697 zoom_controller->GetZoomPercent()); | 694 zoom_controller->GetZoomPercent()); |
| 698 for (auto zoom : zoom_factors) { | 695 for (auto zoom : zoom_factors) { |
| 699 int w = gfx::GetStringWidth( | 696 int w = gfx::GetStringWidth( |
| 700 l10n_util::GetStringFUTF16Int(IDS_ZOOM_PERCENT, | 697 base::FormatPercent(static_cast<int>(zoom * 100 + 0.5)), |
|
Peter Kasting
2016/05/18 02:37:25
Use std::round().
Greg Levin
2016/05/18 21:33:44
Done.
| |
| 701 static_cast<int>(zoom * 100 + 0.5)), | |
| 702 font_list); | 698 font_list); |
| 703 max_w = std::max(w, max_w); | 699 max_w = std::max(w, max_w); |
| 704 } | 700 } |
| 705 } else { | 701 } else { |
| 706 max_w = gfx::GetStringWidth( | 702 max_w = gfx::GetStringWidth(base::FormatPercent(100), font_list); |
| 707 l10n_util::GetStringFUTF16Int(IDS_ZOOM_PERCENT, 100), font_list); | |
| 708 } | 703 } |
| 709 zoom_label_max_width_ = max_w + border_width; | 704 zoom_label_max_width_ = max_w + border_width; |
| 710 | 705 |
| 711 zoom_label_max_width_valid_ = true; | 706 zoom_label_max_width_valid_ = true; |
| 712 } | 707 } |
| 713 return zoom_label_max_width_; | 708 return zoom_label_max_width_; |
| 714 } | 709 } |
| 715 | 710 |
| 716 // Index of the fullscreen menu item in the model. | 711 // Index of the fullscreen menu item in the model. |
| 717 const int fullscreen_index_; | 712 const int fullscreen_index_; |
| (...skipping 571 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1289 0, | 1284 0, |
| 1290 BookmarkMenuDelegate::SHOW_PERMANENT_FOLDERS, | 1285 BookmarkMenuDelegate::SHOW_PERMANENT_FOLDERS, |
| 1291 BOOKMARK_LAUNCH_LOCATION_APP_MENU); | 1286 BOOKMARK_LAUNCH_LOCATION_APP_MENU); |
| 1292 } | 1287 } |
| 1293 | 1288 |
| 1294 int AppMenu::ModelIndexFromCommandId(int command_id) const { | 1289 int AppMenu::ModelIndexFromCommandId(int command_id) const { |
| 1295 CommandIDToEntry::const_iterator ix = command_id_to_entry_.find(command_id); | 1290 CommandIDToEntry::const_iterator ix = command_id_to_entry_.find(command_id); |
| 1296 DCHECK(ix != command_id_to_entry_.end()); | 1291 DCHECK(ix != command_id_to_entry_.end()); |
| 1297 return ix->second.second; | 1292 return ix->second.second; |
| 1298 } | 1293 } |
| OLD | NEW |