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/trace_event/trace_event.h" | 7 #include "base/trace_event/trace_event.h" |
8 #include "cc/base/math_util.h" | 8 #include "cc/base/math_util.h" |
9 #include "cc/output/compositor_frame.h" | 9 #include "cc/output/compositor_frame.h" |
10 #include "cc/output/compositor_frame_ack.h" | 10 #include "cc/output/compositor_frame_ack.h" |
(...skipping 348 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
359 SkMatrix::kFill_ScaleToFit); | 359 SkMatrix::kFill_ScaleToFit); |
360 current_canvas_->concat(content_matrix); | 360 current_canvas_->concat(content_matrix); |
361 | 361 |
362 const bool needs_transparency = | 362 const bool needs_transparency = |
363 SkScalarRoundToInt(quad->shared_quad_state->opacity * 255) < 255; | 363 SkScalarRoundToInt(quad->shared_quad_state->opacity * 255) < 255; |
364 const bool disable_image_filtering = | 364 const bool disable_image_filtering = |
365 frame->disable_picture_quad_image_filtering || quad->nearest_neighbor; | 365 frame->disable_picture_quad_image_filtering || quad->nearest_neighbor; |
366 | 366 |
367 TRACE_EVENT0("cc", "SoftwareRenderer::DrawPictureQuad"); | 367 TRACE_EVENT0("cc", "SoftwareRenderer::DrawPictureQuad"); |
368 | 368 |
369 const bool include_images = true; | 369 RasterSource::PlaybackSettings playback_settings; |
| 370 playback_settings.playback_to_shared_canvas = true; |
370 if (needs_transparency || disable_image_filtering) { | 371 if (needs_transparency || disable_image_filtering) { |
371 // TODO(aelias): This isn't correct in all cases. We should detect these | 372 // TODO(aelias): This isn't correct in all cases. We should detect these |
372 // cases and fall back to a persistent bitmap backing | 373 // cases and fall back to a persistent bitmap backing |
373 // (http://crbug.com/280374). | 374 // (http://crbug.com/280374). |
374 // TODO(vmpstr): Fold this canvas into playback and have raster source | 375 // TODO(vmpstr): Fold this canvas into playback and have raster source |
375 // accept a set of settings on playback that will determine which canvas to | 376 // accept a set of settings on playback that will determine which canvas to |
376 // apply. (http://crbug.com/594679) | 377 // apply. (http://crbug.com/594679) |
377 skia::OpacityFilterCanvas filtered_canvas(current_canvas_, | 378 skia::OpacityFilterCanvas filtered_canvas(current_canvas_, |
378 quad->shared_quad_state->opacity, | 379 quad->shared_quad_state->opacity, |
379 disable_image_filtering); | 380 disable_image_filtering); |
380 quad->raster_source->PlaybackToSharedCanvas( | 381 quad->raster_source->PlaybackToCanvas( |
381 &filtered_canvas, quad->content_rect, quad->contents_scale, | 382 &filtered_canvas, quad->content_rect, quad->content_rect, |
382 include_images); | 383 quad->contents_scale, playback_settings); |
383 } else { | 384 } else { |
384 quad->raster_source->PlaybackToSharedCanvas( | 385 quad->raster_source->PlaybackToCanvas( |
385 current_canvas_, quad->content_rect, quad->contents_scale, | 386 current_canvas_, quad->content_rect, quad->content_rect, |
386 include_images); | 387 quad->contents_scale, playback_settings); |
387 } | 388 } |
388 } | 389 } |
389 | 390 |
390 void SoftwareRenderer::DrawSolidColorQuad(const DrawingFrame* frame, | 391 void SoftwareRenderer::DrawSolidColorQuad(const DrawingFrame* frame, |
391 const SolidColorDrawQuad* quad) { | 392 const SolidColorDrawQuad* quad) { |
392 gfx::RectF visible_quad_vertex_rect = MathUtil::ScaleRectProportional( | 393 gfx::RectF visible_quad_vertex_rect = MathUtil::ScaleRectProportional( |
393 QuadVertexRect(), gfx::RectF(quad->rect), gfx::RectF(quad->visible_rect)); | 394 QuadVertexRect(), gfx::RectF(quad->rect), gfx::RectF(quad->visible_rect)); |
394 current_paint_.setColor(quad->color); | 395 current_paint_.setColor(quad->color); |
395 current_paint_.setAlpha(quad->shared_quad_state->opacity * | 396 current_paint_.setAlpha(quad->shared_quad_state->opacity * |
396 SkColorGetA(quad->color)); | 397 SkColorGetA(quad->color)); |
(...skipping 319 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
716 ApplyImageFilter(filter.get(), quad, &backdrop_bitmap); | 717 ApplyImageFilter(filter.get(), quad, &backdrop_bitmap); |
717 | 718 |
718 if (!filter_backdrop_image) | 719 if (!filter_backdrop_image) |
719 return nullptr; | 720 return nullptr; |
720 | 721 |
721 return filter_backdrop_image->makeShader(content_tile_mode, content_tile_mode, | 722 return filter_backdrop_image->makeShader(content_tile_mode, content_tile_mode, |
722 &filter_backdrop_transform); | 723 &filter_backdrop_transform); |
723 } | 724 } |
724 | 725 |
725 } // namespace cc | 726 } // namespace cc |
OLD | NEW |