| 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 #ifndef CONTENT_BROWSER_FRAME_HOST_RENDER_WIDGET_HOST_VIEW_CHILD_FRAME_H_ | 5 #ifndef CONTENT_BROWSER_FRAME_HOST_RENDER_WIDGET_HOST_VIEW_CHILD_FRAME_H_ |
| 6 #define CONTENT_BROWSER_FRAME_HOST_RENDER_WIDGET_HOST_VIEW_CHILD_FRAME_H_ | 6 #define CONTENT_BROWSER_FRAME_HOST_RENDER_WIDGET_HOST_VIEW_CHILD_FRAME_H_ |
| 7 | 7 |
| 8 #include <stddef.h> | 8 #include <stddef.h> |
| 9 #include <stdint.h> | 9 #include <stdint.h> |
| 10 | 10 |
| 11 #include <deque> | 11 #include <deque> |
| 12 #include <memory> | 12 #include <memory> |
| 13 #include <vector> | 13 #include <vector> |
| 14 | 14 |
| 15 #include "base/callback.h" | 15 #include "base/callback.h" |
| 16 #include "base/macros.h" | 16 #include "base/macros.h" |
| 17 #include "build/build_config.h" | 17 #include "build/build_config.h" |
| 18 #include "cc/resources/returned_resource.h" | 18 #include "cc/resources/returned_resource.h" |
| 19 #include "cc/scheduler/begin_frame_source.h" | 19 #include "cc/scheduler/begin_frame_source.h" |
| 20 #include "cc/surfaces/compositor_frame_sink_support_client.h" |
| 20 #include "cc/surfaces/local_surface_id_allocator.h" | 21 #include "cc/surfaces/local_surface_id_allocator.h" |
| 21 #include "cc/surfaces/surface_factory_client.h" | |
| 22 #include "cc/surfaces/surface_info.h" | 22 #include "cc/surfaces/surface_info.h" |
| 23 #include "cc/surfaces/surface_sequence.h" | 23 #include "cc/surfaces/surface_sequence.h" |
| 24 #include "content/browser/compositor/image_transport_factory.h" | 24 #include "content/browser/compositor/image_transport_factory.h" |
| 25 #include "content/browser/renderer_host/event_with_latency_info.h" | 25 #include "content/browser/renderer_host/event_with_latency_info.h" |
| 26 #include "content/browser/renderer_host/render_widget_host_view_base.h" | 26 #include "content/browser/renderer_host/render_widget_host_view_base.h" |
| 27 #include "content/common/content_export.h" | 27 #include "content/common/content_export.h" |
| 28 #include "content/common/input/input_event_ack_state.h" | 28 #include "content/common/input/input_event_ack_state.h" |
| 29 #include "content/public/browser/readback_types.h" | 29 #include "content/public/browser/readback_types.h" |
| 30 #include "ui/gfx/geometry/rect.h" | 30 #include "ui/gfx/geometry/rect.h" |
| 31 #include "ui/gfx/native_widget_types.h" | 31 #include "ui/gfx/native_widget_types.h" |
| 32 | 32 |
| 33 namespace cc { | 33 namespace cc { |
| 34 class SurfaceFactory; | 34 class CompositorFrameSinkSupport; |
| 35 } | 35 } |
| 36 | 36 |
| 37 | |
| 38 namespace content { | 37 namespace content { |
| 39 class CrossProcessFrameConnector; | 38 class CrossProcessFrameConnector; |
| 40 class RenderWidgetHost; | 39 class RenderWidgetHost; |
| 41 class RenderWidgetHostImpl; | 40 class RenderWidgetHostImpl; |
| 42 class RenderWidgetHostViewChildFrameTest; | 41 class RenderWidgetHostViewChildFrameTest; |
| 43 class RenderWidgetHostViewGuestSurfaceTest; | 42 class RenderWidgetHostViewGuestSurfaceTest; |
| 44 | 43 |
| 45 // RenderWidgetHostViewChildFrame implements the view for a RenderWidgetHost | 44 // RenderWidgetHostViewChildFrame implements the view for a RenderWidgetHost |
| 46 // associated with content being rendered in a separate process from | 45 // associated with content being rendered in a separate process from |
| 47 // content that is embedding it. This is not a platform-specific class; rather, | 46 // content that is embedding it. This is not a platform-specific class; rather, |
| 48 // the embedding renderer process implements the platform containing the | 47 // the embedding renderer process implements the platform containing the |
| 49 // widget, and the top-level frame's RenderWidgetHostView will ultimately | 48 // widget, and the top-level frame's RenderWidgetHostView will ultimately |
| 50 // manage all native widget interaction. | 49 // manage all native widget interaction. |
| 51 // | 50 // |
| 52 // See comments in render_widget_host_view.h about this class and its members. | 51 // See comments in render_widget_host_view.h about this class and its members. |
| 53 class CONTENT_EXPORT RenderWidgetHostViewChildFrame | 52 class CONTENT_EXPORT RenderWidgetHostViewChildFrame |
| 54 : public RenderWidgetHostViewBase, | 53 : public RenderWidgetHostViewBase, |
| 55 public cc::SurfaceFactoryClient, | 54 public NON_EXPORTED_BASE(cc::CompositorFrameSinkSupportClient) { |
| 56 public cc::BeginFrameObserver { | |
| 57 public: | 55 public: |
| 58 static RenderWidgetHostViewChildFrame* Create(RenderWidgetHost* widget); | 56 static RenderWidgetHostViewChildFrame* Create(RenderWidgetHost* widget); |
| 59 ~RenderWidgetHostViewChildFrame() override; | 57 ~RenderWidgetHostViewChildFrame() override; |
| 60 | 58 |
| 61 void SetCrossProcessFrameConnector( | 59 void SetCrossProcessFrameConnector( |
| 62 CrossProcessFrameConnector* frame_connector); | 60 CrossProcessFrameConnector* frame_connector); |
| 63 | 61 |
| 64 // This functions registers single-use callbacks that want to be notified when | 62 // This functions registers single-use callbacks that want to be notified when |
| 65 // the next frame is swapped. The callback is triggered by | 63 // the next frame is swapped. The callback is triggered by |
| 66 // OnSwapCompositorFrame, which is the appropriate time to request pixel | 64 // OnSwapCompositorFrame, which is the appropriate time to request pixel |
| (...skipping 87 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 154 void SpeakSelection() override; | 152 void SpeakSelection() override; |
| 155 bool IsSpeaking() const override; | 153 bool IsSpeaking() const override; |
| 156 void StopSpeaking() override; | 154 void StopSpeaking() override; |
| 157 #endif // defined(OS_MACOSX) | 155 #endif // defined(OS_MACOSX) |
| 158 | 156 |
| 159 InputEventAckState FilterInputEvent( | 157 InputEventAckState FilterInputEvent( |
| 160 const blink::WebInputEvent& input_event) override; | 158 const blink::WebInputEvent& input_event) override; |
| 161 BrowserAccessibilityManager* CreateBrowserAccessibilityManager( | 159 BrowserAccessibilityManager* CreateBrowserAccessibilityManager( |
| 162 BrowserAccessibilityDelegate* delegate, bool for_root_frame) override; | 160 BrowserAccessibilityDelegate* delegate, bool for_root_frame) override; |
| 163 | 161 |
| 164 // cc::SurfaceFactoryClient implementation. | 162 // cc::CompositorFrameSinkSupportClient implementation. |
| 165 void ReturnResources(const cc::ReturnedResourceArray& resources) override; | 163 void DidReceiveCompositorFrameAck() override; |
| 166 void SetBeginFrameSource(cc::BeginFrameSource* source) override; | |
| 167 | |
| 168 // cc::BeginFrameObserver implementation. | |
| 169 void OnBeginFrame(const cc::BeginFrameArgs& args) override; | 164 void OnBeginFrame(const cc::BeginFrameArgs& args) override; |
| 170 const cc::BeginFrameArgs& LastUsedBeginFrameArgs() const override; | 165 void ReclaimResources(const cc::ReturnedResourceArray& resources) override; |
| 171 void OnBeginFrameSourcePausedChanged(bool paused) override; | 166 void WillDrawSurface(const cc::LocalSurfaceId& id, |
| 172 | 167 const gfx::Rect& damage_rect) override {} |
| 173 // Declared 'public' instead of 'protected' here to allow derived classes | |
| 174 // to Bind() to it. | |
| 175 void SurfaceDrawn(uint32_t compositor_frame_sink_id); | |
| 176 | 168 |
| 177 // Exposed for tests. | 169 // Exposed for tests. |
| 178 bool IsChildFrameForTesting() const override; | 170 bool IsChildFrameForTesting() const override; |
| 179 cc::SurfaceId SurfaceIdForTesting() const override; | 171 cc::SurfaceId SurfaceIdForTesting() const override; |
| 180 CrossProcessFrameConnector* FrameConnectorForTesting() const { | 172 CrossProcessFrameConnector* FrameConnectorForTesting() const { |
| 181 return frame_connector_; | 173 return frame_connector_; |
| 182 } | 174 } |
| 183 | 175 |
| 184 // Returns the current surface scale factor. | 176 // Returns the current surface scale factor. |
| 185 float current_surface_scale_factor() { return current_surface_scale_factor_; } | 177 float current_surface_scale_factor() { return current_surface_scale_factor_; } |
| (...skipping 34 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 220 | 212 |
| 221 // Members will become private when RenderWidgetHostViewGuest is removed. | 213 // Members will become private when RenderWidgetHostViewGuest is removed. |
| 222 // The model object. | 214 // The model object. |
| 223 RenderWidgetHostImpl* host_; | 215 RenderWidgetHostImpl* host_; |
| 224 | 216 |
| 225 // The ID for FrameSink associated with this view. | 217 // The ID for FrameSink associated with this view. |
| 226 cc::FrameSinkId frame_sink_id_; | 218 cc::FrameSinkId frame_sink_id_; |
| 227 | 219 |
| 228 // Surface-related state. | 220 // Surface-related state. |
| 229 std::unique_ptr<cc::LocalSurfaceIdAllocator> id_allocator_; | 221 std::unique_ptr<cc::LocalSurfaceIdAllocator> id_allocator_; |
| 230 std::unique_ptr<cc::SurfaceFactory> surface_factory_; | 222 std::unique_ptr<cc::CompositorFrameSinkSupport> support_; |
| 231 cc::LocalSurfaceId local_surface_id_; | 223 cc::LocalSurfaceId local_surface_id_; |
| 232 uint32_t next_surface_sequence_; | 224 uint32_t next_surface_sequence_; |
| 233 uint32_t last_compositor_frame_sink_id_; | 225 uint32_t last_compositor_frame_sink_id_; |
| 234 gfx::Size current_surface_size_; | 226 gfx::Size current_surface_size_; |
| 235 float current_surface_scale_factor_; | 227 float current_surface_scale_factor_; |
| 236 gfx::Rect last_screen_rect_; | 228 gfx::Rect last_screen_rect_; |
| 237 uint32_t ack_pending_count_; | |
| 238 cc::ReturnedResourceArray surface_returned_resources_; | |
| 239 | 229 |
| 240 // frame_connector_ provides a platform abstraction. Messages | 230 // frame_connector_ provides a platform abstraction. Messages |
| 241 // sent through it are routed to the embedding renderer process. | 231 // sent through it are routed to the embedding renderer process. |
| 242 CrossProcessFrameConnector* frame_connector_; | 232 CrossProcessFrameConnector* frame_connector_; |
| 243 | 233 |
| 244 base::WeakPtr<RenderWidgetHostViewChildFrame> AsWeakPtr() { | 234 base::WeakPtr<RenderWidgetHostViewChildFrame> AsWeakPtr() { |
| 245 return weak_factory_.GetWeakPtr(); | 235 return weak_factory_.GetWeakPtr(); |
| 246 } | 236 } |
| 247 | 237 |
| 248 private: | 238 private: |
| 249 virtual void SendSurfaceInfoToEmbedderImpl( | 239 virtual void SendSurfaceInfoToEmbedderImpl( |
| 250 const cc::SurfaceInfo& surface_info, | 240 const cc::SurfaceInfo& surface_info, |
| 251 const cc::SurfaceSequence& sequence); | 241 const cc::SurfaceSequence& sequence); |
| 252 | 242 |
| 253 void SubmitSurfaceCopyRequest(const gfx::Rect& src_subrect, | 243 void SubmitSurfaceCopyRequest(const gfx::Rect& src_subrect, |
| 254 const gfx::Size& dst_size, | 244 const gfx::Size& dst_size, |
| 255 const ReadbackRequestCallback& callback, | 245 const ReadbackRequestCallback& callback, |
| 256 const SkColorType preferred_color_type); | 246 const SkColorType preferred_color_type); |
| 257 | 247 |
| 248 void CreateCompositorFrameSinkSupport(); |
| 249 void ResetCompositorFrameSinkSupport(); |
| 250 |
| 258 using FrameSwappedCallbackList = std::deque<std::unique_ptr<base::Closure>>; | 251 using FrameSwappedCallbackList = std::deque<std::unique_ptr<base::Closure>>; |
| 259 // Since frame-drawn callbacks are "fire once", we use std::deque to make | 252 // Since frame-drawn callbacks are "fire once", we use std::deque to make |
| 260 // it convenient to swap() when processing the list. | 253 // it convenient to swap() when processing the list. |
| 261 FrameSwappedCallbackList frame_swapped_callbacks_; | 254 FrameSwappedCallbackList frame_swapped_callbacks_; |
| 262 | 255 |
| 263 // The begin frame source being observed. Null if none. | |
| 264 cc::BeginFrameSource* begin_frame_source_; | |
| 265 cc::BeginFrameArgs last_begin_frame_args_; | |
| 266 // The surface client ID of the parent RenderWidgetHostView. 0 if none. | 256 // The surface client ID of the parent RenderWidgetHostView. 0 if none. |
| 267 cc::FrameSinkId parent_frame_sink_id_; | 257 cc::FrameSinkId parent_frame_sink_id_; |
| 268 | 258 |
| 269 base::WeakPtrFactory<RenderWidgetHostViewChildFrame> weak_factory_; | 259 base::WeakPtrFactory<RenderWidgetHostViewChildFrame> weak_factory_; |
| 270 DISALLOW_COPY_AND_ASSIGN(RenderWidgetHostViewChildFrame); | 260 DISALLOW_COPY_AND_ASSIGN(RenderWidgetHostViewChildFrame); |
| 271 }; | 261 }; |
| 272 | 262 |
| 273 } // namespace content | 263 } // namespace content |
| 274 | 264 |
| 275 #endif // CONTENT_BROWSER_FRAME_HOST_RENDER_WIDGET_HOST_VIEW_CHILD_FRAME_H_ | 265 #endif // CONTENT_BROWSER_FRAME_HOST_RENDER_WIDGET_HOST_VIEW_CHILD_FRAME_H_ |
| OLD | NEW |