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 "content/renderer/child_frame_compositing_helper.h" | 5 #include "content/renderer/child_frame_compositing_helper.h" |
6 | 6 |
7 #include "cc/layers/delegated_frame_provider.h" | 7 #include "cc/layers/delegated_frame_provider.h" |
8 #include "cc/layers/delegated_frame_resource_collection.h" | 8 #include "cc/layers/delegated_frame_resource_collection.h" |
9 #include "cc/layers/delegated_renderer_layer.h" | 9 #include "cc/layers/delegated_renderer_layer.h" |
10 #include "cc/layers/solid_color_layer.h" | 10 #include "cc/layers/solid_color_layer.h" |
11 #include "cc/layers/texture_layer.h" | 11 #include "cc/layers/texture_layer.h" |
12 #include "cc/output/context_provider.h" | 12 #include "cc/output/context_provider.h" |
13 #include "cc/output/copy_output_request.h" | 13 #include "cc/output/copy_output_request.h" |
14 #include "cc/output/copy_output_result.h" | 14 #include "cc/output/copy_output_result.h" |
15 #include "cc/resources/single_release_callback.h" | 15 #include "cc/resources/single_release_callback.h" |
16 #include "content/common/browser_plugin/browser_plugin_messages.h" | 16 #include "content/common/browser_plugin/browser_plugin_messages.h" |
17 #include "content/common/frame_messages.h" | 17 #include "content/common/frame_messages.h" |
18 #include "content/common/gpu/client/context_provider_command_buffer.h" | 18 #include "content/common/gpu/client/context_provider_command_buffer.h" |
19 #include "content/renderer/browser_plugin/browser_plugin.h" | |
19 #include "content/renderer/browser_plugin/browser_plugin_manager.h" | 20 #include "content/renderer/browser_plugin/browser_plugin_manager.h" |
20 #include "content/renderer/render_frame_impl.h" | 21 #include "content/renderer/render_frame_impl.h" |
21 #include "content/renderer/render_thread_impl.h" | 22 #include "content/renderer/render_thread_impl.h" |
22 #include "skia/ext/image_operations.h" | 23 #include "skia/ext/image_operations.h" |
23 #include "third_party/WebKit/public/platform/WebGraphicsContext3D.h" | 24 #include "third_party/WebKit/public/platform/WebGraphicsContext3D.h" |
24 #include "third_party/WebKit/public/web/WebFrame.h" | 25 #include "third_party/WebKit/public/web/WebFrame.h" |
25 #include "third_party/WebKit/public/web/WebPluginContainer.h" | 26 #include "third_party/WebKit/public/web/WebPluginContainer.h" |
26 #include "third_party/khronos/GLES2/gl2.h" | 27 #include "third_party/khronos/GLES2/gl2.h" |
27 #include "ui/gfx/size_conversions.h" | 28 #include "ui/gfx/size_conversions.h" |
28 #include "ui/gfx/skia_util.h" | 29 #include "ui/gfx/skia_util.h" |
29 #include "webkit/renderer/compositor_bindings/web_layer_impl.h" | 30 #include "webkit/renderer/compositor_bindings/web_layer_impl.h" |
30 | 31 |
31 namespace content { | 32 namespace content { |
32 | 33 |
33 ChildFrameCompositingHelper::SwapBuffersInfo::SwapBuffersInfo() | 34 ChildFrameCompositingHelper::SwapBuffersInfo::SwapBuffersInfo() |
34 : route_id(0), | 35 : route_id(0), |
35 output_surface_id(0), | 36 output_surface_id(0), |
36 host_id(0), | 37 host_id(0), |
37 software_frame_id(0), | 38 software_frame_id(0), |
38 shared_memory(NULL) {} | 39 shared_memory(NULL) {} |
39 | 40 |
40 ChildFrameCompositingHelper* | 41 ChildFrameCompositingHelper* |
41 ChildFrameCompositingHelper::CreateCompositingHelperForBrowserPlugin( | 42 ChildFrameCompositingHelper::CreateCompositingHelperForBrowserPlugin( |
42 blink::WebPluginContainer* container, | 43 const base::WeakPtr<BrowserPlugin>& browser_plugin) { |
43 BrowserPluginManager* manager, | |
44 int instance_id, | |
45 int host_routing_id) { | |
46 return new ChildFrameCompositingHelper( | 44 return new ChildFrameCompositingHelper( |
47 container, NULL, manager, NULL, instance_id, host_routing_id); | 45 browser_plugin, NULL, NULL, browser_plugin->render_view_routing_id()); |
48 } | 46 } |
49 | 47 |
50 ChildFrameCompositingHelper* | 48 ChildFrameCompositingHelper* |
51 ChildFrameCompositingHelper::CreateCompositingHelperForRenderFrame( | 49 ChildFrameCompositingHelper::CreateCompositingHelperForRenderFrame( |
52 blink::WebFrame* frame, | 50 blink::WebFrame* frame, |
53 RenderFrameImpl* render_frame, | 51 RenderFrameImpl* render_frame, |
54 int host_routing_id) { | 52 int host_routing_id) { |
55 return new ChildFrameCompositingHelper( | 53 return new ChildFrameCompositingHelper( |
56 NULL, frame, NULL, render_frame, 0, host_routing_id); | 54 base::WeakPtr<BrowserPlugin>(), frame, render_frame, host_routing_id); |
57 } | 55 } |
58 | 56 |
59 ChildFrameCompositingHelper::ChildFrameCompositingHelper( | 57 ChildFrameCompositingHelper::ChildFrameCompositingHelper( |
60 blink::WebPluginContainer* container, | 58 const base::WeakPtr<BrowserPlugin>& browser_plugin, |
61 blink::WebFrame* frame, | 59 blink::WebFrame* frame, |
62 BrowserPluginManager* manager, | |
63 RenderFrameImpl* render_frame, | 60 RenderFrameImpl* render_frame, |
64 int instance_id, | |
65 int host_routing_id) | 61 int host_routing_id) |
66 : instance_id_(instance_id), | 62 : host_routing_id_(host_routing_id), |
67 host_routing_id_(host_routing_id), | |
68 last_route_id_(0), | 63 last_route_id_(0), |
69 last_output_surface_id_(0), | 64 last_output_surface_id_(0), |
70 last_host_id_(0), | 65 last_host_id_(0), |
71 last_mailbox_valid_(false), | 66 last_mailbox_valid_(false), |
72 ack_pending_(true), | 67 ack_pending_(true), |
73 software_ack_pending_(false), | 68 software_ack_pending_(false), |
74 opaque_(true), | 69 opaque_(true), |
75 container_(container), | |
76 frame_(frame), | 70 frame_(frame), |
77 browser_plugin_manager_(manager), | 71 browser_plugin_(browser_plugin), |
78 render_frame_(render_frame) {} | 72 render_frame_(render_frame) {} |
79 | 73 |
80 ChildFrameCompositingHelper::~ChildFrameCompositingHelper() {} | 74 ChildFrameCompositingHelper::~ChildFrameCompositingHelper() {} |
81 | 75 |
76 BrowserPluginManager* ChildFrameCompositingHelper::GetBrowserPluginManager() { | |
77 if (!browser_plugin_) | |
kenrb
2014/01/31 23:44:37
nit: is this check necessary? If BrowerPlugin owns
Fady Samuel
2014/02/03 18:04:20
I just attempted this. There are a couple of callb
| |
78 return NULL; | |
79 | |
80 return browser_plugin_->browser_plugin_manager(); | |
81 } | |
82 | |
83 blink::WebPluginContainer* ChildFrameCompositingHelper::GetContainer() { | |
84 if (!browser_plugin_) | |
85 return NULL; | |
86 | |
87 return browser_plugin_->container(); | |
88 } | |
89 | |
90 int ChildFrameCompositingHelper::GetInstanceID() { | |
91 if (!browser_plugin_) | |
92 return 0; | |
93 | |
94 return browser_plugin_->guest_instance_id(); | |
95 } | |
96 | |
82 void ChildFrameCompositingHelper::SendCompositorFrameSwappedACKToBrowser( | 97 void ChildFrameCompositingHelper::SendCompositorFrameSwappedACKToBrowser( |
83 FrameHostMsg_CompositorFrameSwappedACK_Params& params) { | 98 FrameHostMsg_CompositorFrameSwappedACK_Params& params) { |
84 // This function will be removed when BrowserPluginManager is removed and | 99 // This function will be removed when BrowserPluginManager is removed and |
85 // BrowserPlugin is modified to use a RenderFrame. | 100 // BrowserPlugin is modified to use a RenderFrame. |
86 if (browser_plugin_manager_) { | 101 if (GetBrowserPluginManager()) { |
87 browser_plugin_manager_->Send( | 102 GetBrowserPluginManager()->Send( |
88 new BrowserPluginHostMsg_CompositorFrameSwappedACK( | 103 new BrowserPluginHostMsg_CompositorFrameSwappedACK( |
89 host_routing_id_, instance_id_, params)); | 104 host_routing_id_, GetInstanceID(), params)); |
90 } else { | 105 } else if (render_frame_) { |
91 DCHECK(render_frame_); | |
92 render_frame_->Send( | 106 render_frame_->Send( |
93 new FrameHostMsg_CompositorFrameSwappedACK(host_routing_id_, params)); | 107 new FrameHostMsg_CompositorFrameSwappedACK(host_routing_id_, params)); |
94 } | 108 } |
95 } | 109 } |
96 | 110 |
97 void ChildFrameCompositingHelper::SendBuffersSwappedACKToBrowser( | 111 void ChildFrameCompositingHelper::SendBuffersSwappedACKToBrowser( |
98 FrameHostMsg_BuffersSwappedACK_Params& params) { | 112 FrameHostMsg_BuffersSwappedACK_Params& params) { |
99 // This function will be removed when BrowserPluginManager is removed and | 113 // This function will be removed when BrowserPluginManager is removed and |
100 // BrowserPlugin is modified to use a RenderFrame. | 114 // BrowserPlugin is modified to use a RenderFrame. |
101 if (browser_plugin_manager_) { | 115 if (GetBrowserPluginManager()) { |
102 browser_plugin_manager_->Send(new BrowserPluginHostMsg_BuffersSwappedACK( | 116 GetBrowserPluginManager()->Send(new BrowserPluginHostMsg_BuffersSwappedACK( |
103 host_routing_id_, instance_id_, params)); | 117 host_routing_id_, GetInstanceID(), params)); |
104 } else { | 118 } else if (render_frame_) { |
105 DCHECK(render_frame_); | |
106 render_frame_->Send( | 119 render_frame_->Send( |
107 new FrameHostMsg_BuffersSwappedACK(host_routing_id_, params)); | 120 new FrameHostMsg_BuffersSwappedACK(host_routing_id_, params)); |
108 } | 121 } |
109 } | 122 } |
110 | 123 |
111 void ChildFrameCompositingHelper::SendReclaimCompositorResourcesToBrowser( | 124 void ChildFrameCompositingHelper::SendReclaimCompositorResourcesToBrowser( |
112 FrameHostMsg_ReclaimCompositorResources_Params& params) { | 125 FrameHostMsg_ReclaimCompositorResources_Params& params) { |
113 // This function will be removed when BrowserPluginManager is removed and | 126 // This function will be removed when BrowserPluginManager is removed and |
114 // BrowserPlugin is modified to use a RenderFrame. | 127 // BrowserPlugin is modified to use a RenderFrame. |
115 if (browser_plugin_manager_) { | 128 if (GetBrowserPluginManager()) { |
116 browser_plugin_manager_->Send( | 129 GetBrowserPluginManager()->Send( |
117 new BrowserPluginHostMsg_ReclaimCompositorResources( | 130 new BrowserPluginHostMsg_ReclaimCompositorResources( |
118 host_routing_id_, instance_id_, params)); | 131 host_routing_id_, GetInstanceID(), params)); |
119 } else { | 132 } else if (render_frame_) { |
120 DCHECK(render_frame_); | |
121 render_frame_->Send( | 133 render_frame_->Send( |
122 new FrameHostMsg_ReclaimCompositorResources(host_routing_id_, params)); | 134 new FrameHostMsg_ReclaimCompositorResources(host_routing_id_, params)); |
123 } | 135 } |
124 } | 136 } |
125 | 137 |
126 void ChildFrameCompositingHelper::CopyFromCompositingSurface( | 138 void ChildFrameCompositingHelper::CopyFromCompositingSurface( |
127 int request_id, | 139 int request_id, |
128 gfx::Rect source_rect, | 140 gfx::Rect source_rect, |
129 gfx::Size dest_size) { | 141 gfx::Size dest_size) { |
130 CHECK(background_layer_); | 142 CHECK(background_layer_); |
(...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
170 | 182 |
171 void ChildFrameCompositingHelper::EnableCompositing(bool enable) { | 183 void ChildFrameCompositingHelper::EnableCompositing(bool enable) { |
172 if (enable && !background_layer_.get()) { | 184 if (enable && !background_layer_.get()) { |
173 background_layer_ = cc::SolidColorLayer::Create(); | 185 background_layer_ = cc::SolidColorLayer::Create(); |
174 background_layer_->SetMasksToBounds(true); | 186 background_layer_->SetMasksToBounds(true); |
175 background_layer_->SetBackgroundColor( | 187 background_layer_->SetBackgroundColor( |
176 SkColorSetARGBInline(255, 255, 255, 255)); | 188 SkColorSetARGBInline(255, 255, 255, 255)); |
177 web_layer_.reset(new webkit::WebLayerImpl(background_layer_)); | 189 web_layer_.reset(new webkit::WebLayerImpl(background_layer_)); |
178 } | 190 } |
179 | 191 |
180 if (container_) { | 192 if (GetContainer()) { |
181 container_->setWebLayer(enable ? web_layer_.get() : NULL); | 193 GetContainer()->setWebLayer(enable ? web_layer_.get() : NULL); |
182 } else { | 194 } else if (frame_) { |
183 frame_->setRemoteWebLayer(enable ? web_layer_.get() : NULL); | 195 frame_->setRemoteWebLayer(enable ? web_layer_.get() : NULL); |
184 } | 196 } |
185 } | 197 } |
186 | 198 |
187 void ChildFrameCompositingHelper::CheckSizeAndAdjustLayerProperties( | 199 void ChildFrameCompositingHelper::CheckSizeAndAdjustLayerProperties( |
188 const gfx::Size& new_size, | 200 const gfx::Size& new_size, |
189 float device_scale_factor, | 201 float device_scale_factor, |
190 cc::Layer* layer) { | 202 cc::Layer* layer) { |
191 if (buffer_size_ != new_size) { | 203 if (buffer_size_ != new_size) { |
192 buffer_size_ = new_size; | 204 buffer_size_ = new_size; |
(...skipping 62 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
255 params.ack.gl_frame_data->sync_point = sync_point; | 267 params.ack.gl_frame_data->sync_point = sync_point; |
256 SendCompositorFrameSwappedACKToBrowser(params); | 268 SendCompositorFrameSwappedACKToBrowser(params); |
257 break; | 269 break; |
258 } | 270 } |
259 case SOFTWARE_COMPOSITOR_FRAME: | 271 case SOFTWARE_COMPOSITOR_FRAME: |
260 break; | 272 break; |
261 } | 273 } |
262 } | 274 } |
263 | 275 |
264 void ChildFrameCompositingHelper::OnContainerDestroy() { | 276 void ChildFrameCompositingHelper::OnContainerDestroy() { |
265 if (container_) | 277 if (GetContainer()) |
266 container_->setWebLayer(NULL); | 278 GetContainer()->setWebLayer(NULL); |
267 container_ = NULL; | |
268 | 279 |
269 if (resource_collection_) | 280 if (resource_collection_) |
270 resource_collection_->SetClient(NULL); | 281 resource_collection_->SetClient(NULL); |
271 | 282 |
272 ack_pending_ = false; | 283 ack_pending_ = false; |
273 software_ack_pending_ = false; | 284 software_ack_pending_ = false; |
274 resource_collection_ = NULL; | 285 resource_collection_ = NULL; |
275 frame_provider_ = NULL; | 286 frame_provider_ = NULL; |
276 texture_layer_ = NULL; | 287 texture_layer_ = NULL; |
277 delegated_layer_ = NULL; | 288 delegated_layer_ = NULL; |
(...skipping 259 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
537 bitmap = result->TakeBitmap(); | 548 bitmap = result->TakeBitmap(); |
538 | 549 |
539 SkBitmap resized_bitmap; | 550 SkBitmap resized_bitmap; |
540 if (bitmap) { | 551 if (bitmap) { |
541 resized_bitmap = | 552 resized_bitmap = |
542 skia::ImageOperations::Resize(*bitmap, | 553 skia::ImageOperations::Resize(*bitmap, |
543 skia::ImageOperations::RESIZE_BEST, | 554 skia::ImageOperations::RESIZE_BEST, |
544 dest_size.width(), | 555 dest_size.width(), |
545 dest_size.height()); | 556 dest_size.height()); |
546 } | 557 } |
547 browser_plugin_manager_->Send( | 558 if (GetBrowserPluginManager()) { |
548 new BrowserPluginHostMsg_CopyFromCompositingSurfaceAck( | 559 GetBrowserPluginManager()->Send( |
549 host_routing_id_, instance_id_, request_id, resized_bitmap)); | 560 new BrowserPluginHostMsg_CopyFromCompositingSurfaceAck( |
561 host_routing_id_, GetInstanceID(), request_id, resized_bitmap)); | |
562 } | |
550 } | 563 } |
551 | 564 |
552 } // namespace content | 565 } // namespace content |
OLD | NEW |