| OLD | NEW |
| 1 // Copyright 2012 The Chromium Authors. All rights reserved. | 1 // Copyright 2012 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 "cc/output/delegating_renderer.h" | 5 #include "cc/output/delegating_renderer.h" |
| 6 | 6 |
| 7 #include <set> | 7 #include <set> |
| 8 #include <string> | 8 #include <string> |
| 9 #include <utility> |
| 9 #include <vector> | 10 #include <vector> |
| 10 | 11 |
| 11 #include "base/memory/ptr_util.h" | 12 #include "base/memory/ptr_util.h" |
| 12 #include "base/trace_event/trace_event.h" | 13 #include "base/trace_event/trace_event.h" |
| 13 #include "cc/output/context_provider.h" | 14 #include "cc/output/context_provider.h" |
| 14 #include "cc/quads/draw_quad.h" | 15 #include "cc/quads/draw_quad.h" |
| 15 #include "cc/quads/render_pass.h" | 16 #include "cc/quads/render_pass.h" |
| 16 #include "cc/resources/resource_provider.h" | 17 #include "cc/resources/resource_provider.h" |
| 17 #include "gpu/command_buffer/client/context_support.h" | 18 #include "gpu/command_buffer/client/context_support.h" |
| 18 #include "gpu/command_buffer/client/gles2_interface.h" | |
| 19 | 19 |
| 20 | 20 |
| 21 namespace cc { | 21 namespace cc { |
| 22 | 22 |
| 23 DelegatingRenderer::DelegatingRenderer(OutputSurface* output_surface, | 23 DelegatingRenderer::DelegatingRenderer(OutputSurface* output_surface, |
| 24 ResourceProvider* resource_provider) | 24 ResourceProvider* resource_provider) |
| 25 : output_surface_(output_surface), resource_provider_(resource_provider) { | 25 : output_surface_(output_surface), resource_provider_(resource_provider) { |
| 26 DCHECK(resource_provider_); | 26 DCHECK(resource_provider_); |
| 27 } | 27 } |
| 28 | 28 |
| 29 DelegatingRenderer::~DelegatingRenderer() = default; | 29 DelegatingRenderer::~DelegatingRenderer() = default; |
| 30 | 30 |
| 31 void DelegatingRenderer::DrawFrame( | 31 void DelegatingRenderer::DrawFrame(CompositorFrameMetadata metadata, |
| 32 RenderPassList* render_passes_in_draw_order) { | 32 RenderPassList render_passes_in_draw_order) { |
| 33 TRACE_EVENT0("cc", "DelegatingRenderer::DrawFrame"); | 33 TRACE_EVENT0("cc", "DelegatingRenderer::DrawFrame"); |
| 34 | 34 |
| 35 delegated_frame_data_ = base::WrapUnique(new DelegatedFrameData); | 35 // Collect all resource ids in the render passes into a single array. |
| 36 DelegatedFrameData& out_data = *delegated_frame_data_; | |
| 37 // Move the render passes and resources into the |out_frame|. | |
| 38 out_data.render_pass_list.swap(*render_passes_in_draw_order); | |
| 39 | |
| 40 // Collect all resource ids in the render passes into a ResourceIdArray. | |
| 41 ResourceProvider::ResourceIdArray resources; | 36 ResourceProvider::ResourceIdArray resources; |
| 42 for (const auto& render_pass : out_data.render_pass_list) { | 37 for (const auto& render_pass : render_passes_in_draw_order) { |
| 43 for (auto* quad : render_pass->quad_list) { | 38 for (auto* quad : render_pass->quad_list) { |
| 44 for (ResourceId resource_id : quad->resources) | 39 for (ResourceId resource_id : quad->resources) |
| 45 resources.push_back(resource_id); | 40 resources.push_back(resource_id); |
| 46 } | 41 } |
| 47 } | 42 } |
| 48 resource_provider_->PrepareSendToParent(resources, &out_data.resource_list); | |
| 49 } | |
| 50 | 43 |
| 51 void DelegatingRenderer::SwapBuffers(CompositorFrameMetadata metadata) { | 44 auto data = base::MakeUnique<DelegatedFrameData>(); |
| 52 TRACE_EVENT0("cc,benchmark", "DelegatingRenderer::SwapBuffers"); | 45 resource_provider_->PrepareSendToParent(resources, &data->resource_list); |
| 46 data->render_pass_list = std::move(render_passes_in_draw_order); |
| 47 |
| 53 CompositorFrame compositor_frame; | 48 CompositorFrame compositor_frame; |
| 54 compositor_frame.metadata = std::move(metadata); | 49 compositor_frame.metadata = std::move(metadata); |
| 55 compositor_frame.delegated_frame_data = std::move(delegated_frame_data_); | 50 compositor_frame.delegated_frame_data = std::move(data); |
| 56 output_surface_->SwapBuffers(std::move(compositor_frame)); | 51 output_surface_->SwapBuffers(std::move(compositor_frame)); |
| 57 } | 52 } |
| 58 | 53 |
| 59 } // namespace cc | 54 } // namespace cc |
| OLD | NEW |