Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(357)

Side by Side Diff: mojo/services/native_viewport/platform_viewport.cc

Issue 403263002: platform-window: Add a PlatformWindowFactory for creating windows. Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: win32 Created 6 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright 2014 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 #include "mojo/services/native_viewport/native_viewport.h" 5 #include "mojo/services/native_viewport/native_viewport.h"
6 6
7 #include "ui/events/event.h" 7 #include "ui/gfx/rect.h"
8 #include "ui/events/platform/platform_event_dispatcher.h"
9 #include "ui/events/platform/platform_event_source.h"
10 #include "ui/ozone/public/cursor_factory_ozone.h"
11 #include "ui/ozone/public/event_factory_ozone.h"
12 #include "ui/ozone/public/ozone_platform.h"
13 #include "ui/ozone/public/surface_factory_ozone.h"
14 #include "ui/platform_window/platform_window.h" 8 #include "ui/platform_window/platform_window.h"
15 #include "ui/platform_window/platform_window_delegate.h" 9 #include "ui/platform_window/platform_window_delegate.h"
10 #include "ui/platform_window/platform_window_factory.h"
11
12 #if defined(USE_X11)
13 #include "ui/platform_window/x11/x11_window_factory.h"
14 #elif defined(OS_WIN)
15 #include "ui/platform_window/win/win_window_factory.h"
16 #elif defined(USE_OZONE)
17 #include "ui/ozone/public/ozone_platform.h"
18 #endif
16 19
17 namespace mojo { 20 namespace mojo {
18 namespace services { 21 namespace services {
19 22
20 // TODO(spang): Deduplicate with NativeViewportX11.. but there's a hack 23 class PlatformViewport : public NativeViewport,
21 // in there that prevents this. 24 public ui::PlatformWindowDelegate {
22 class NativeViewportOzone : public NativeViewport,
23 public ui::PlatformWindowDelegate {
24 public: 25 public:
25 explicit NativeViewportOzone(NativeViewportDelegate* delegate) 26 explicit PlatformViewport(NativeViewportDelegate* delegate)
26 : delegate_(delegate) { 27 : delegate_(delegate) {}
27 ui::OzonePlatform::InitializeForUI();
28 }
29 28
30 virtual ~NativeViewportOzone() { 29 virtual ~PlatformViewport() {
31 // Destroy the platform-window while |this| is still alive. 30 // Destroy the platform-window while |this| is still alive.
32 platform_window_.reset(); 31 platform_window_.reset();
33 } 32 }
34 33
35 private: 34 private:
36 // Overridden from NativeViewport: 35 // Overridden from NativeViewport:
37 virtual void Init(const gfx::Rect& bounds) OVERRIDE { 36 virtual void Init(const gfx::Rect& bounds) OVERRIDE {
37 CHECK(!platform_window_);
38
38 platform_window_ = 39 platform_window_ =
39 ui::OzonePlatform::GetInstance()->CreatePlatformWindow(this, bounds); 40 ui::PlatformWindowFactory::GetInstance()->CreatePlatformWindow(this,
41 bounds);
40 } 42 }
41 43
42 virtual void Show() OVERRIDE { platform_window_->Show(); } 44 virtual void Show() OVERRIDE { platform_window_->Show(); }
43 45
44 virtual void Hide() OVERRIDE { platform_window_->Hide(); } 46 virtual void Hide() OVERRIDE { platform_window_->Hide(); }
45 47
46 virtual void Close() OVERRIDE { platform_window_->Close(); } 48 virtual void Close() OVERRIDE { platform_window_->Close(); }
47 49
48 virtual gfx::Size GetSize() OVERRIDE { 50 virtual gfx::Size GetSize() OVERRIDE {
49 return platform_window_->GetBounds().size(); 51 return platform_window_->GetBounds().size();
(...skipping 29 matching lines...) Expand all
79 virtual void OnAcceleratedWidgetAvailable( 81 virtual void OnAcceleratedWidgetAvailable(
80 gfx::AcceleratedWidget widget) OVERRIDE { 82 gfx::AcceleratedWidget widget) OVERRIDE {
81 delegate_->OnAcceleratedWidgetAvailable(widget); 83 delegate_->OnAcceleratedWidgetAvailable(widget);
82 } 84 }
83 85
84 virtual void OnActivationChanged(bool active) OVERRIDE {} 86 virtual void OnActivationChanged(bool active) OVERRIDE {}
85 87
86 scoped_ptr<ui::PlatformWindow> platform_window_; 88 scoped_ptr<ui::PlatformWindow> platform_window_;
87 NativeViewportDelegate* delegate_; 89 NativeViewportDelegate* delegate_;
88 90
89 DISALLOW_COPY_AND_ASSIGN(NativeViewportOzone); 91 DISALLOW_COPY_AND_ASSIGN(PlatformViewport);
90 }; 92 };
91 93
92 // static 94 // static
93 scoped_ptr<NativeViewport> NativeViewport::Create( 95 scoped_ptr<NativeViewport> NativeViewport::Create(
94 NativeViewportDelegate* delegate) { 96 NativeViewportDelegate* delegate) {
95 return scoped_ptr<NativeViewport>(new NativeViewportOzone(delegate)).Pass(); 97 #if defined(USE_X11)
98 ui::X11WindowFactory::CreateIfNecessary();
99 #elif defined(OS_WIN)
100 ui::WinWindowFactory::CreateIfNecessary();
101 #elif defined(USE_OZONE)
102 ui::OzonePlatform::InitializeForUI();
103 #endif
104 return scoped_ptr<NativeViewport>(new PlatformViewport(delegate)).Pass();
96 } 105 }
97 106
98 } // namespace services 107 } // namespace services
99 } // namespace mojo 108 } // namespace mojo
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698