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))); | |
msw
2014/02/11 19:32:59
Using base::Unretained is generally unsafe. Is the
Matt Giuca
2014/02/12 01:09:18
Good question.
It looks like your last sentence i
| |
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 | |
msw
2014/02/11 19:32:59
If the default is force native, won't this toggle
Matt Giuca
2014/02/12 01:09:18
The default is force custom, with a weird conditio
| |
296 : Widget::FRAME_TYPE_FORCE_NATIVE); | |
297 FrameTypeChanged(); | |
298 } | |
OLD | NEW |