| OLD | NEW |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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_impl.h" | 5 #include "mojo/services/native_viewport/native_viewport_impl.h" |
| 6 | 6 |
| 7 #include "base/auto_reset.h" | 7 #include "base/auto_reset.h" |
| 8 #include "base/bind.h" | 8 #include "base/bind.h" |
| 9 #include "base/macros.h" | 9 #include "base/macros.h" |
| 10 #include "base/message_loop/message_loop.h" | 10 #include "base/message_loop/message_loop.h" |
| (...skipping 75 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 86 size_, | 86 size_, |
| 87 child_surface_id.To<cc::SurfaceId>())); | 87 child_surface_id.To<cc::SurfaceId>())); |
| 88 if (widget_id_) | 88 if (widget_id_) |
| 89 viewport_surface_->SetWidgetId(widget_id_); | 89 viewport_surface_->SetWidgetId(widget_id_); |
| 90 } | 90 } |
| 91 child_surface_id_ = child_surface_id.To<cc::SurfaceId>(); | 91 child_surface_id_ = child_surface_id.To<cc::SurfaceId>(); |
| 92 if (viewport_surface_) | 92 if (viewport_surface_) |
| 93 viewport_surface_->SetChildId(child_surface_id_); | 93 viewport_surface_->SetChildId(child_surface_id_); |
| 94 } | 94 } |
| 95 | 95 |
| 96 void NativeViewportImpl::SetEventDispatcher( |
| 97 NativeViewportEventDispatcherPtr dispatcher) { |
| 98 event_dispatcher_ = dispatcher.Pass(); |
| 99 } |
| 100 |
| 96 void NativeViewportImpl::OnBoundsChanged(const gfx::Rect& bounds) { | 101 void NativeViewportImpl::OnBoundsChanged(const gfx::Rect& bounds) { |
| 97 if (size_ == bounds.size()) | 102 if (size_ == bounds.size()) |
| 98 return; | 103 return; |
| 99 | 104 |
| 100 size_ = bounds.size(); | 105 size_ = bounds.size(); |
| 101 | 106 |
| 102 // Wait for the accelerated widget before telling the client of the bounds. | 107 // Wait for the accelerated widget before telling the client of the bounds. |
| 103 if (create_callback_.is_null()) | 108 if (create_callback_.is_null()) |
| 104 ProcessOnBoundsChanged(); | 109 ProcessOnBoundsChanged(); |
| 105 } | 110 } |
| 106 | 111 |
| 107 void NativeViewportImpl::OnAcceleratedWidgetAvailable( | 112 void NativeViewportImpl::OnAcceleratedWidgetAvailable( |
| 108 gfx::AcceleratedWidget widget) { | 113 gfx::AcceleratedWidget widget) { |
| 109 widget_id_ = static_cast<uint64_t>(bit_cast<uintptr_t>(widget)); | 114 widget_id_ = static_cast<uint64_t>(bit_cast<uintptr_t>(widget)); |
| 110 // TODO(jamesr): Remove once everything is converted to surfaces. | 115 // TODO(jamesr): Remove once everything is converted to surfaces. |
| 111 create_callback_.Run(widget_id_); | 116 create_callback_.Run(widget_id_); |
| 112 create_callback_.reset(); | 117 create_callback_.reset(); |
| 113 // Immediately tell the client of the size. The size may be wrong, if so we'll | 118 // Immediately tell the client of the size. The size may be wrong, if so we'll |
| 114 // get the right one in the next OnBoundsChanged() call. | 119 // get the right one in the next OnBoundsChanged() call. |
| 115 ProcessOnBoundsChanged(); | 120 ProcessOnBoundsChanged(); |
| 116 if (viewport_surface_) | 121 if (viewport_surface_) |
| 117 viewport_surface_->SetWidgetId(widget_id_); | 122 viewport_surface_->SetWidgetId(widget_id_); |
| 118 } | 123 } |
| 119 | 124 |
| 120 bool NativeViewportImpl::OnEvent(ui::Event* ui_event) { | 125 bool NativeViewportImpl::OnEvent(ui::Event* ui_event) { |
| 126 if (!event_dispatcher_.get()) |
| 127 return false; |
| 128 |
| 121 // Must not return early before updating capture. | 129 // Must not return early before updating capture. |
| 122 switch (ui_event->type()) { | 130 switch (ui_event->type()) { |
| 123 case ui::ET_MOUSE_PRESSED: | 131 case ui::ET_MOUSE_PRESSED: |
| 124 case ui::ET_TOUCH_PRESSED: | 132 case ui::ET_TOUCH_PRESSED: |
| 125 platform_viewport_->SetCapture(); | 133 platform_viewport_->SetCapture(); |
| 126 break; | 134 break; |
| 127 case ui::ET_MOUSE_RELEASED: | 135 case ui::ET_MOUSE_RELEASED: |
| 128 case ui::ET_TOUCH_RELEASED: | 136 case ui::ET_TOUCH_RELEASED: |
| 129 platform_viewport_->ReleaseCapture(); | 137 platform_viewport_->ReleaseCapture(); |
| 130 break; | 138 break; |
| 131 default: | 139 default: |
| 132 break; | 140 break; |
| 133 } | 141 } |
| 134 | 142 |
| 135 if (waiting_for_event_ack_ && IsRateLimitedEventType(ui_event)) | 143 if (waiting_for_event_ack_ && IsRateLimitedEventType(ui_event)) |
| 136 return false; | 144 return false; |
| 137 | 145 |
| 138 client()->OnEvent( | 146 event_dispatcher_->OnEvent( |
| 139 Event::From(*ui_event), | 147 Event::From(*ui_event), |
| 140 base::Bind(&NativeViewportImpl::AckEvent, weak_factory_.GetWeakPtr())); | 148 base::Bind(&NativeViewportImpl::AckEvent, weak_factory_.GetWeakPtr())); |
| 141 waiting_for_event_ack_ = true; | 149 waiting_for_event_ack_ = true; |
| 142 return false; | 150 return false; |
| 143 } | 151 } |
| 144 | 152 |
| 145 void NativeViewportImpl::OnDestroyed() { | 153 void NativeViewportImpl::OnDestroyed() { |
| 146 client()->OnDestroyed(); | 154 client()->OnDestroyed(); |
| 147 } | 155 } |
| 148 | 156 |
| 149 void NativeViewportImpl::AckEvent() { | 157 void NativeViewportImpl::AckEvent() { |
| 150 waiting_for_event_ack_ = false; | 158 waiting_for_event_ack_ = false; |
| 151 } | 159 } |
| 152 | 160 |
| 153 void NativeViewportImpl::ProcessOnBoundsChanged() { | 161 void NativeViewportImpl::ProcessOnBoundsChanged() { |
| 154 client()->OnSizeChanged(Size::From(size_)); | 162 client()->OnSizeChanged(Size::From(size_)); |
| 155 if (viewport_surface_) | 163 if (viewport_surface_) |
| 156 viewport_surface_->SetSize(size_); | 164 viewport_surface_->SetSize(size_); |
| 157 } | 165 } |
| 158 | 166 |
| 159 } // namespace mojo | 167 } // namespace mojo |
| 160 | 168 |
| OLD | NEW |