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 |