| 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/frame/browser_frame.h" | 5 #include "chrome/browser/ui/views/frame/browser_frame.h" |
| 6 | 6 |
| 7 #include "ash/shell.h" | 7 #include "ash/shell.h" |
| 8 #include "base/command_line.h" | 8 #include "base/command_line.h" |
| 9 #include "base/debug/leak_annotations.h" | 9 #include "base/debug/leak_annotations.h" |
| 10 #include "base/i18n/rtl.h" | 10 #include "base/i18n/rtl.h" |
| 11 #include "chrome/browser/app_mode/app_mode_utils.h" | 11 #include "chrome/browser/app_mode/app_mode_utils.h" |
| 12 #include "chrome/browser/themes/theme_service.h" | 12 #include "chrome/browser/themes/theme_service.h" |
| 13 #include "chrome/browser/themes/theme_service_factory.h" | 13 #include "chrome/browser/themes/theme_service_factory.h" |
| 14 #include "chrome/browser/ui/browser.h" | 14 #include "chrome/browser/ui/browser.h" |
| 15 #include "chrome/browser/ui/browser_list.h" | 15 #include "chrome/browser/ui/browser_list.h" |
| 16 #include "chrome/browser/ui/browser_window_state.h" | 16 #include "chrome/browser/ui/browser_window_state.h" |
| 17 #include "chrome/browser/ui/views/frame/browser_non_client_frame_view.h" | 17 #include "chrome/browser/ui/views/frame/browser_non_client_frame_view.h" |
| 18 #include "chrome/browser/ui/views/frame/browser_root_view.h" | 18 #include "chrome/browser/ui/views/frame/browser_root_view.h" |
| 19 #include "chrome/browser/ui/views/frame/browser_view.h" | 19 #include "chrome/browser/ui/views/frame/browser_view.h" |
| 20 #include "chrome/browser/ui/views/frame/immersive_mode_controller.h" | 20 #include "chrome/browser/ui/views/frame/immersive_mode_controller.h" |
| 21 #include "chrome/browser/ui/views/frame/native_browser_frame.h" | 21 #include "chrome/browser/ui/views/frame/native_browser_frame.h" |
| 22 #include "chrome/browser/ui/views/frame/native_browser_frame_factory.h" | 22 #include "chrome/browser/ui/views/frame/native_browser_frame_factory.h" |
| 23 #include "chrome/browser/ui/views/frame/system_menu_model_builder.h" | 23 #include "chrome/browser/ui/views/frame/system_menu_model_builder.h" |
| 24 #include "chrome/browser/ui/views/frame/top_container_view.h" | 24 #include "chrome/browser/ui/views/frame/top_container_view.h" |
| 25 #include "chrome/browser/web_applications/web_app.h" | 25 #include "chrome/browser/web_applications/web_app.h" |
| 26 #include "chrome/common/chrome_switches.h" | 26 #include "chrome/common/chrome_switches.h" |
| 27 #include "chrome/common/pref_names.h" |
| 27 #include "ui/aura/root_window.h" | 28 #include "ui/aura/root_window.h" |
| 28 #include "ui/aura/window.h" | 29 #include "ui/aura/window.h" |
| 29 #include "ui/base/hit_test.h" | 30 #include "ui/base/hit_test.h" |
| 30 #include "ui/base/theme_provider.h" | 31 #include "ui/base/theme_provider.h" |
| 31 #include "ui/gfx/font_list.h" | 32 #include "ui/gfx/font_list.h" |
| 32 #include "ui/gfx/screen.h" | 33 #include "ui/gfx/screen.h" |
| 33 #include "ui/views/controls/menu/menu_runner.h" | 34 #include "ui/views/controls/menu/menu_runner.h" |
| 34 #include "ui/views/widget/native_widget.h" | 35 #include "ui/views/widget/native_widget.h" |
| 35 | 36 |
| 36 #if defined(OS_WIN) && !defined(USE_AURA) | 37 #if defined(OS_WIN) && !defined(USE_AURA) |
| (...skipping 38 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 75 static const gfx::FontList* title_font_list = new gfx::FontList(); | 76 static const gfx::FontList* title_font_list = new gfx::FontList(); |
| 76 #else | 77 #else |
| 77 static const gfx::FontList* title_font_list = | 78 static const gfx::FontList* title_font_list = |
| 78 new gfx::FontList(views::NativeWidgetWin::GetWindowTitleFontList()); | 79 new gfx::FontList(views::NativeWidgetWin::GetWindowTitleFontList()); |
| 79 #endif | 80 #endif |
| 80 ANNOTATE_LEAKING_OBJECT_PTR(title_font_list); | 81 ANNOTATE_LEAKING_OBJECT_PTR(title_font_list); |
| 81 return *title_font_list; | 82 return *title_font_list; |
| 82 } | 83 } |
| 83 | 84 |
| 84 void BrowserFrame::InitBrowserFrame() { | 85 void BrowserFrame::InitBrowserFrame() { |
| 86 use_custom_frame_pref_.Init( |
| 87 prefs::kUseCustomChromeFrame, |
| 88 browser_view_->browser()->profile()->GetPrefs(), |
| 89 base::Bind(&BrowserFrame::OnUseCustomChromeFrameChanged, |
| 90 base::Unretained(this))); |
| 91 |
| 85 native_browser_frame_ = | 92 native_browser_frame_ = |
| 86 NativeBrowserFrameFactory::CreateNativeBrowserFrame(this, browser_view_); | 93 NativeBrowserFrameFactory::CreateNativeBrowserFrame(this, browser_view_); |
| 87 views::Widget::InitParams params; | 94 views::Widget::InitParams params; |
| 88 params.delegate = browser_view_; | 95 params.delegate = browser_view_; |
| 89 params.native_widget = native_browser_frame_->AsNativeWidget(); | 96 params.native_widget = native_browser_frame_->AsNativeWidget(); |
| 90 if (browser_view_->browser()->is_type_tabbed()) { | 97 if (browser_view_->browser()->is_type_tabbed()) { |
| 91 // Typed panel/popup can only return a size once the widget has been | 98 // Typed panel/popup can only return a size once the widget has been |
| 92 // created. | 99 // created. |
| 93 chrome::GetSavedWindowBoundsAndShowState(browser_view_->browser(), | 100 chrome::GetSavedWindowBoundsAndShowState(browser_view_->browser(), |
| 94 ¶ms.bounds, | 101 ¶ms.bounds, |
| (...skipping 29 matching lines...) Expand all Loading... |
| 124 // file. | 131 // file. |
| 125 const std::string user_data_dir = | 132 const std::string user_data_dir = |
| 126 command_line.GetSwitchValueNative(switches::kUserDataDir); | 133 command_line.GetSwitchValueNative(switches::kUserDataDir); |
| 127 params.wm_class_name += " (" + user_data_dir + ")"; | 134 params.wm_class_name += " (" + user_data_dir + ")"; |
| 128 } | 135 } |
| 129 const char kX11WindowRoleBrowser[] = "browser"; | 136 const char kX11WindowRoleBrowser[] = "browser"; |
| 130 const char kX11WindowRolePopup[] = "pop-up"; | 137 const char kX11WindowRolePopup[] = "pop-up"; |
| 131 params.wm_role_name = browser_view_->browser()->is_type_tabbed() ? | 138 params.wm_role_name = browser_view_->browser()->is_type_tabbed() ? |
| 132 std::string(kX11WindowRoleBrowser) : std::string(kX11WindowRolePopup); | 139 std::string(kX11WindowRoleBrowser) : std::string(kX11WindowRolePopup); |
| 133 | 140 |
| 134 params.remove_standard_frame = | 141 params.remove_standard_frame = UseCustomFrame(); |
| 135 !command_line.HasSwitch(switches::kUseSystemTitleBar); | |
| 136 #endif // defined(OS_LINUX) | 142 #endif // defined(OS_LINUX) |
| 137 | 143 |
| 138 Init(params); | 144 Init(params); |
| 139 | 145 |
| 140 if (!native_browser_frame_->UsesNativeSystemMenu()) { | 146 if (!native_browser_frame_->UsesNativeSystemMenu()) { |
| 141 DCHECK(non_client_view()); | 147 DCHECK(non_client_view()); |
| 142 non_client_view()->set_context_menu_controller(this); | 148 non_client_view()->set_context_menu_controller(this); |
| 143 } | 149 } |
| 144 } | 150 } |
| 145 | 151 |
| (...skipping 19 matching lines...) Expand all Loading... |
| 165 } | 171 } |
| 166 | 172 |
| 167 void BrowserFrame::UpdateThrobber(bool running) { | 173 void BrowserFrame::UpdateThrobber(bool running) { |
| 168 browser_frame_view_->UpdateThrobber(running); | 174 browser_frame_view_->UpdateThrobber(running); |
| 169 } | 175 } |
| 170 | 176 |
| 171 views::View* BrowserFrame::GetFrameView() const { | 177 views::View* BrowserFrame::GetFrameView() const { |
| 172 return browser_frame_view_; | 178 return browser_frame_view_; |
| 173 } | 179 } |
| 174 | 180 |
| 181 bool BrowserFrame::UseCustomFrame() const { |
| 182 return use_custom_frame_pref_.GetValue(); |
| 183 } |
| 184 |
| 175 /////////////////////////////////////////////////////////////////////////////// | 185 /////////////////////////////////////////////////////////////////////////////// |
| 176 // BrowserFrame, views::Widget overrides: | 186 // BrowserFrame, views::Widget overrides: |
| 177 | 187 |
| 178 views::internal::RootView* BrowserFrame::CreateRootView() { | 188 views::internal::RootView* BrowserFrame::CreateRootView() { |
| 179 root_view_ = new BrowserRootView(browser_view_, this); | 189 root_view_ = new BrowserRootView(browser_view_, this); |
| 180 return root_view_; | 190 return root_view_; |
| 181 } | 191 } |
| 182 | 192 |
| 183 views::NonClientFrameView* BrowserFrame::CreateNonClientFrameView() { | 193 views::NonClientFrameView* BrowserFrame::CreateNonClientFrameView() { |
| 184 browser_frame_view_ = | 194 browser_frame_view_ = |
| (...skipping 87 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 272 | 282 |
| 273 NewAvatarButton* BrowserFrame::GetNewAvatarMenuButton() { | 283 NewAvatarButton* BrowserFrame::GetNewAvatarMenuButton() { |
| 274 return browser_frame_view_->new_avatar_button(); | 284 return browser_frame_view_->new_avatar_button(); |
| 275 } | 285 } |
| 276 | 286 |
| 277 #if !defined(OS_WIN) || defined(USE_AURA) | 287 #if !defined(OS_WIN) || defined(USE_AURA) |
| 278 bool BrowserFrame::ShouldLeaveOffsetNearTopBorder() { | 288 bool BrowserFrame::ShouldLeaveOffsetNearTopBorder() { |
| 279 return !IsMaximized(); | 289 return !IsMaximized(); |
| 280 } | 290 } |
| 281 #endif // OS_WIN | 291 #endif // OS_WIN |
| 292 |
| 293 void BrowserFrame::OnUseCustomChromeFrameChanged() { |
| 294 // Tell the window manager to add or remove system borders. |
| 295 set_frame_type(UseCustomFrame() ? Widget::FRAME_TYPE_DEFAULT |
| 296 : Widget::FRAME_TYPE_FORCE_NATIVE); |
| 297 FrameTypeChanged(); |
| 298 } |
| OLD | NEW |