| 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 #include <stdio.h> | 5 #include <stdio.h> |
| 6 #include <string> | 6 #include <string> |
| 7 | 7 |
| 8 #include "base/at_exit.h" | 8 #include "base/at_exit.h" |
| 9 #include "base/command_line.h" | 9 #include "base/command_line.h" |
| 10 #include "base/message_loop/message_loop.h" | 10 #include "base/message_loop/message_loop.h" |
| 11 #include "mojo/examples/aura_demo/demo_screen.h" | 11 #include "mojo/examples/aura_demo/demo_screen.h" |
| 12 #include "mojo/examples/aura_demo/root_window_host_mojo.h" | 12 #include "mojo/examples/aura_demo/root_window_host_mojo.h" |
| 13 #include "mojo/public/bindings/allocation_scope.h" | 13 #include "mojo/public/bindings/allocation_scope.h" |
| 14 #include "mojo/public/bindings/remote_ptr.h" | |
| 15 #include "mojo/public/gles2/gles2_cpp.h" | 14 #include "mojo/public/gles2/gles2_cpp.h" |
| 15 #include "mojo/public/shell/application.h" |
| 16 #include "mojo/public/system/core.h" | 16 #include "mojo/public/system/core.h" |
| 17 #include "mojo/public/system/macros.h" | 17 #include "mojo/public/system/macros.h" |
| 18 #include "mojom/native_viewport.h" | 18 #include "mojom/native_viewport.h" |
| 19 #include "mojom/shell.h" | 19 #include "mojom/shell.h" |
| 20 #include "ui/aura/client/default_capture_client.h" | 20 #include "ui/aura/client/default_capture_client.h" |
| 21 #include "ui/aura/client/window_tree_client.h" | 21 #include "ui/aura/client/window_tree_client.h" |
| 22 #include "ui/aura/env.h" | 22 #include "ui/aura/env.h" |
| 23 #include "ui/aura/root_window.h" | 23 #include "ui/aura/root_window.h" |
| 24 #include "ui/aura/window.h" | 24 #include "ui/aura/window.h" |
| 25 #include "ui/aura/window_delegate.h" | 25 #include "ui/aura/window_delegate.h" |
| (...skipping 82 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 108 } | 108 } |
| 109 | 109 |
| 110 private: | 110 private: |
| 111 aura::Window* window_; | 111 aura::Window* window_; |
| 112 | 112 |
| 113 scoped_ptr<aura::client::DefaultCaptureClient> capture_client_; | 113 scoped_ptr<aura::client::DefaultCaptureClient> capture_client_; |
| 114 | 114 |
| 115 DISALLOW_COPY_AND_ASSIGN(DemoWindowTreeClient); | 115 DISALLOW_COPY_AND_ASSIGN(DemoWindowTreeClient); |
| 116 }; | 116 }; |
| 117 | 117 |
| 118 class AuraDemo : public ShellClient { | 118 class AuraDemo : public Application { |
| 119 public: | 119 public: |
| 120 explicit AuraDemo(ScopedShellHandle shell_handle) | 120 explicit AuraDemo(MojoHandle shell_handle) : Application(shell_handle) { |
| 121 : shell_(shell_handle.Pass(), this) { | |
| 122 screen_.reset(DemoScreen::Create()); | 121 screen_.reset(DemoScreen::Create()); |
| 123 gfx::Screen::SetScreenInstance(gfx::SCREEN_TYPE_NATIVE, screen_.get()); | 122 gfx::Screen::SetScreenInstance(gfx::SCREEN_TYPE_NATIVE, screen_.get()); |
| 124 | 123 |
| 125 InterfacePipe<NativeViewport, AnyInterface> pipe; | 124 InterfacePipe<NativeViewport, AnyInterface> pipe; |
| 126 | 125 |
| 127 mojo::AllocationScope scope; | 126 mojo::AllocationScope scope; |
| 128 shell_->Connect("mojo:mojo_native_viewport_service", | 127 GetShell()->Connect("mojo:mojo_native_viewport_service", |
| 129 pipe.handle_to_peer.Pass()); | 128 pipe.handle_to_peer.Pass()); |
| 130 root_window_host_.reset(new WindowTreeHostMojo( | 129 root_window_host_.reset(new WindowTreeHostMojo( |
| 131 pipe.handle_to_self.Pass(), | 130 pipe.handle_to_self.Pass(), |
| 132 gfx::Rect(800, 600), | 131 gfx::Rect(800, 600), |
| 133 base::Bind(&AuraDemo::HostContextCreated, base::Unretained(this)))); | 132 base::Bind(&AuraDemo::HostContextCreated, base::Unretained(this)))); |
| 134 } | 133 } |
| 135 | 134 |
| 136 virtual void AcceptConnection(const mojo::String& url, | |
| 137 ScopedMessagePipeHandle handle) MOJO_OVERRIDE { | |
| 138 NOTREACHED() << "AuraDemo can't be connected to."; | |
| 139 } | |
| 140 | |
| 141 private: | 135 private: |
| 142 void HostContextCreated() { | 136 void HostContextCreated() { |
| 143 aura::RootWindow::CreateParams params( | 137 aura::RootWindow::CreateParams params( |
| 144 gfx::Rect(root_window_host_->bounds().size())); | 138 gfx::Rect(root_window_host_->bounds().size())); |
| 145 params.host = root_window_host_.get(); | 139 params.host = root_window_host_.get(); |
| 146 root_window_.reset(new aura::RootWindow(params)); | 140 root_window_.reset(new aura::RootWindow(params)); |
| 147 root_window_host_->set_delegate(root_window_.get()); | 141 root_window_host_->set_delegate(root_window_.get()); |
| 148 root_window_->Init(); | 142 root_window_->Init(); |
| 149 | 143 |
| 150 window_tree_client_.reset(new DemoWindowTreeClient(root_window_->window())); | 144 window_tree_client_.reset(new DemoWindowTreeClient(root_window_->window())); |
| (...skipping 27 matching lines...) Expand all Loading... |
| 178 scoped_ptr<DemoWindowTreeClient> window_tree_client_; | 172 scoped_ptr<DemoWindowTreeClient> window_tree_client_; |
| 179 | 173 |
| 180 scoped_ptr<DemoWindowDelegate> delegate1_; | 174 scoped_ptr<DemoWindowDelegate> delegate1_; |
| 181 scoped_ptr<DemoWindowDelegate> delegate2_; | 175 scoped_ptr<DemoWindowDelegate> delegate2_; |
| 182 scoped_ptr<DemoWindowDelegate> delegate21_; | 176 scoped_ptr<DemoWindowDelegate> delegate21_; |
| 183 | 177 |
| 184 aura::Window* window1_; | 178 aura::Window* window1_; |
| 185 aura::Window* window2_; | 179 aura::Window* window2_; |
| 186 aura::Window* window21_; | 180 aura::Window* window21_; |
| 187 | 181 |
| 188 RemotePtr<Shell> shell_; | |
| 189 scoped_ptr<WindowTreeHostMojo> root_window_host_; | 182 scoped_ptr<WindowTreeHostMojo> root_window_host_; |
| 190 scoped_ptr<aura::RootWindow> root_window_; | 183 scoped_ptr<aura::RootWindow> root_window_; |
| 191 }; | 184 }; |
| 192 | 185 |
| 193 } // namespace examples | 186 } // namespace examples |
| 194 } // namespace mojo | 187 } // namespace mojo |
| 195 | 188 |
| 196 extern "C" AURA_DEMO_EXPORT MojoResult CDECL MojoMain( | 189 extern "C" AURA_DEMO_EXPORT MojoResult CDECL MojoMain( |
| 197 MojoHandle shell_handle) { | 190 MojoHandle shell_handle) { |
| 198 CommandLine::Init(0, NULL); | 191 CommandLine::Init(0, NULL); |
| 199 base::AtExitManager at_exit; | 192 base::AtExitManager at_exit; |
| 200 base::MessageLoop loop; | 193 base::MessageLoop loop; |
| 201 mojo::GLES2Initializer gles2; | 194 mojo::GLES2Initializer gles2; |
| 202 | 195 |
| 203 // TODO(beng): This crashes in a DCHECK on X11 because this thread's | 196 // TODO(beng): This crashes in a DCHECK on X11 because this thread's |
| 204 // MessageLoop is not of TYPE_UI. I think we need a way to build | 197 // MessageLoop is not of TYPE_UI. I think we need a way to build |
| 205 // Aura that doesn't define platform-specific stuff. | 198 // Aura that doesn't define platform-specific stuff. |
| 206 aura::Env::CreateInstance(); | 199 aura::Env::CreateInstance(); |
| 207 mojo::examples::AuraDemo app( | 200 mojo::examples::AuraDemo app(shell_handle); |
| 208 mojo::MakeScopedHandle(mojo::ShellHandle(shell_handle)).Pass()); | |
| 209 loop.Run(); | 201 loop.Run(); |
| 210 | 202 |
| 211 return MOJO_RESULT_OK; | 203 return MOJO_RESULT_OK; |
| 212 } | 204 } |
| OLD | NEW |