| 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 |