Chromium Code Reviews| 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 |