OLD | NEW |
1 /* | 1 /* |
2 * Copyright 2015 Google Inc. | 2 * Copyright 2015 Google Inc. |
3 * | 3 * |
4 * Use of this source code is governed by a BSD-style license that can be | 4 * Use of this source code is governed by a BSD-style license that can be |
5 * found in the LICENSE file. | 5 * found in the LICENSE file. |
6 */ | 6 */ |
7 #ifndef SkBmpCodec_DEFINED | 7 #ifndef SkBmpCodec_DEFINED |
8 #define SkBmpCodec_DEFINED | 8 #define SkBmpCodec_DEFINED |
9 | 9 |
10 #include "SkCodec.h" | 10 #include "SkCodec.h" |
11 #include "SkColorTable.h" | 11 #include "SkColorTable.h" |
12 #include "SkImageInfo.h" | 12 #include "SkImageInfo.h" |
13 #include "SkMaskSwizzler.h" | 13 #include "SkMaskSwizzler.h" |
14 #include "SkScanlineDecoder.h" | |
15 #include "SkStream.h" | 14 #include "SkStream.h" |
16 #include "SkSwizzler.h" | 15 #include "SkSwizzler.h" |
17 #include "SkTypes.h" | 16 #include "SkTypes.h" |
18 | 17 |
19 /* | 18 /* |
20 * This class enables code sharing between its bmp codec subclasses. The | 19 * This class enables code sharing between its bmp codec subclasses. The |
21 * subclasses actually do the work. | 20 * subclasses actually do the work. |
22 */ | 21 */ |
23 class SkBmpCodec : public SkCodec { | 22 class SkBmpCodec : public SkCodec { |
24 public: | 23 public: |
25 | 24 |
26 /* | 25 /* |
27 * Checks the start of the stream to see if the image is a bmp | 26 * Checks the start of the stream to see if the image is a bmp |
28 */ | 27 */ |
29 static bool IsBmp(SkStream*); | 28 static bool IsBmp(SkStream*); |
30 | 29 |
31 /* | 30 /* |
32 * Assumes IsBmp was called and returned true | 31 * Assumes IsBmp was called and returned true |
33 * Creates a bmp decoder | 32 * Creates a bmp decoder |
34 * Reads enough of the stream to determine the image format | 33 * Reads enough of the stream to determine the image format |
35 */ | 34 */ |
36 static SkCodec* NewFromStream(SkStream*); | 35 static SkCodec* NewFromStream(SkStream*); |
37 | 36 |
38 /* | 37 /* |
39 * Creates a bmp decoder for a bmp embedded in ico | 38 * Creates a bmp decoder for a bmp embedded in ico |
40 * Reads enough of the stream to determine the image format | 39 * Reads enough of the stream to determine the image format |
41 */ | 40 */ |
42 static SkCodec* NewFromIco(SkStream*); | 41 static SkCodec* NewFromIco(SkStream*); |
43 | 42 |
44 /* | |
45 * Assumes IsBmp was called and returned true | |
46 * Creates a bmp scanline decoder | |
47 * Takes ownership of the stream | |
48 */ | |
49 static SkScanlineDecoder* NewSDFromStream(SkStream* stream); | |
50 | |
51 protected: | 43 protected: |
52 | 44 |
53 SkBmpCodec(const SkImageInfo& info, SkStream* stream, uint16_t bitsPerPixel, | 45 SkBmpCodec(const SkImageInfo& info, SkStream* stream, uint16_t bitsPerPixel, |
54 SkScanlineDecoder::SkScanlineOrder rowOrder); | 46 SkCodec::SkScanlineOrder rowOrder); |
55 | 47 |
56 SkEncodedFormat onGetEncodedFormat() const override { return kBMP_SkEncodedF
ormat; } | 48 SkEncodedFormat onGetEncodedFormat() const override { return kBMP_SkEncodedF
ormat; } |
57 | 49 |
58 /* | 50 /* |
59 * Read enough of the stream to initialize the SkBmpCodec. Returns a bool | 51 * Read enough of the stream to initialize the SkBmpCodec. Returns a bool |
60 * representing success or failure. If it returned true, and codecOut was | 52 * representing success or failure. If it returned true, and codecOut was |
61 * not nullptr, it will be set to a new SkBmpCodec. | 53 * not nullptr, it will be set to a new SkBmpCodec. |
62 * Does *not* take ownership of the passed in SkStream. | 54 * Does *not* take ownership of the passed in SkStream. |
63 */ | 55 */ |
64 static bool ReadHeader(SkStream*, bool inIco, SkCodec** codecOut); | 56 static bool ReadHeader(SkStream*, bool inIco, SkCodec** codecOut); |
(...skipping 15 matching lines...) Expand all Loading... |
80 * Get the destination row number corresponding to the encoded row number. | 72 * Get the destination row number corresponding to the encoded row number. |
81 * For kTopDown, we simply return y, but for kBottomUp, the rows will be | 73 * For kTopDown, we simply return y, but for kBottomUp, the rows will be |
82 * decoded in reverse order. | 74 * decoded in reverse order. |
83 * | 75 * |
84 * @param y Iterates from 0 to height, indicating the current row. | 76 * @param y Iterates from 0 to height, indicating the current row. |
85 * @param height The height of the current subset of the image that we are | 77 * @param height The height of the current subset of the image that we are |
86 * decoding. This is generally equal to the full height | 78 * decoding. This is generally equal to the full height |
87 * when we want to decode the full or one when we are | 79 * when we want to decode the full or one when we are |
88 * sampling. | 80 * sampling. |
89 */ | 81 */ |
90 int32_t getDstRow(int32_t y, int32_t height); | 82 int32_t getDstRow(int32_t y, int32_t height) const; |
91 | 83 |
92 /* | 84 /* |
93 * Get the destination row to start filling from | 85 * Get the destination row to start filling from |
94 * Used to fill the remainder of the image on incomplete input for bmps | 86 * Used to fill the remainder of the image on incomplete input for bmps |
95 * This is tricky since bmps may be kTopDown or kBottomUp. For kTopDown, | 87 * This is tricky since bmps may be kTopDown or kBottomUp. For kTopDown, |
96 * we start filling from where we left off, but for kBottomUp we start | 88 * we start filling from where we left off, but for kBottomUp we start |
97 * filling at the top of the image. | 89 * filling at the top of the image. |
98 */ | 90 */ |
99 void* getDstStartRow(void* dst, size_t dstRowBytes, int32_t y) const; | 91 void* getDstStartRow(void* dst, size_t dstRowBytes, int32_t y) const; |
100 | 92 |
101 /* | 93 /* |
102 * Compute the number of colors in the color table | 94 * Compute the number of colors in the color table |
103 */ | 95 */ |
104 uint32_t computeNumColors(uint32_t numColors); | 96 uint32_t computeNumColors(uint32_t numColors); |
105 | 97 |
106 /* | 98 /* |
107 * Accessors used by subclasses | 99 * Accessors used by subclasses |
108 */ | 100 */ |
109 uint16_t bitsPerPixel() const { return fBitsPerPixel; } | 101 uint16_t bitsPerPixel() const { return fBitsPerPixel; } |
110 SkScanlineDecoder::SkScanlineOrder rowOrder() const { return fRowOrder; } | 102 SkScanlineOrder onGetScanlineOrder() const override { return fRowOrder; } |
111 | 103 |
112 /* | 104 /* |
113 * To be overriden by bmp subclasses, which provide unique implementations. | 105 * To be overriden by bmp subclasses, which provide unique implementations. |
114 * Performs subclass specific setup. | 106 * Performs subclass specific setup. |
115 * | 107 * |
116 * @param dstInfo Contains output information. Height specifies | 108 * @param dstInfo Contains output information. Height specifies |
117 * the total number of rows that will be decoded. | 109 * the total number of rows that will be decoded. |
118 * @param options Additonal options to pass to the decoder. | 110 * @param options Additonal options to pass to the decoder. |
119 * @param inputColorPtr Client-provided memory for a color table. Must | 111 * @param inputColorPtr Client-provided memory for a color table. Must |
120 * be enough for 256 colors. This will be | 112 * be enough for 256 colors. This will be |
(...skipping 25 matching lines...) Expand all Loading... |
146 * lines in the image. | 138 * lines in the image. |
147 * | 139 * |
148 * @param dstInfo Contains output information. Height specifies the | 140 * @param dstInfo Contains output information. Height specifies the |
149 * number of rows to decode at this time. | 141 * number of rows to decode at this time. |
150 * @param dst Memory location to store output pixels | 142 * @param dst Memory location to store output pixels |
151 * @param dstRowBytes Bytes in a row of the destination | 143 * @param dstRowBytes Bytes in a row of the destination |
152 */ | 144 */ |
153 virtual Result decodeRows(const SkImageInfo& dstInfo, void* dst, size_t dstR
owBytes, | 145 virtual Result decodeRows(const SkImageInfo& dstInfo, void* dst, size_t dstR
owBytes, |
154 const Options& opts) = 0; | 146 const Options& opts) = 0; |
155 | 147 |
156 const uint16_t fBitsPerPixel; | 148 Result onStart(const SkImageInfo& dstInfo, const SkCodec::Options&, |
157 const SkScanlineDecoder::SkScanlineOrder fRowOrder; | 149 SkPMColor inputColorPtr[], int* inputColorCount) override; |
158 | 150 |
159 friend class SkBmpScanlineDecoder; | 151 Result onGetScanlines(void* dst, int count, size_t rowBytes) override; |
| 152 |
| 153 int onGetY() const override; |
| 154 |
| 155 // TODO(msarett): Override default skipping with something more clever. |
| 156 |
| 157 const uint16_t fBitsPerPixel; |
| 158 const SkScanlineOrder fRowOrder; |
160 | 159 |
161 typedef SkCodec INHERITED; | 160 typedef SkCodec INHERITED; |
162 }; | 161 }; |
163 | 162 |
164 #endif | 163 #endif |
OLD | NEW |