OLD | NEW |
1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 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/aura/window_tree_host_mojo.h" | 5 #include "mojo/aura/window_tree_host_mojo.h" |
6 | 6 |
7 #include "mojo/aura/context_factory_mojo.h" | 7 #include "mojo/aura/context_factory_mojo.h" |
8 #include "mojo/public/c/gles2/gles2.h" | 8 #include "mojo/public/c/gles2/gles2.h" |
9 #include "mojo/public/cpp/bindings/allocation_scope.h" | |
10 #include "mojo/services/native_viewport/geometry_conversions.h" | 9 #include "mojo/services/native_viewport/geometry_conversions.h" |
11 #include "ui/aura/env.h" | 10 #include "ui/aura/env.h" |
12 #include "ui/aura/window.h" | 11 #include "ui/aura/window.h" |
13 #include "ui/aura/window_event_dispatcher.h" | 12 #include "ui/aura/window_event_dispatcher.h" |
14 #include "ui/compositor/compositor.h" | 13 #include "ui/compositor/compositor.h" |
15 #include "ui/events/event.h" | 14 #include "ui/events/event.h" |
16 #include "ui/events/event_constants.h" | 15 #include "ui/events/event_constants.h" |
17 #include "ui/gfx/geometry/insets.h" | 16 #include "ui/gfx/geometry/insets.h" |
18 #include "ui/gfx/geometry/rect.h" | 17 #include "ui/gfx/geometry/rect.h" |
19 | 18 |
20 namespace mojo { | 19 namespace mojo { |
21 | 20 |
22 // static | 21 // static |
23 mojo::ContextFactoryMojo* WindowTreeHostMojo::context_factory_ = NULL; | 22 mojo::ContextFactoryMojo* WindowTreeHostMojo::context_factory_ = NULL; |
24 | 23 |
25 //////////////////////////////////////////////////////////////////////////////// | 24 //////////////////////////////////////////////////////////////////////////////// |
26 // WindowTreeHostMojo, public: | 25 // WindowTreeHostMojo, public: |
27 | 26 |
28 WindowTreeHostMojo::WindowTreeHostMojo( | 27 WindowTreeHostMojo::WindowTreeHostMojo( |
29 NativeViewportPtr viewport, | 28 NativeViewportPtr viewport, |
30 const gfx::Rect& bounds, | 29 const gfx::Rect& bounds, |
31 const base::Callback<void()>& compositor_created_callback) | 30 const base::Callback<void()>& compositor_created_callback) |
32 : native_viewport_(viewport.Pass()), | 31 : native_viewport_(viewport.Pass()), |
33 compositor_created_callback_(compositor_created_callback), | 32 compositor_created_callback_(compositor_created_callback), |
34 bounds_(bounds) { | 33 bounds_(bounds) { |
35 native_viewport_->SetClient(this); | 34 native_viewport_->SetClient(this); |
36 | 35 native_viewport_->Create(Rect::From(bounds)); |
37 AllocationScope scope; | |
38 native_viewport_->Create(bounds); | |
39 | 36 |
40 ScopedMessagePipeHandle gles2_handle, gles2_client_handle; | 37 ScopedMessagePipeHandle gles2_handle, gles2_client_handle; |
41 CreateMessagePipe(&gles2_handle, &gles2_client_handle); | 38 CreateMessagePipe(&gles2_handle, &gles2_client_handle); |
42 | 39 |
43 // The ContextFactory must exist before any Compositors are created. | 40 // The ContextFactory must exist before any Compositors are created. |
44 if (context_factory_) { | 41 if (context_factory_) { |
45 ui::ContextFactory::SetInstance(NULL); | 42 ui::ContextFactory::SetInstance(NULL); |
46 delete context_factory_; | 43 delete context_factory_; |
47 context_factory_ = NULL; | 44 context_factory_ = NULL; |
48 } | 45 } |
(...skipping 29 matching lines...) Expand all Loading... |
78 void WindowTreeHostMojo::Hide() { | 75 void WindowTreeHostMojo::Hide() { |
79 native_viewport_->Hide(); | 76 native_viewport_->Hide(); |
80 window()->Hide(); | 77 window()->Hide(); |
81 } | 78 } |
82 | 79 |
83 gfx::Rect WindowTreeHostMojo::GetBounds() const { | 80 gfx::Rect WindowTreeHostMojo::GetBounds() const { |
84 return bounds_; | 81 return bounds_; |
85 } | 82 } |
86 | 83 |
87 void WindowTreeHostMojo::SetBounds(const gfx::Rect& bounds) { | 84 void WindowTreeHostMojo::SetBounds(const gfx::Rect& bounds) { |
88 AllocationScope scope; | 85 native_viewport_->SetBounds(Rect::From(bounds)); |
89 native_viewport_->SetBounds(bounds); | |
90 } | 86 } |
91 | 87 |
92 gfx::Point WindowTreeHostMojo::GetLocationOnNativeScreen() const { | 88 gfx::Point WindowTreeHostMojo::GetLocationOnNativeScreen() const { |
93 return gfx::Point(0, 0); | 89 return gfx::Point(0, 0); |
94 } | 90 } |
95 | 91 |
96 void WindowTreeHostMojo::SetCapture() { | 92 void WindowTreeHostMojo::SetCapture() { |
97 NOTIMPLEMENTED(); | 93 NOTIMPLEMENTED(); |
98 } | 94 } |
99 | 95 |
(...skipping 30 matching lines...) Expand all Loading... |
130 } | 126 } |
131 | 127 |
132 //////////////////////////////////////////////////////////////////////////////// | 128 //////////////////////////////////////////////////////////////////////////////// |
133 // WindowTreeHostMojo, NativeViewportClient implementation: | 129 // WindowTreeHostMojo, NativeViewportClient implementation: |
134 | 130 |
135 void WindowTreeHostMojo::OnCreated() { | 131 void WindowTreeHostMojo::OnCreated() { |
136 CreateCompositor(GetAcceleratedWidget()); | 132 CreateCompositor(GetAcceleratedWidget()); |
137 compositor_created_callback_.Run(); | 133 compositor_created_callback_.Run(); |
138 } | 134 } |
139 | 135 |
140 void WindowTreeHostMojo::OnBoundsChanged(const Rect& bounds) { | 136 void WindowTreeHostMojo::OnBoundsChanged(RectPtr bounds) { |
141 bounds_ = gfx::Rect(bounds.position().x(), bounds.position().y(), | 137 bounds_ = gfx::Rect(bounds->position->x, bounds->position->y, |
142 bounds.size().width(), bounds.size().height()); | 138 bounds->size->width, bounds->size->height); |
143 window()->SetBounds(gfx::Rect(bounds_.size())); | 139 window()->SetBounds(gfx::Rect(bounds_.size())); |
144 OnHostResized(bounds_.size()); | 140 OnHostResized(bounds_.size()); |
145 } | 141 } |
146 | 142 |
147 void WindowTreeHostMojo::OnDestroyed() { | 143 void WindowTreeHostMojo::OnDestroyed() { |
148 base::MessageLoop::current()->Quit(); | 144 base::MessageLoop::current()->Quit(); |
149 } | 145 } |
150 | 146 |
151 void WindowTreeHostMojo::OnEvent(const Event& event, | 147 void WindowTreeHostMojo::OnEvent(EventPtr event, |
152 const mojo::Callback<void()>& callback) { | 148 const mojo::Callback<void()>& callback) { |
153 switch (event.action()) { | 149 switch (event->action) { |
154 case ui::ET_MOUSE_PRESSED: | 150 case ui::ET_MOUSE_PRESSED: |
155 case ui::ET_MOUSE_DRAGGED: | 151 case ui::ET_MOUSE_DRAGGED: |
156 case ui::ET_MOUSE_RELEASED: | 152 case ui::ET_MOUSE_RELEASED: |
157 case ui::ET_MOUSE_MOVED: | 153 case ui::ET_MOUSE_MOVED: |
158 case ui::ET_MOUSE_ENTERED: | 154 case ui::ET_MOUSE_ENTERED: |
159 case ui::ET_MOUSE_EXITED: { | 155 case ui::ET_MOUSE_EXITED: { |
160 gfx::Point location(event.location().x(), event.location().y()); | 156 gfx::Point location(event->location->x, event->location->y); |
161 ui::MouseEvent ev(static_cast<ui::EventType>(event.action()), location, | 157 ui::MouseEvent ev(static_cast<ui::EventType>(event->action), location, |
162 location, event.flags(), 0); | 158 location, event->flags, 0); |
163 SendEventToProcessor(&ev); | 159 SendEventToProcessor(&ev); |
164 break; | 160 break; |
165 } | 161 } |
166 case ui::ET_KEY_PRESSED: | 162 case ui::ET_KEY_PRESSED: |
167 case ui::ET_KEY_RELEASED: { | 163 case ui::ET_KEY_RELEASED: { |
168 ui::KeyEvent ev( | 164 ui::KeyEvent ev( |
169 static_cast<ui::EventType>(event.action()), | 165 static_cast<ui::EventType>(event->action), |
170 static_cast<ui::KeyboardCode>(event.key_data().key_code()), | 166 static_cast<ui::KeyboardCode>(event->key_data->key_code), |
171 event.flags(), event.key_data().is_char()); | 167 event->flags, event->key_data->is_char); |
172 SendEventToProcessor(&ev); | 168 SendEventToProcessor(&ev); |
173 break; | 169 break; |
174 } | 170 } |
175 // TODO(beng): touch, etc. | 171 // TODO(beng): touch, etc. |
176 } | 172 } |
177 callback.Run(); | 173 callback.Run(); |
178 }; | 174 }; |
179 | 175 |
180 } // namespace mojo | 176 } // namespace mojo |
OLD | NEW |