| OLD | NEW |
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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/raster/gpu_rasterizer.h" | 5 #include "cc/raster/gpu_rasterizer.h" |
| 6 | 6 |
| 7 #include <algorithm> | 7 #include <algorithm> |
| 8 | 8 |
| 9 #include "base/bind.h" | 9 #include "base/bind.h" |
| 10 #include "base/metrics/histogram.h" | 10 #include "base/metrics/histogram.h" |
| (...skipping 37 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 48 SkPictureRecorder recorder; | 48 SkPictureRecorder recorder; |
| 49 const gfx::Size size = write_lock->GetResourceSize(); | 49 const gfx::Size size = write_lock->GetResourceSize(); |
| 50 const int flags = SkPictureRecorder::kComputeSaveLayerInfo_RecordFlag; | 50 const int flags = SkPictureRecorder::kComputeSaveLayerInfo_RecordFlag; |
| 51 skia::RefPtr<SkCanvas> canvas = skia::SharePtr( | 51 skia::RefPtr<SkCanvas> canvas = skia::SharePtr( |
| 52 recorder.beginRecording(size.width(), size.height(), NULL, flags)); | 52 recorder.beginRecording(size.width(), size.height(), NULL, flags)); |
| 53 canvas->save(); | 53 canvas->save(); |
| 54 const bool include_images = true; | 54 const bool include_images = true; |
| 55 raster_source->PlaybackToCanvas(canvas.get(), raster_full_rect, playback_rect, | 55 raster_source->PlaybackToCanvas(canvas.get(), raster_full_rect, playback_rect, |
| 56 scale, include_images); | 56 scale, include_images); |
| 57 canvas->restore(); | 57 canvas->restore(); |
| 58 skia::RefPtr<SkPicture> picture = | 58 sk_sp<SkPicture> picture = recorder.finishRecordingAsPicture(); |
| 59 skia::AdoptRef(recorder.endRecordingAsPicture()); | |
| 60 | 59 |
| 61 // Turn on distance fields for layers that have ever animated. | 60 // Turn on distance fields for layers that have ever animated. |
| 62 bool use_distance_field_text = | 61 bool use_distance_field_text = |
| 63 use_distance_field_text_ || | 62 use_distance_field_text_ || |
| 64 raster_source->ShouldAttemptToUseDistanceFieldText(); | 63 raster_source->ShouldAttemptToUseDistanceFieldText(); |
| 65 | 64 |
| 66 // Playback picture into resource. | 65 // Playback picture into resource. |
| 67 { | 66 { |
| 68 ScopedGpuRaster gpu_raster( | 67 ScopedGpuRaster gpu_raster( |
| 69 resource_provider_->output_surface()->worker_context_provider()); | 68 resource_provider_->output_surface()->worker_context_provider()); |
| 70 write_lock->InitSkSurface(use_distance_field_text, | 69 write_lock->InitSkSurface(use_distance_field_text, |
| 71 raster_source->CanUseLCDText(), | 70 raster_source->CanUseLCDText(), |
| 72 msaa_sample_count_); | 71 msaa_sample_count_); |
| 73 | 72 |
| 74 SkSurface* sk_surface = write_lock->sk_surface(); | 73 SkSurface* sk_surface = write_lock->sk_surface(); |
| 75 | 74 |
| 76 // Allocating an SkSurface will fail after a lost context. Pretend we | 75 // Allocating an SkSurface will fail after a lost context. Pretend we |
| 77 // rasterized, as the contents of the resource don't matter anymore. | 76 // rasterized, as the contents of the resource don't matter anymore. |
| 78 if (!sk_surface) | 77 if (!sk_surface) |
| 79 return; | 78 return; |
| 80 | 79 |
| 81 SkMultiPictureDraw multi_picture_draw; | 80 SkMultiPictureDraw multi_picture_draw; |
| 82 multi_picture_draw.add(sk_surface->getCanvas(), picture.get()); | 81 multi_picture_draw.add(sk_surface->getCanvas(), picture.get()); |
| 83 multi_picture_draw.draw(false); | 82 multi_picture_draw.draw(false); |
| 84 write_lock->ReleaseSkSurface(); | 83 write_lock->ReleaseSkSurface(); |
| 85 } | 84 } |
| 86 } | 85 } |
| 87 | 86 |
| 88 } // namespace cc | 87 } // namespace cc |
| OLD | NEW |