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 #ifndef CHROME_BROWSER_UI_VIEWS_APPS_NATIVE_APP_WINDOW_VIEWS_H_ | 5 #ifndef CHROME_BROWSER_UI_VIEWS_APPS_NATIVE_APP_WINDOW_VIEWS_H_ |
6 #define CHROME_BROWSER_UI_VIEWS_APPS_NATIVE_APP_WINDOW_VIEWS_H_ | 6 #define CHROME_BROWSER_UI_VIEWS_APPS_NATIVE_APP_WINDOW_VIEWS_H_ |
7 | 7 |
8 #include "apps/shell_window.h" | 8 #include "apps/app_window.h" |
9 #include "apps/ui/native_app_window.h" | 9 #include "apps/ui/native_app_window.h" |
10 #include "base/observer_list.h" | 10 #include "base/observer_list.h" |
11 #include "content/public/browser/web_contents_observer.h" | 11 #include "content/public/browser/web_contents_observer.h" |
12 #include "third_party/skia/include/core/SkRegion.h" | 12 #include "third_party/skia/include/core/SkRegion.h" |
13 #include "ui/gfx/image/image_skia.h" | 13 #include "ui/gfx/image/image_skia.h" |
14 #include "ui/gfx/rect.h" | 14 #include "ui/gfx/rect.h" |
15 #include "ui/views/context_menu_controller.h" | 15 #include "ui/views/context_menu_controller.h" |
16 #include "ui/views/controls/webview/unhandled_keyboard_event_handler.h" | 16 #include "ui/views/controls/webview/unhandled_keyboard_event_handler.h" |
17 #include "ui/views/widget/widget.h" | 17 #include "ui/views/widget/widget.h" |
18 #include "ui/views/widget/widget_delegate.h" | 18 #include "ui/views/widget/widget_delegate.h" |
19 #include "ui/views/widget/widget_observer.h" | 19 #include "ui/views/widget/widget_observer.h" |
20 | 20 |
21 #if defined(OS_WIN) | 21 #if defined(OS_WIN) |
22 #include "chrome/browser/shell_integration.h" | 22 #include "chrome/browser/shell_integration.h" |
23 #endif | 23 #endif |
24 | 24 |
25 #if defined(USE_ASH) | 25 #if defined(USE_ASH) |
26 namespace ash { | 26 namespace ash { |
27 class ImmersiveFullscreenController; | 27 class ImmersiveFullscreenController; |
28 } | 28 } |
29 #endif | 29 #endif |
30 | 30 |
31 class ExtensionKeybindingRegistryViews; | 31 class ExtensionKeybindingRegistryViews; |
32 | 32 |
33 namespace apps { | 33 namespace apps { |
34 class ShellWindowFrameView; | 34 class AppWindowFrameView; |
35 } | 35 } |
36 | 36 |
37 namespace content { | 37 namespace content { |
38 class BrowserContext; | 38 class BrowserContext; |
39 class RenderViewHost; | 39 class RenderViewHost; |
40 class WebContents; | 40 class WebContents; |
41 } | 41 } |
42 | 42 |
43 namespace extensions { | 43 namespace extensions { |
44 class Extension; | 44 class Extension; |
45 } | 45 } |
46 | 46 |
47 namespace ui { | 47 namespace ui { |
48 class MenuModel; | 48 class MenuModel; |
49 } | 49 } |
50 | 50 |
51 namespace views { | 51 namespace views { |
52 class MenuRunner; | 52 class MenuRunner; |
53 class WebView; | 53 class WebView; |
54 } | 54 } |
55 | 55 |
56 class NativeAppWindowViews : public apps::NativeAppWindow, | 56 class NativeAppWindowViews : public apps::NativeAppWindow, |
57 public content::WebContentsObserver, | 57 public content::WebContentsObserver, |
58 public views::ContextMenuController, | 58 public views::ContextMenuController, |
59 public views::WidgetDelegateView, | 59 public views::WidgetDelegateView, |
60 public views::WidgetObserver { | 60 public views::WidgetObserver { |
61 public: | 61 public: |
62 NativeAppWindowViews(); | 62 NativeAppWindowViews(); |
63 virtual ~NativeAppWindowViews(); | 63 virtual ~NativeAppWindowViews(); |
64 void Init(apps::ShellWindow* shell_window, | 64 void Init(apps::AppWindow* app_window, |
65 const apps::ShellWindow::CreateParams& create_params); | 65 const apps::AppWindow::CreateParams& create_params); |
66 | 66 |
67 SkRegion* shape() { return shape_.get(); } | 67 SkRegion* shape() { return shape_.get(); } |
68 | 68 |
69 protected: | 69 protected: |
70 // Called before views::Widget::Init() to allow subclasses to customize | 70 // Called before views::Widget::Init() to allow subclasses to customize |
71 // the InitParams that would be passed. | 71 // the InitParams that would be passed. |
72 virtual void OnBeforeWidgetInit(views::Widget::InitParams* init_params, | 72 virtual void OnBeforeWidgetInit(views::Widget::InitParams* init_params, |
73 views::Widget* widget); | 73 views::Widget* widget); |
74 | 74 |
75 // ui::BaseWindow implementation that subclasses may override. | 75 // ui::BaseWindow implementation that subclasses may override. |
76 virtual void Show() OVERRIDE; | 76 virtual void Show() OVERRIDE; |
77 virtual void Activate() OVERRIDE; | 77 virtual void Activate() OVERRIDE; |
78 | 78 |
79 content::BrowserContext* browser_context() { | 79 content::BrowserContext* browser_context() { |
80 return shell_window_->browser_context(); | 80 return app_window_->browser_context(); |
81 } | 81 } |
82 | 82 |
83 const extensions::Extension* extension() { | 83 const extensions::Extension* extension() { return app_window_->extension(); } |
84 return shell_window_->extension(); | |
85 } | |
86 | 84 |
87 private: | 85 private: |
88 friend class ShapedAppWindowTargeterTest; | 86 friend class ShapedAppWindowTargeterTest; |
89 | 87 |
90 void InitializeDefaultWindow( | 88 void InitializeDefaultWindow( |
91 const apps::ShellWindow::CreateParams& create_params); | 89 const apps::AppWindow::CreateParams& create_params); |
92 void InitializePanelWindow( | 90 void InitializePanelWindow( |
93 const apps::ShellWindow::CreateParams& create_params); | 91 const apps::AppWindow::CreateParams& create_params); |
94 void OnViewWasResized(); | 92 void OnViewWasResized(); |
95 | 93 |
96 bool ShouldUseChromeStyleFrame() const; | 94 bool ShouldUseChromeStyleFrame() const; |
97 | 95 |
98 // Caller owns the returned object. | 96 // Caller owns the returned object. |
99 apps::ShellWindowFrameView* CreateShellWindowFrameView(); | 97 apps::AppWindowFrameView* CreateAppWindowFrameView(); |
100 | 98 |
101 #if defined(OS_WIN) | 99 #if defined(OS_WIN) |
102 void OnShortcutInfoLoaded( | 100 void OnShortcutInfoLoaded( |
103 const ShellIntegration::ShortcutInfo& shortcut_info); | 101 const ShellIntegration::ShortcutInfo& shortcut_info); |
104 HWND GetNativeAppWindowHWND() const; | 102 HWND GetNativeAppWindowHWND() const; |
105 #endif | 103 #endif |
106 | 104 |
107 // ui::BaseWindow implementation. | 105 // ui::BaseWindow implementation. |
108 virtual bool IsActive() const OVERRIDE; | 106 virtual bool IsActive() const OVERRIDE; |
109 virtual bool IsMaximized() const OVERRIDE; | 107 virtual bool IsMaximized() const OVERRIDE; |
(...skipping 88 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
198 | 196 |
199 // web_modal::WebContentsModalDialogHost implementation. | 197 // web_modal::WebContentsModalDialogHost implementation. |
200 virtual gfx::NativeView GetHostView() const OVERRIDE; | 198 virtual gfx::NativeView GetHostView() const OVERRIDE; |
201 virtual gfx::Point GetDialogPosition(const gfx::Size& size) OVERRIDE; | 199 virtual gfx::Point GetDialogPosition(const gfx::Size& size) OVERRIDE; |
202 virtual gfx::Size GetMaximumDialogSize() OVERRIDE; | 200 virtual gfx::Size GetMaximumDialogSize() OVERRIDE; |
203 virtual void AddObserver( | 201 virtual void AddObserver( |
204 web_modal::ModalDialogHostObserver* observer) OVERRIDE; | 202 web_modal::ModalDialogHostObserver* observer) OVERRIDE; |
205 virtual void RemoveObserver( | 203 virtual void RemoveObserver( |
206 web_modal::ModalDialogHostObserver* observer) OVERRIDE; | 204 web_modal::ModalDialogHostObserver* observer) OVERRIDE; |
207 | 205 |
208 content::WebContents* web_contents() { | 206 content::WebContents* web_contents() { return app_window_->web_contents(); } |
209 return shell_window_->web_contents(); | |
210 } | |
211 | 207 |
212 apps::ShellWindow* shell_window_; // weak - ShellWindow owns NativeAppWindow. | 208 apps::AppWindow* app_window_; // Not owned. |
213 views::WebView* web_view_; | 209 views::WebView* web_view_; |
214 views::Widget* window_; | 210 views::Widget* window_; |
215 bool is_fullscreen_; | 211 bool is_fullscreen_; |
216 | 212 |
217 // Custom shape of the window. If this is not set then the window has a | 213 // Custom shape of the window. If this is not set then the window has a |
218 // default shape, usually rectangular. | 214 // default shape, usually rectangular. |
219 scoped_ptr<SkRegion> shape_; | 215 scoped_ptr<SkRegion> shape_; |
220 | 216 |
221 scoped_ptr<SkRegion> draggable_region_; | 217 scoped_ptr<SkRegion> draggable_region_; |
222 | 218 |
(...skipping 20 matching lines...) Expand all Loading... |
243 | 239 |
244 base::WeakPtrFactory<NativeAppWindowViews> weak_ptr_factory_; | 240 base::WeakPtrFactory<NativeAppWindowViews> weak_ptr_factory_; |
245 | 241 |
246 // Used to show the system menu. | 242 // Used to show the system menu. |
247 scoped_ptr<views::MenuRunner> menu_runner_; | 243 scoped_ptr<views::MenuRunner> menu_runner_; |
248 | 244 |
249 DISALLOW_COPY_AND_ASSIGN(NativeAppWindowViews); | 245 DISALLOW_COPY_AND_ASSIGN(NativeAppWindowViews); |
250 }; | 246 }; |
251 | 247 |
252 #endif // CHROME_BROWSER_UI_VIEWS_APPS_NATIVE_APP_WINDOW_VIEWS_H_ | 248 #endif // CHROME_BROWSER_UI_VIEWS_APPS_NATIVE_APP_WINDOW_VIEWS_H_ |
OLD | NEW |