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" |
| 8 #include "base/command_line.h" |
7 #include "base/debug/leak_annotations.h" | 9 #include "base/debug/leak_annotations.h" |
8 #include "base/i18n/rtl.h" | 10 #include "base/i18n/rtl.h" |
9 #include "chrome/browser/app_mode/app_mode_utils.h" | 11 #include "chrome/browser/app_mode/app_mode_utils.h" |
10 #include "chrome/browser/themes/theme_service.h" | 12 #include "chrome/browser/themes/theme_service.h" |
11 #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" |
12 #include "chrome/browser/ui/browser.h" | 15 #include "chrome/browser/ui/browser.h" |
13 #include "chrome/browser/ui/browser_list.h" | 16 #include "chrome/browser/ui/browser_list.h" |
14 #include "chrome/browser/ui/browser_window_state.h" | 17 #include "chrome/browser/ui/browser_window_state.h" |
15 #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" |
16 #include "chrome/browser/ui/views/frame/browser_root_view.h" | 19 #include "chrome/browser/ui/views/frame/browser_root_view.h" |
17 #include "chrome/browser/ui/views/frame/browser_view.h" | 20 #include "chrome/browser/ui/views/frame/browser_view.h" |
18 #include "chrome/browser/ui/views/frame/immersive_mode_controller.h" | 21 #include "chrome/browser/ui/views/frame/immersive_mode_controller.h" |
19 #include "chrome/browser/ui/views/frame/native_browser_frame.h" | 22 #include "chrome/browser/ui/views/frame/native_browser_frame.h" |
20 #include "chrome/browser/ui/views/frame/native_browser_frame_factory.h" | 23 #include "chrome/browser/ui/views/frame/native_browser_frame_factory.h" |
21 #include "chrome/browser/ui/views/frame/system_menu_model_builder.h" | 24 #include "chrome/browser/ui/views/frame/system_menu_model_builder.h" |
22 #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" |
| 27 #include "chrome/common/chrome_switches.h" |
23 #include "chrome/common/pref_names.h" | 28 #include "chrome/common/pref_names.h" |
| 29 #include "ui/aura/window.h" |
| 30 #include "ui/aura/window_event_dispatcher.h" |
24 #include "ui/base/hit_test.h" | 31 #include "ui/base/hit_test.h" |
25 #include "ui/base/theme_provider.h" | 32 #include "ui/base/theme_provider.h" |
26 #include "ui/events/event_handler.h" | 33 #include "ui/events/event_handler.h" |
27 #include "ui/gfx/font_list.h" | 34 #include "ui/gfx/font_list.h" |
28 #include "ui/gfx/screen.h" | 35 #include "ui/gfx/screen.h" |
29 #include "ui/views/controls/menu/menu_runner.h" | 36 #include "ui/views/controls/menu/menu_runner.h" |
30 #include "ui/views/widget/native_widget.h" | 37 #include "ui/views/widget/native_widget.h" |
31 | 38 |
| 39 #if defined(OS_LINUX) && !defined(OS_CHROMEOS) |
| 40 #include "chrome/browser/shell_integration_linux.h" |
| 41 #endif |
| 42 |
32 #if defined(OS_CHROMEOS) | 43 #if defined(OS_CHROMEOS) |
33 #include "ash/session/session_state_delegate.h" | 44 #include "ash/session/session_state_delegate.h" |
34 #include "ash/shell.h" | |
35 #endif | 45 #endif |
36 | 46 |
37 #if defined(USE_X11) | 47 #if defined(USE_X11) |
38 #include "chrome/browser/ui/views/frame/browser_command_handler_x11.h" | 48 #include "chrome/browser/ui/views/frame/browser_command_handler_x11.h" |
39 #endif | 49 #endif |
40 | 50 |
41 //////////////////////////////////////////////////////////////////////////////// | 51 //////////////////////////////////////////////////////////////////////////////// |
42 // BrowserFrame, public: | 52 // BrowserFrame, public: |
43 | 53 |
44 BrowserFrame::BrowserFrame(BrowserView* browser_view) | 54 BrowserFrame::BrowserFrame(BrowserView* browser_view) |
45 : native_browser_frame_(NULL), | 55 : native_browser_frame_(NULL), |
46 root_view_(NULL), | 56 root_view_(NULL), |
47 browser_frame_view_(NULL), | 57 browser_frame_view_(NULL), |
48 browser_view_(browser_view), | 58 browser_view_(browser_view), |
49 theme_provider_(ThemeServiceFactory::GetForProfile( | 59 theme_provider_(ThemeServiceFactory::GetForProfile( |
50 browser_view_->browser()->profile())) { | 60 browser_view_->browser()->profile())) { |
51 browser_view_->set_frame(this); | 61 browser_view_->set_frame(this); |
52 set_is_secondary_widget(false); | 62 set_is_secondary_widget(false); |
53 // 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. |
54 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 |
55 } | 70 } |
56 | 71 |
57 BrowserFrame::~BrowserFrame() { | 72 BrowserFrame::~BrowserFrame() { |
| 73 if (browser_command_handler_ && GetNativeView()) |
| 74 GetNativeView()->RemovePreTargetHandler(browser_command_handler_.get()); |
58 } | 75 } |
59 | 76 |
60 // static | 77 // static |
61 const gfx::FontList& BrowserFrame::GetTitleFontList() { | 78 const gfx::FontList& BrowserFrame::GetTitleFontList() { |
62 static const gfx::FontList* title_font_list = new gfx::FontList(); | 79 static const gfx::FontList* title_font_list = new gfx::FontList(); |
63 ANNOTATE_LEAKING_OBJECT_PTR(title_font_list); | 80 ANNOTATE_LEAKING_OBJECT_PTR(title_font_list); |
64 return *title_font_list; | 81 return *title_font_list; |
65 } | 82 } |
66 | 83 |
67 void BrowserFrame::InitBrowserFrame() { | 84 void BrowserFrame::InitBrowserFrame() { |
68 use_custom_frame_pref_.Init( | 85 use_custom_frame_pref_.Init( |
69 prefs::kUseCustomChromeFrame, | 86 prefs::kUseCustomChromeFrame, |
70 browser_view_->browser()->profile()->GetPrefs(), | 87 browser_view_->browser()->profile()->GetPrefs(), |
71 base::Bind(&BrowserFrame::OnUseCustomChromeFrameChanged, | 88 base::Bind(&BrowserFrame::OnUseCustomChromeFrameChanged, |
72 base::Unretained(this))); | 89 base::Unretained(this))); |
73 | 90 |
74 native_browser_frame_ = | 91 native_browser_frame_ = |
75 NativeBrowserFrameFactory::CreateNativeBrowserFrame(this, browser_view_); | 92 NativeBrowserFrameFactory::CreateNativeBrowserFrame(this, browser_view_); |
76 views::Widget::InitParams params = native_browser_frame_->GetWidgetParams(); | 93 views::Widget::InitParams params; |
77 params.delegate = browser_view_; | 94 params.delegate = browser_view_; |
| 95 params.native_widget = native_browser_frame_->AsNativeWidget(); |
78 if (browser_view_->browser()->is_type_tabbed()) { | 96 if (browser_view_->browser()->is_type_tabbed()) { |
79 // Typed panel/popup can only return a size once the widget has been | 97 // Typed panel/popup can only return a size once the widget has been |
80 // created. | 98 // created. |
81 chrome::GetSavedWindowBoundsAndShowState(browser_view_->browser(), | 99 chrome::GetSavedWindowBoundsAndShowState(browser_view_->browser(), |
82 ¶ms.bounds, | 100 ¶ms.bounds, |
83 ¶ms.show_state); | 101 ¶ms.show_state); |
84 } | 102 } |
| 103 |
| 104 if (browser_view_->browser()->host_desktop_type() == |
| 105 chrome::HOST_DESKTOP_TYPE_ASH || chrome::ShouldOpenAshOnStartup()) { |
| 106 params.context = ash::Shell::GetPrimaryRootWindow(); |
| 107 #if defined(OS_WIN) |
| 108 // If this window is under ASH on Windows, we need it to be translucent. |
| 109 params.opacity = views::Widget::InitParams::TRANSLUCENT_WINDOW; |
| 110 #endif |
| 111 } |
| 112 |
| 113 #if defined(OS_LINUX) && !defined(OS_CHROMEOS) |
| 114 // 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 |
| 116 // windows and e.g app windows. |
| 117 const CommandLine& command_line = *CommandLine::ForCurrentProcess(); |
| 118 const Browser& browser = *browser_view_->browser(); |
| 119 params.wm_class_class = shell_integration_linux::GetProgramClassName(); |
| 120 params.wm_class_name = params.wm_class_class; |
| 121 if (browser.is_app() && !browser.is_devtools()) { |
| 122 // This window is a hosted app or v1 packaged app. |
| 123 // NOTE: v2 packaged app windows are created by ChromeNativeAppWindowViews. |
| 124 params.wm_class_name = web_app::GetWMClassFromAppName(browser.app_name()); |
| 125 } else if (command_line.HasSwitch(switches::kUserDataDir)) { |
| 126 // Set the class name to e.g. "Chrome (/tmp/my-user-data)". The |
| 127 // class name will show up in the alt-tab list in gnome-shell if |
| 128 // you're running a binary that doesn't have a matching .desktop |
| 129 // file. |
| 130 const std::string user_data_dir = |
| 131 command_line.GetSwitchValueNative(switches::kUserDataDir); |
| 132 params.wm_class_name += " (" + user_data_dir + ")"; |
| 133 } |
| 134 const char kX11WindowRoleBrowser[] = "browser"; |
| 135 const char kX11WindowRolePopup[] = "pop-up"; |
| 136 params.wm_role_name = browser_view_->browser()->is_type_tabbed() ? |
| 137 std::string(kX11WindowRoleBrowser) : std::string(kX11WindowRolePopup); |
| 138 |
85 params.remove_standard_frame = UseCustomFrame(); | 139 params.remove_standard_frame = UseCustomFrame(); |
86 set_frame_type(UseCustomFrame() ? Widget::FRAME_TYPE_FORCE_CUSTOM | 140 set_frame_type(UseCustomFrame() ? Widget::FRAME_TYPE_FORCE_CUSTOM |
87 : Widget::FRAME_TYPE_FORCE_NATIVE); | 141 : Widget::FRAME_TYPE_FORCE_NATIVE); |
| 142 #endif // defined(OS_LINUX) |
88 | 143 |
89 Init(params); | 144 Init(params); |
90 | 145 |
91 if (!native_browser_frame_->UsesNativeSystemMenu()) { | 146 if (!native_browser_frame_->UsesNativeSystemMenu()) { |
92 DCHECK(non_client_view()); | 147 DCHECK(non_client_view()); |
93 non_client_view()->set_context_menu_controller(this); | 148 non_client_view()->set_context_menu_controller(this); |
94 } | 149 } |
95 | 150 |
96 #if defined(USE_X11) | 151 if (browser_command_handler_) |
97 browser_command_handler_.reset(new BrowserCommandHandlerX11(browser_view_)); | 152 GetNativeWindow()->AddPreTargetHandler(browser_command_handler_.get()); |
98 #endif | |
99 } | 153 } |
100 | 154 |
101 void BrowserFrame::SetThemeProvider(scoped_ptr<ui::ThemeProvider> provider) { | 155 void BrowserFrame::SetThemeProvider(scoped_ptr<ui::ThemeProvider> provider) { |
102 owned_theme_provider_ = provider.Pass(); | 156 owned_theme_provider_ = provider.Pass(); |
103 theme_provider_ = owned_theme_provider_.get(); | 157 theme_provider_ = owned_theme_provider_.get(); |
104 } | 158 } |
105 | 159 |
106 int BrowserFrame::GetMinimizeButtonOffset() const { | 160 int BrowserFrame::GetMinimizeButtonOffset() const { |
107 return native_browser_frame_->GetMinimizeButtonOffset(); | 161 return native_browser_frame_->GetMinimizeButtonOffset(); |
108 } | 162 } |
(...skipping 143 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
252 bool BrowserFrame::ShouldLeaveOffsetNearTopBorder() { | 306 bool BrowserFrame::ShouldLeaveOffsetNearTopBorder() { |
253 return !IsMaximized(); | 307 return !IsMaximized(); |
254 } | 308 } |
255 | 309 |
256 void BrowserFrame::OnUseCustomChromeFrameChanged() { | 310 void BrowserFrame::OnUseCustomChromeFrameChanged() { |
257 // Tell the window manager to add or remove system borders. | 311 // Tell the window manager to add or remove system borders. |
258 set_frame_type(UseCustomFrame() ? Widget::FRAME_TYPE_FORCE_CUSTOM | 312 set_frame_type(UseCustomFrame() ? Widget::FRAME_TYPE_FORCE_CUSTOM |
259 : Widget::FRAME_TYPE_FORCE_NATIVE); | 313 : Widget::FRAME_TYPE_FORCE_NATIVE); |
260 FrameTypeChanged(); | 314 FrameTypeChanged(); |
261 } | 315 } |
OLD | NEW |