| 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/direct_renderer.h" | 5 #include "cc/output/direct_renderer.h" |
| 6 | 6 |
| 7 #include <utility> | 7 #include <utility> |
| 8 #include <vector> | 8 #include <vector> |
| 9 | 9 |
| 10 #include "base/containers/hash_tables.h" | 10 #include "base/containers/hash_tables.h" |
| (...skipping 133 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 144 const gfx::Vector2d& amount) { | 144 const gfx::Vector2d& amount) { |
| 145 enlarge_pass_texture_amount_ = amount; | 145 enlarge_pass_texture_amount_ = amount; |
| 146 } | 146 } |
| 147 | 147 |
| 148 void DirectRenderer::DecideRenderPassAllocationsForFrame( | 148 void DirectRenderer::DecideRenderPassAllocationsForFrame( |
| 149 const RenderPassList& render_passes_in_draw_order) { | 149 const RenderPassList& render_passes_in_draw_order) { |
| 150 base::hash_map<RenderPassId, gfx::Size> render_passes_in_frame; | 150 base::hash_map<RenderPassId, gfx::Size> render_passes_in_frame; |
| 151 for (size_t i = 0; i < render_passes_in_draw_order.size(); ++i) | 151 for (size_t i = 0; i < render_passes_in_draw_order.size(); ++i) |
| 152 render_passes_in_frame.insert(std::pair<RenderPassId, gfx::Size>( | 152 render_passes_in_frame.insert(std::pair<RenderPassId, gfx::Size>( |
| 153 render_passes_in_draw_order[i]->id, | 153 render_passes_in_draw_order[i]->id, |
| 154 RenderPassTextureSize(render_passes_in_draw_order[i]))); | 154 RenderPassTextureSize(render_passes_in_draw_order[i].get()))); |
| 155 | 155 |
| 156 std::vector<RenderPassId> passes_to_delete; | 156 std::vector<RenderPassId> passes_to_delete; |
| 157 for (auto pass_iter = render_pass_textures_.begin(); | 157 for (auto pass_iter = render_pass_textures_.begin(); |
| 158 pass_iter != render_pass_textures_.end(); ++pass_iter) { | 158 pass_iter != render_pass_textures_.end(); ++pass_iter) { |
| 159 base::hash_map<RenderPassId, gfx::Size>::const_iterator it = | 159 base::hash_map<RenderPassId, gfx::Size>::const_iterator it = |
| 160 render_passes_in_frame.find(pass_iter->first); | 160 render_passes_in_frame.find(pass_iter->first); |
| 161 if (it == render_passes_in_frame.end()) { | 161 if (it == render_passes_in_frame.end()) { |
| 162 passes_to_delete.push_back(pass_iter->first); | 162 passes_to_delete.push_back(pass_iter->first); |
| 163 continue; | 163 continue; |
| 164 } | 164 } |
| (...skipping 26 matching lines...) Expand all Loading... |
| 191 void DirectRenderer::DrawFrame(RenderPassList* render_passes_in_draw_order, | 191 void DirectRenderer::DrawFrame(RenderPassList* render_passes_in_draw_order, |
| 192 float device_scale_factor, | 192 float device_scale_factor, |
| 193 const gfx::Rect& device_viewport_rect, | 193 const gfx::Rect& device_viewport_rect, |
| 194 const gfx::Rect& device_clip_rect, | 194 const gfx::Rect& device_clip_rect, |
| 195 bool disable_picture_quad_image_filtering) { | 195 bool disable_picture_quad_image_filtering) { |
| 196 TRACE_EVENT0("cc", "DirectRenderer::DrawFrame"); | 196 TRACE_EVENT0("cc", "DirectRenderer::DrawFrame"); |
| 197 UMA_HISTOGRAM_COUNTS( | 197 UMA_HISTOGRAM_COUNTS( |
| 198 "Renderer4.renderPassCount", | 198 "Renderer4.renderPassCount", |
| 199 base::saturated_cast<int>(render_passes_in_draw_order->size())); | 199 base::saturated_cast<int>(render_passes_in_draw_order->size())); |
| 200 | 200 |
| 201 const RenderPass* root_render_pass = render_passes_in_draw_order->back(); | 201 const RenderPass* root_render_pass = |
| 202 render_passes_in_draw_order->back().get(); |
| 202 DCHECK(root_render_pass); | 203 DCHECK(root_render_pass); |
| 203 | 204 |
| 204 DrawingFrame frame; | 205 DrawingFrame frame; |
| 205 frame.render_passes_in_draw_order = render_passes_in_draw_order; | 206 frame.render_passes_in_draw_order = render_passes_in_draw_order; |
| 206 frame.root_render_pass = root_render_pass; | 207 frame.root_render_pass = root_render_pass; |
| 207 frame.root_damage_rect = Capabilities().using_partial_swap | 208 frame.root_damage_rect = Capabilities().using_partial_swap |
| 208 ? root_render_pass->damage_rect | 209 ? root_render_pass->damage_rect |
| 209 : root_render_pass->output_rect; | 210 : root_render_pass->output_rect; |
| 210 frame.root_damage_rect.Intersect(gfx::Rect(device_viewport_rect.size())); | 211 frame.root_damage_rect.Intersect(gfx::Rect(device_viewport_rect.size())); |
| 211 frame.device_viewport_rect = device_viewport_rect; | 212 frame.device_viewport_rect = device_viewport_rect; |
| (...skipping 28 matching lines...) Expand all Loading... |
| 240 // otherwise the framebuffer will be missing the overlay contents. | 241 // otherwise the framebuffer will be missing the overlay contents. |
| 241 if (root_render_pass->copy_requests.empty()) { | 242 if (root_render_pass->copy_requests.empty()) { |
| 242 overlay_processor_->ProcessForOverlays( | 243 overlay_processor_->ProcessForOverlays( |
| 243 resource_provider_, render_passes_in_draw_order, &frame.overlay_list, | 244 resource_provider_, render_passes_in_draw_order, &frame.overlay_list, |
| 244 &frame.root_damage_rect); | 245 &frame.root_damage_rect); |
| 245 | 246 |
| 246 // No need to render in case the damage rect is completely composited using | 247 // No need to render in case the damage rect is completely composited using |
| 247 // overlays and dont have any copy requests. | 248 // overlays and dont have any copy requests. |
| 248 if (frame.root_damage_rect.IsEmpty()) { | 249 if (frame.root_damage_rect.IsEmpty()) { |
| 249 bool handle_copy_requests = false; | 250 bool handle_copy_requests = false; |
| 250 for (auto* pass : *render_passes_in_draw_order) { | 251 for (const auto& pass : *render_passes_in_draw_order) { |
| 251 if (!pass->copy_requests.empty()) { | 252 if (!pass->copy_requests.empty()) { |
| 252 handle_copy_requests = true; | 253 handle_copy_requests = true; |
| 253 break; | 254 break; |
| 254 } | 255 } |
| 255 } | 256 } |
| 256 | 257 |
| 257 if (!handle_copy_requests) { | 258 if (!handle_copy_requests) { |
| 258 BindFramebufferToOutputSurface(&frame); | 259 BindFramebufferToOutputSurface(&frame); |
| 259 FinishDrawingFrame(&frame); | 260 FinishDrawingFrame(&frame); |
| 260 render_passes_in_draw_order->clear(); | 261 render_passes_in_draw_order->clear(); |
| 261 return; | 262 return; |
| 262 } | 263 } |
| 263 } | 264 } |
| 264 } | 265 } |
| 265 | 266 |
| 266 for (size_t i = 0; i < render_passes_in_draw_order->size(); ++i) { | 267 for (const auto& pass : *render_passes_in_draw_order) { |
| 267 RenderPass* pass = render_passes_in_draw_order->at(i); | 268 DrawRenderPass(&frame, pass.get()); |
| 268 DrawRenderPass(&frame, pass); | |
| 269 | 269 |
| 270 for (ScopedPtrVector<CopyOutputRequest>::iterator it = | 270 bool first_request = true; |
| 271 pass->copy_requests.begin(); | 271 for (auto& copy_request : pass->copy_requests) { |
| 272 it != pass->copy_requests.end(); | 272 // Doing a readback is destructive of our state on Mac, so make sure |
| 273 ++it) { | 273 // we restore the state between readbacks. http://crbug.com/99393. |
| 274 if (it != pass->copy_requests.begin()) { | 274 if (!first_request) |
| 275 // Doing a readback is destructive of our state on Mac, so make sure | 275 UseRenderPass(&frame, pass.get()); |
| 276 // we restore the state between readbacks. http://crbug.com/99393. | 276 CopyCurrentRenderPassToBitmap(&frame, std::move(copy_request)); |
| 277 UseRenderPass(&frame, pass); | 277 first_request = false; |
| 278 } | |
| 279 CopyCurrentRenderPassToBitmap(&frame, pass->copy_requests.take(it)); | |
| 280 } | 278 } |
| 281 } | 279 } |
| 282 FinishDrawingFrame(&frame); | 280 FinishDrawingFrame(&frame); |
| 283 | 281 |
| 284 render_passes_in_draw_order->clear(); | 282 render_passes_in_draw_order->clear(); |
| 285 } | 283 } |
| 286 | 284 |
| 287 gfx::Rect DirectRenderer::ComputeScissorRectForRenderPass( | 285 gfx::Rect DirectRenderer::ComputeScissorRectForRenderPass( |
| 288 const DrawingFrame* frame) { | 286 const DrawingFrame* frame) { |
| 289 gfx::Rect render_pass_scissor = frame->current_render_pass->output_rect; | 287 gfx::Rect render_pass_scissor = frame->current_render_pass->output_rect; |
| (...skipping 267 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 557 ScopedResource* texture = render_pass_textures_.get(id); | 555 ScopedResource* texture = render_pass_textures_.get(id); |
| 558 return texture && texture->id(); | 556 return texture && texture->id(); |
| 559 } | 557 } |
| 560 | 558 |
| 561 // static | 559 // static |
| 562 gfx::Size DirectRenderer::RenderPassTextureSize(const RenderPass* render_pass) { | 560 gfx::Size DirectRenderer::RenderPassTextureSize(const RenderPass* render_pass) { |
| 563 return render_pass->output_rect.size(); | 561 return render_pass->output_rect.size(); |
| 564 } | 562 } |
| 565 | 563 |
| 566 } // namespace cc | 564 } // namespace cc |
| OLD | NEW |