SkBmpStandardCodec.h revision 8321f7585b6aded0c35e50e9af8709b25fdce3f6
1/*
2 * Copyright 2015 Google Inc.
3 *
4 * Use of this source code is governed by a BSD-style license that can be
5 * found in the LICENSE file.
6 */
7#ifndef SkBmpStandardCodec_DEFINED
8#define SkBmpStandardCodec_DEFINED
9
10#include "SkBmpBaseCodec.h"
11#include "SkColorTable.h"
12#include "SkImageInfo.h"
13#include "SkSwizzler.h"
14#include "SkTypes.h"
15
16/*
17 * This class implements the decoding for bmp images that use "standard" modes,
18 * which essentially means they do not contain bit masks or RLE codes.
19 */
20class SkBmpStandardCodec : public SkBmpBaseCodec {
21public:
22
23    /*
24     * Creates an instance of the decoder
25     *
26     * Called only by SkBmpCodec::NewFromStream
27     * There should be no other callers despite this being public
28     *
29     * @param info contains properties of the encoded data
30     * @param stream the stream of encoded image data
31     * @param bitsPerPixel the number of bits used to store each pixel
32     * @param numColors the number of colors in the color table
33     * @param bytesPerColor the number of bytes in the stream used to represent
34                            each color in the color table
35     * @param offset the offset of the image pixel data from the end of the
36     *               headers
37     * @param rowOrder indicates whether rows are ordered top-down or bottom-up
38     * @param isOpaque indicates if the bmp itself is opaque (before applying
39     *                 the icp mask, if there is one)
40     * @param inIco    indicates if the bmp is embedded in an ico file
41     */
42    SkBmpStandardCodec(int width, int height, const SkEncodedInfo& info, SkStream* stream,
43            uint16_t bitsPerPixel, uint32_t numColors, uint32_t bytesPerColor,
44            uint32_t offset, SkCodec::SkScanlineOrder rowOrder, bool isOpaque,
45            bool inIco);
46
47protected:
48
49    Result onGetPixels(const SkImageInfo& dstInfo, void* dst,
50                       size_t dstRowBytes, const Options&, SkPMColor*,
51                       int*, int*) override;
52
53    bool onInIco() const override {
54        return fInIco;
55    }
56
57    SkCodec::Result onPrepareToDecode(const SkImageInfo& dstInfo,
58            const SkCodec::Options& options, SkPMColor inputColorPtr[],
59            int* inputColorCount) override;
60
61
62    uint64_t onGetFillValue(const SkImageInfo&) const override;
63
64    SkSampler* getSampler(bool createIfNecessary) override {
65        SkASSERT(fSwizzler);
66        return fSwizzler.get();
67    }
68
69private:
70
71    /*
72     * Creates the color table
73     * Sets colorCount to the new color count if it is non-nullptr
74     */
75    bool createColorTable(SkColorType colorType, SkAlphaType alphaType, int* colorCount);
76
77    void initializeSwizzler(const SkImageInfo& dstInfo, const Options& opts);
78
79    int decodeRows(const SkImageInfo& dstInfo, void* dst, size_t dstRowBytes,
80            const Options& opts) override;
81
82    /*
83     * @param stream This may be a pointer to the stream owned by the parent SkCodec
84     *               or a sub-stream of the stream owned by the parent SkCodec.
85     *               Either way, this stream is unowned.
86     */
87    void decodeIcoMask(SkStream* stream, const SkImageInfo& dstInfo, void* dst, size_t dstRowBytes);
88
89    sk_sp<SkColorTable>         fColorTable;
90    // fNumColors is the number specified in the header, or 0 if not present in the header.
91    const uint32_t              fNumColors;
92    const uint32_t              fBytesPerColor;
93    const uint32_t              fOffset;
94    std::unique_ptr<SkSwizzler> fSwizzler;
95    const bool                  fIsOpaque;
96    const bool                  fInIco;
97    const size_t                fAndMaskRowBytes; // only used for fInIco decodes
98
99    typedef SkBmpBaseCodec INHERITED;
100};
101#endif  // SkBmpStandardCodec_DEFINED
102