Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(237)

Side by Side Diff: third_party/WebKit/Source/platform/image-decoders/webp/WEBPImageDecoder.h

Issue 1812273003: Eliminate copies of encoded image data (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Rebase Created 4 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 /* 1 /*
2 * Copyright (C) 2010 Google Inc. All rights reserved. 2 * Copyright (C) 2010 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 5 * modification, are permitted provided that the following conditions
6 * are met: 6 * are met:
7 * 7 *
8 * 1. Redistributions of source code must retain the above copyright 8 * 1. 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 * 2. Redistributions in binary form must reproduce the above copyright 10 * 2. Redistributions in binary form must reproduce the above copyright
(...skipping 12 matching lines...) Expand all
23 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND 23 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
24 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 24 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF 25 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 26 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27 */ 27 */
28 28
29 #ifndef WEBPImageDecoder_h 29 #ifndef WEBPImageDecoder_h
30 #define WEBPImageDecoder_h 30 #define WEBPImageDecoder_h
31 31
32 #include "platform/image-decoders/ImageDecoder.h" 32 #include "platform/image-decoders/ImageDecoder.h"
33 #include "third_party/skia/include/core/SkData.h"
33 #include "webp/decode.h" 34 #include "webp/decode.h"
34 #include "webp/demux.h" 35 #include "webp/demux.h"
36 #include "wtf/RefPtr.h"
35 37
36 namespace blink { 38 namespace blink {
37 39
38 class PLATFORM_EXPORT WEBPImageDecoder final : public ImageDecoder { 40 class PLATFORM_EXPORT WEBPImageDecoder final : public ImageDecoder {
39 WTF_MAKE_NONCOPYABLE(WEBPImageDecoder); 41 WTF_MAKE_NONCOPYABLE(WEBPImageDecoder);
40 public: 42 public:
41 WEBPImageDecoder(AlphaOption, GammaAndColorProfileOption, size_t maxDecodedB ytes); 43 WEBPImageDecoder(AlphaOption, GammaAndColorProfileOption, size_t maxDecodedB ytes);
42 ~WEBPImageDecoder() override; 44 ~WEBPImageDecoder() override;
43 45
44 // ImageDecoder: 46 // ImageDecoder:
45 String filenameExtension() const override { return "webp"; } 47 String filenameExtension() const override { return "webp"; }
46 void onSetData(SharedBuffer* data) override; 48 void onSetData(SegmentReader* data) override;
47 int repetitionCount() const override; 49 int repetitionCount() const override;
48 bool frameIsCompleteAtIndex(size_t) const override; 50 bool frameIsCompleteAtIndex(size_t) const override;
49 float frameDurationAtIndex(size_t) const override; 51 float frameDurationAtIndex(size_t) const override;
50 size_t clearCacheExceptFrame(size_t) override; 52 size_t clearCacheExceptFrame(size_t) override;
51 53
52 private: 54 private:
53 // ImageDecoder: 55 // ImageDecoder:
54 virtual void decodeSize() { updateDemuxer(); } 56 virtual void decodeSize() { updateDemuxer(); }
55 size_t decodeFrameCount() override; 57 size_t decodeFrameCount() override;
56 void initializeNewFrame(size_t) override; 58 void initializeNewFrame(size_t) override;
(...skipping 19 matching lines...) Expand all
76 WebPDemuxState m_demuxState; 78 WebPDemuxState m_demuxState;
77 bool m_haveAlreadyParsedThisData; 79 bool m_haveAlreadyParsedThisData;
78 int m_repetitionCount; 80 int m_repetitionCount;
79 int m_decodedHeight; 81 int m_decodedHeight;
80 82
81 typedef void (*AlphaBlendFunction)(ImageFrame&, ImageFrame&, int, int, int); 83 typedef void (*AlphaBlendFunction)(ImageFrame&, ImageFrame&, int, int, int);
82 AlphaBlendFunction m_blendFunction; 84 AlphaBlendFunction m_blendFunction;
83 85
84 void clear(); 86 void clear();
85 void clearDecoder(); 87 void clearDecoder();
88
89 // FIXME: Update libwebp's API so it does not require copying the data on ea ch update.
90 RefPtr<SkData> m_consolidatedData;
86 }; 91 };
87 92
88 } // namespace blink 93 } // namespace blink
89 94
90 #endif 95 #endif
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698