OLD | NEW |
1 /* | 1 /* |
2 * Copyright (C) 2013 Google Inc. All rights reserved. | 2 * Copyright (C) 2013 Google Inc. All rights reserved. |
3 * | 3 * |
4 * Redistribution and use in source and binary forms, with or without | 4 * Redistribution and use in source and binary forms, with or without |
5 * modification, are permitted provided that the following conditions are | 5 * modification, are permitted provided that the following conditions are |
6 * met: | 6 * met: |
7 * | 7 * |
8 * * Redistributions of source code must retain the above copyright | 8 * * Redistributions of source code must retain the above copyright |
9 * notice, this list of conditions and the following disclaimer. | 9 * notice, this list of conditions and the following disclaimer. |
10 * * Redistributions in binary form must reproduce the above | 10 * * Redistributions in binary form must reproduce the above |
(...skipping 49 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
60 class SkiaImageDecoder final : public SkImageDeserializer { | 60 class SkiaImageDecoder final : public SkImageDeserializer { |
61 public: | 61 public: |
62 sk_sp<SkImage> makeFromMemory(const void* data, | 62 sk_sp<SkImage> makeFromMemory(const void* data, |
63 size_t length, | 63 size_t length, |
64 const SkIRect* subset) override { | 64 const SkIRect* subset) override { |
65 // No need to copy the data; this decodes immediately. | 65 // No need to copy the data; this decodes immediately. |
66 RefPtr<SegmentReader> segmentReader = | 66 RefPtr<SegmentReader> segmentReader = |
67 SegmentReader::createFromSkData(SkData::MakeWithoutCopy(data, length)); | 67 SegmentReader::createFromSkData(SkData::MakeWithoutCopy(data, length)); |
68 std::unique_ptr<ImageDecoder> imageDecoder = ImageDecoder::create( | 68 std::unique_ptr<ImageDecoder> imageDecoder = ImageDecoder::create( |
69 segmentReader.release(), true, ImageDecoder::AlphaPremultiplied, | 69 segmentReader.release(), true, ImageDecoder::AlphaPremultiplied, |
70 ImageDecoder::GammaAndColorProfileIgnored); | 70 ImageDecoder::ColorSpaceIgnored); |
71 if (!imageDecoder) | 71 if (!imageDecoder) |
72 return nullptr; | 72 return nullptr; |
73 | 73 |
74 ImageFrame* frame = imageDecoder->frameBufferAtIndex(0); | 74 ImageFrame* frame = imageDecoder->frameBufferAtIndex(0); |
75 return (frame && !imageDecoder->failed()) | 75 return (frame && !imageDecoder->failed()) |
76 ? frame->finalizePixelsAndGetImage() | 76 ? frame->finalizePixelsAndGetImage() |
77 : nullptr; | 77 : nullptr; |
78 } | 78 } |
79 sk_sp<SkImage> makeFromData(SkData* data, const SkIRect* subset) override { | 79 sk_sp<SkImage> makeFromData(SkData* data, const SkIRect* subset) override { |
80 return this->makeFromMemory(data->data(), data->size(), subset); | 80 return this->makeFromMemory(data->data(), data->size(), subset); |
(...skipping 115 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
196 } | 196 } |
197 | 197 |
198 std::unique_ptr<JSONArray> PictureSnapshot::snapshotCommandLog() const { | 198 std::unique_ptr<JSONArray> PictureSnapshot::snapshotCommandLog() const { |
199 const SkIRect bounds = m_picture->cullRect().roundOut(); | 199 const SkIRect bounds = m_picture->cullRect().roundOut(); |
200 LoggingCanvas canvas(bounds.width(), bounds.height()); | 200 LoggingCanvas canvas(bounds.width(), bounds.height()); |
201 m_picture->playback(&canvas); | 201 m_picture->playback(&canvas); |
202 return canvas.log(); | 202 return canvas.log(); |
203 } | 203 } |
204 | 204 |
205 } // namespace blink | 205 } // namespace blink |
OLD | NEW |