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/software_renderer.h" | 5 #include "cc/output/software_renderer.h" |
6 | 6 |
7 #include "base/memory/ptr_util.h" | 7 #include "base/memory/ptr_util.h" |
8 #include "base/trace_event/trace_event.h" | 8 #include "base/trace_event/trace_event.h" |
9 #include "cc/base/math_util.h" | 9 #include "cc/base/math_util.h" |
| 10 #include "cc/base/scale_translate2d.h" |
10 #include "cc/output/compositor_frame.h" | 11 #include "cc/output/compositor_frame.h" |
11 #include "cc/output/compositor_frame_metadata.h" | 12 #include "cc/output/compositor_frame_metadata.h" |
12 #include "cc/output/copy_output_request.h" | 13 #include "cc/output/copy_output_request.h" |
13 #include "cc/output/output_surface.h" | 14 #include "cc/output/output_surface.h" |
14 #include "cc/output/render_surface_filters.h" | 15 #include "cc/output/render_surface_filters.h" |
15 #include "cc/output/renderer_settings.h" | 16 #include "cc/output/renderer_settings.h" |
16 #include "cc/output/software_output_device.h" | 17 #include "cc/output/software_output_device.h" |
17 #include "cc/quads/debug_border_draw_quad.h" | 18 #include "cc/quads/debug_border_draw_quad.h" |
18 #include "cc/quads/picture_draw_quad.h" | 19 #include "cc/quads/picture_draw_quad.h" |
19 #include "cc/quads/render_pass_draw_quad.h" | 20 #include "cc/quads/render_pass_draw_quad.h" |
(...skipping 335 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
355 // cases and fall back to a persistent bitmap backing | 356 // cases and fall back to a persistent bitmap backing |
356 // (http://crbug.com/280374). | 357 // (http://crbug.com/280374). |
357 // TODO(vmpstr): Fold this canvas into playback and have raster source | 358 // TODO(vmpstr): Fold this canvas into playback and have raster source |
358 // accept a set of settings on playback that will determine which canvas to | 359 // accept a set of settings on playback that will determine which canvas to |
359 // apply. (http://crbug.com/594679) | 360 // apply. (http://crbug.com/594679) |
360 skia::OpacityFilterCanvas filtered_canvas(current_canvas_, | 361 skia::OpacityFilterCanvas filtered_canvas(current_canvas_, |
361 quad->shared_quad_state->opacity, | 362 quad->shared_quad_state->opacity, |
362 disable_image_filtering); | 363 disable_image_filtering); |
363 quad->raster_source->PlaybackToCanvas( | 364 quad->raster_source->PlaybackToCanvas( |
364 &filtered_canvas, quad->content_rect, quad->content_rect, | 365 &filtered_canvas, quad->content_rect, quad->content_rect, |
365 quad->contents_scale, playback_settings); | 366 ScaleTranslate2d(quad->contents_scale, gfx::Vector2dF()), |
| 367 playback_settings); |
366 } else { | 368 } else { |
367 quad->raster_source->PlaybackToCanvas( | 369 quad->raster_source->PlaybackToCanvas( |
368 current_canvas_, quad->content_rect, quad->content_rect, | 370 current_canvas_, quad->content_rect, quad->content_rect, |
369 quad->contents_scale, playback_settings); | 371 ScaleTranslate2d(quad->contents_scale, gfx::Vector2dF()), |
| 372 playback_settings); |
370 } | 373 } |
371 } | 374 } |
372 | 375 |
373 void SoftwareRenderer::DrawSolidColorQuad(const DrawingFrame* frame, | 376 void SoftwareRenderer::DrawSolidColorQuad(const DrawingFrame* frame, |
374 const SolidColorDrawQuad* quad) { | 377 const SolidColorDrawQuad* quad) { |
375 gfx::RectF visible_quad_vertex_rect = MathUtil::ScaleRectProportional( | 378 gfx::RectF visible_quad_vertex_rect = MathUtil::ScaleRectProportional( |
376 QuadVertexRect(), gfx::RectF(quad->rect), gfx::RectF(quad->visible_rect)); | 379 QuadVertexRect(), gfx::RectF(quad->rect), gfx::RectF(quad->visible_rect)); |
377 current_paint_.setColor(quad->color); | 380 current_paint_.setColor(quad->color); |
378 current_paint_.setAlpha(quad->shared_quad_state->opacity * | 381 current_paint_.setAlpha(quad->shared_quad_state->opacity * |
379 SkColorGetA(quad->color)); | 382 SkColorGetA(quad->color)); |
(...skipping 329 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
709 ApplyImageFilter(filter.get(), quad, backdrop_bitmap, nullptr); | 712 ApplyImageFilter(filter.get(), quad, backdrop_bitmap, nullptr); |
710 | 713 |
711 if (!filter_backdrop_image) | 714 if (!filter_backdrop_image) |
712 return nullptr; | 715 return nullptr; |
713 | 716 |
714 return filter_backdrop_image->makeShader(content_tile_mode, content_tile_mode, | 717 return filter_backdrop_image->makeShader(content_tile_mode, content_tile_mode, |
715 &filter_backdrop_transform); | 718 &filter_backdrop_transform); |
716 } | 719 } |
717 | 720 |
718 } // namespace cc | 721 } // namespace cc |
OLD | NEW |