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" |
tapted
2014/11/04 02:33:42
remove?
Andre
2014/11/05 02:04:22
Needed for ash::Shell:GetInstance().
Moved inside
| |
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/ash/ash_util.h" | 14 #include "chrome/browser/ui/ash/ash_util.h" |
tapted
2014/11/04 02:33:42
remove? or guard in #if ash
Andre
2014/11/05 02:04:23
No longer needed, deleted.
| |
15 #include "chrome/browser/ui/browser.h" | 15 #include "chrome/browser/ui/browser.h" |
16 #include "chrome/browser/ui/browser_list.h" | 16 #include "chrome/browser/ui/browser_list.h" |
17 #include "chrome/browser/ui/browser_window_state.h" | 17 #include "chrome/browser/ui/browser_window_state.h" |
18 #include "chrome/browser/ui/views/frame/browser_non_client_frame_view.h" | 18 #include "chrome/browser/ui/views/frame/browser_non_client_frame_view.h" |
19 #include "chrome/browser/ui/views/frame/browser_root_view.h" | 19 #include "chrome/browser/ui/views/frame/browser_root_view.h" |
20 #include "chrome/browser/ui/views/frame/browser_view.h" | 20 #include "chrome/browser/ui/views/frame/browser_view.h" |
21 #include "chrome/browser/ui/views/frame/immersive_mode_controller.h" | 21 #include "chrome/browser/ui/views/frame/immersive_mode_controller.h" |
22 #include "chrome/browser/ui/views/frame/native_browser_frame.h" | 22 #include "chrome/browser/ui/views/frame/native_browser_frame.h" |
23 #include "chrome/browser/ui/views/frame/native_browser_frame_factory.h" | 23 #include "chrome/browser/ui/views/frame/native_browser_frame_factory.h" |
24 #include "chrome/browser/ui/views/frame/system_menu_model_builder.h" | 24 #include "chrome/browser/ui/views/frame/system_menu_model_builder.h" |
25 #include "chrome/browser/ui/views/frame/top_container_view.h" | 25 #include "chrome/browser/ui/views/frame/top_container_view.h" |
26 #include "chrome/browser/web_applications/web_app.h" | 26 #include "chrome/browser/web_applications/web_app.h" |
27 #include "chrome/common/chrome_switches.h" | 27 #include "chrome/common/chrome_switches.h" |
28 #include "chrome/common/pref_names.h" | 28 #include "chrome/common/pref_names.h" |
29 #include "ui/aura/window.h" | 29 #include "ui/aura/window.h" |
tapted
2014/11/04 02:33:42
remove?
Andre
2014/11/05 02:04:22
Removed.
| |
30 #include "ui/aura/window_event_dispatcher.h" | 30 #include "ui/aura/window_event_dispatcher.h" |
tapted
2014/11/04 02:33:42
remove?
Andre
2014/11/05 02:04:23
Removed.
| |
31 #include "ui/base/hit_test.h" | 31 #include "ui/base/hit_test.h" |
32 #include "ui/base/theme_provider.h" | 32 #include "ui/base/theme_provider.h" |
33 #include "ui/events/event_handler.h" | 33 #include "ui/events/event_handler.h" |
34 #include "ui/gfx/font_list.h" | 34 #include "ui/gfx/font_list.h" |
35 #include "ui/gfx/screen.h" | 35 #include "ui/gfx/screen.h" |
36 #include "ui/views/controls/menu/menu_runner.h" | 36 #include "ui/views/controls/menu/menu_runner.h" |
37 #include "ui/views/widget/native_widget.h" | 37 #include "ui/views/widget/native_widget.h" |
38 | 38 |
39 #if defined(OS_LINUX) && !defined(OS_CHROMEOS) | 39 #if defined(OS_LINUX) && !defined(OS_CHROMEOS) |
40 #include "chrome/browser/shell_integration_linux.h" | 40 #include "chrome/browser/shell_integration_linux.h" |
(...skipping 14 matching lines...) Expand all Loading... | |
55 : native_browser_frame_(NULL), | 55 : native_browser_frame_(NULL), |
56 root_view_(NULL), | 56 root_view_(NULL), |
57 browser_frame_view_(NULL), | 57 browser_frame_view_(NULL), |
58 browser_view_(browser_view), | 58 browser_view_(browser_view), |
59 theme_provider_(ThemeServiceFactory::GetForProfile( | 59 theme_provider_(ThemeServiceFactory::GetForProfile( |
60 browser_view_->browser()->profile())) { | 60 browser_view_->browser()->profile())) { |
61 browser_view_->set_frame(this); | 61 browser_view_->set_frame(this); |
62 set_is_secondary_widget(false); | 62 set_is_secondary_widget(false); |
63 // Don't focus anything on creation, selecting a tab will set the focus. | 63 // Don't focus anything on creation, selecting a tab will set the focus. |
64 set_focus_on_creation(false); | 64 set_focus_on_creation(false); |
65 | |
66 #if defined(USE_X11) | |
67 browser_command_handler_.reset( | |
68 new BrowserCommandHandlerX11(browser_view_->browser())); | |
69 #endif | |
70 } | 65 } |
71 | 66 |
72 BrowserFrame::~BrowserFrame() { | 67 BrowserFrame::~BrowserFrame() { |
73 if (browser_command_handler_ && GetNativeView()) | |
74 GetNativeView()->RemovePreTargetHandler(browser_command_handler_.get()); | |
75 } | 68 } |
76 | 69 |
77 // static | 70 // static |
78 const gfx::FontList& BrowserFrame::GetTitleFontList() { | 71 const gfx::FontList& BrowserFrame::GetTitleFontList() { |
79 static const gfx::FontList* title_font_list = new gfx::FontList(); | 72 static const gfx::FontList* title_font_list = new gfx::FontList(); |
80 ANNOTATE_LEAKING_OBJECT_PTR(title_font_list); | 73 ANNOTATE_LEAKING_OBJECT_PTR(title_font_list); |
81 return *title_font_list; | 74 return *title_font_list; |
82 } | 75 } |
83 | 76 |
84 void BrowserFrame::InitBrowserFrame() { | 77 void BrowserFrame::InitBrowserFrame() { |
85 use_custom_frame_pref_.Init( | 78 use_custom_frame_pref_.Init( |
86 prefs::kUseCustomChromeFrame, | 79 prefs::kUseCustomChromeFrame, |
87 browser_view_->browser()->profile()->GetPrefs(), | 80 browser_view_->browser()->profile()->GetPrefs(), |
88 base::Bind(&BrowserFrame::OnUseCustomChromeFrameChanged, | 81 base::Bind(&BrowserFrame::OnUseCustomChromeFrameChanged, |
89 base::Unretained(this))); | 82 base::Unretained(this))); |
90 | 83 |
91 native_browser_frame_ = | 84 native_browser_frame_ = |
92 NativeBrowserFrameFactory::CreateNativeBrowserFrame(this, browser_view_); | 85 NativeBrowserFrameFactory::CreateNativeBrowserFrame(this, browser_view_); |
93 views::Widget::InitParams params; | 86 views::Widget::InitParams params; |
94 params.delegate = browser_view_; | 87 params.delegate = browser_view_; |
95 params.native_widget = native_browser_frame_->AsNativeWidget(); | 88 params.native_widget = native_browser_frame_->AsNativeWidget(); |
96 if (browser_view_->browser()->is_type_tabbed()) { | 89 if (browser_view_->browser()->is_type_tabbed()) { |
97 // Typed panel/popup can only return a size once the widget has been | 90 // Typed panel/popup can only return a size once the widget has been |
98 // created. | 91 // created. |
99 chrome::GetSavedWindowBoundsAndShowState(browser_view_->browser(), | 92 chrome::GetSavedWindowBoundsAndShowState(browser_view_->browser(), |
100 ¶ms.bounds, | 93 ¶ms.bounds, |
101 ¶ms.show_state); | 94 ¶ms.show_state); |
102 } | 95 } |
103 | 96 |
97 #if defined(USE_ASH) | |
104 if (browser_view_->browser()->host_desktop_type() == | 98 if (browser_view_->browser()->host_desktop_type() == |
tapted
2014/11/04 02:33:42
This feels out of place here... the condition is e
Andre
2014/11/05 02:04:23
Done.
| |
105 chrome::HOST_DESKTOP_TYPE_ASH || chrome::ShouldOpenAshOnStartup()) { | 99 chrome::HOST_DESKTOP_TYPE_ASH || chrome::ShouldOpenAshOnStartup()) { |
106 params.context = ash::Shell::GetPrimaryRootWindow(); | 100 params.context = ash::Shell::GetPrimaryRootWindow(); |
107 #if defined(OS_WIN) | 101 #if defined(OS_WIN) |
108 // If this window is under ASH on Windows, we need it to be translucent. | 102 // If this window is under ASH on Windows, we need it to be translucent. |
109 params.opacity = views::Widget::InitParams::TRANSLUCENT_WINDOW; | 103 params.opacity = views::Widget::InitParams::TRANSLUCENT_WINDOW; |
110 #endif | 104 #endif |
111 } | 105 } |
106 #endif | |
112 | 107 |
113 #if defined(OS_LINUX) && !defined(OS_CHROMEOS) | 108 #if defined(OS_LINUX) && !defined(OS_CHROMEOS) |
114 // Set up a custom WM_CLASS for some sorts of window types. This allows | 109 // Set up a custom WM_CLASS for some sorts of window types. This allows |
115 // task switchers in X11 environments to distinguish between main browser | 110 // task switchers in X11 environments to distinguish between main browser |
116 // windows and e.g app windows. | 111 // windows and e.g app windows. |
117 const CommandLine& command_line = *CommandLine::ForCurrentProcess(); | 112 const CommandLine& command_line = *CommandLine::ForCurrentProcess(); |
118 const Browser& browser = *browser_view_->browser(); | 113 const Browser& browser = *browser_view_->browser(); |
119 params.wm_class_class = shell_integration_linux::GetProgramClassName(); | 114 params.wm_class_class = shell_integration_linux::GetProgramClassName(); |
120 params.wm_class_name = params.wm_class_class; | 115 params.wm_class_name = params.wm_class_class; |
121 if (browser.is_app() && !browser.is_devtools()) { | 116 if (browser.is_app() && !browser.is_devtools()) { |
(...skipping 19 matching lines...) Expand all Loading... | |
141 : Widget::FRAME_TYPE_FORCE_NATIVE); | 136 : Widget::FRAME_TYPE_FORCE_NATIVE); |
142 #endif // defined(OS_LINUX) | 137 #endif // defined(OS_LINUX) |
143 | 138 |
144 Init(params); | 139 Init(params); |
145 | 140 |
146 if (!native_browser_frame_->UsesNativeSystemMenu()) { | 141 if (!native_browser_frame_->UsesNativeSystemMenu()) { |
147 DCHECK(non_client_view()); | 142 DCHECK(non_client_view()); |
148 non_client_view()->set_context_menu_controller(this); | 143 non_client_view()->set_context_menu_controller(this); |
149 } | 144 } |
150 | 145 |
151 if (browser_command_handler_) | 146 #if defined(USE_X11) |
152 GetNativeWindow()->AddPreTargetHandler(browser_command_handler_.get()); | 147 browser_command_handler_.reset( |
148 new BrowserCommandHandlerX11(browser_view_->browser())); | |
149 #endif | |
153 } | 150 } |
154 | 151 |
155 void BrowserFrame::SetThemeProvider(scoped_ptr<ui::ThemeProvider> provider) { | 152 void BrowserFrame::SetThemeProvider(scoped_ptr<ui::ThemeProvider> provider) { |
156 owned_theme_provider_ = provider.Pass(); | 153 owned_theme_provider_ = provider.Pass(); |
157 theme_provider_ = owned_theme_provider_.get(); | 154 theme_provider_ = owned_theme_provider_.get(); |
158 } | 155 } |
159 | 156 |
160 int BrowserFrame::GetMinimizeButtonOffset() const { | 157 int BrowserFrame::GetMinimizeButtonOffset() const { |
161 return native_browser_frame_->GetMinimizeButtonOffset(); | 158 return native_browser_frame_->GetMinimizeButtonOffset(); |
162 } | 159 } |
(...skipping 143 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
306 bool BrowserFrame::ShouldLeaveOffsetNearTopBorder() { | 303 bool BrowserFrame::ShouldLeaveOffsetNearTopBorder() { |
307 return !IsMaximized(); | 304 return !IsMaximized(); |
308 } | 305 } |
309 | 306 |
310 void BrowserFrame::OnUseCustomChromeFrameChanged() { | 307 void BrowserFrame::OnUseCustomChromeFrameChanged() { |
311 // Tell the window manager to add or remove system borders. | 308 // Tell the window manager to add or remove system borders. |
312 set_frame_type(UseCustomFrame() ? Widget::FRAME_TYPE_FORCE_CUSTOM | 309 set_frame_type(UseCustomFrame() ? Widget::FRAME_TYPE_FORCE_CUSTOM |
313 : Widget::FRAME_TYPE_FORCE_NATIVE); | 310 : Widget::FRAME_TYPE_FORCE_NATIVE); |
314 FrameTypeChanged(); | 311 FrameTypeChanged(); |
315 } | 312 } |
OLD | NEW |