| Index: src/codec/SkJpegCodec.h
|
| diff --git a/src/codec/SkJpegCodec.h b/src/codec/SkJpegCodec.h
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..51a741a525aa0936442aa7ac50c179f6e07db5fb
|
| --- /dev/null
|
| +++ b/src/codec/SkJpegCodec.h
|
| @@ -0,0 +1,99 @@
|
| +/*
|
| + * Copyright 2015 Google Inc.
|
| + *
|
| + * Use of this source code is governed by a BSD-style license that can be
|
| + * found in the LICENSE file.
|
| + */
|
| +
|
| +#ifndef SkJpegCodec_DEFINED
|
| +#define SkJpegCodec_DEFINED
|
| +
|
| +#include "SkCodec.h"
|
| +#include "SkImageInfo.h"
|
| +#include "SkJpegDecoderMgr.h"
|
| +#include "SkJpegUtility.h"
|
| +#include "SkStream.h"
|
| +
|
| +extern "C" {
|
| + #include "jpeglib.h"
|
| +}
|
| +
|
| +/*
|
| + *
|
| + * This class implements the decoding for jpeg images
|
| + *
|
| + */
|
| +class SkJpegCodec : public SkCodec {
|
| +public:
|
| +
|
| + /*
|
| + * Checks the start of the stream to see if the image is a jpeg
|
| + * Does not take ownership of the stream
|
| + */
|
| + static bool IsJpeg(SkStream*);
|
| +
|
| + /*
|
| + * Assumes IsJpeg was called and returned true
|
| + * Creates a jpeg decoder
|
| + * Takes ownership of the stream
|
| + */
|
| + static SkCodec* NewFromStream(SkStream*);
|
| +
|
| +protected:
|
| +
|
| + /*
|
| + * Recommend a set of destination dimensions given a requested scale
|
| + */
|
| + SkISize onGetScaledDimensions(float desiredScale) const override;
|
| +
|
| + /*
|
| + * Initiates the jpeg decode
|
| + */
|
| + Result onGetPixels(const SkImageInfo& dstInfo, void* dst, size_t dstRowBytes, const Options&,
|
| + SkPMColor*, int*) override;
|
| +
|
| + SkEncodedFormat onGetEncodedFormat() const override {
|
| + return kJPEG_SkEncodedFormat;
|
| + }
|
| +
|
| +private:
|
| +
|
| + /*
|
| + * Read enough of the stream to initialize the SkJpegCodec.
|
| + * Returns a bool representing success or failure.
|
| + *
|
| + * @param codecOut
|
| + * If this returns true, and codecOut was not NULL,
|
| + * codecOut will be set to a new SkJpegCodec.
|
| + *
|
| + * @param decoderMgrOut
|
| + * If this returns true, and codecOut was NULL,
|
| + * decoderMgrOut must be non-NULL and decoderMgrOut will be set to a new
|
| + * JpegDecoderMgr pointer.
|
| + *
|
| + * @param stream
|
| + * Deleted on failure.
|
| + * codecOut will take ownership of it in the case where we created a codec.
|
| + * Ownership is unchanged when we set decoderMgrOut.
|
| + *
|
| + */
|
| + static bool ReadHeader(SkStream* stream, SkCodec** codecOut,
|
| + JpegDecoderMgr** decoderMgrOut);
|
| +
|
| + /*
|
| + * Creates an instance of the decoder
|
| + * Called only by NewFromStream
|
| + *
|
| + * @param srcInfo contains the source width and height
|
| + * @param stream the encoded image data
|
| + * @param decoderMgr holds decompress struct, src manager, and error manager
|
| + * takes ownership
|
| + */
|
| + SkJpegCodec(const SkImageInfo& srcInfo, SkStream* stream, JpegDecoderMgr* decoderMgr);
|
| +
|
| + SkAutoTDelete<JpegDecoderMgr> fDecoderMgr;
|
| +
|
| + typedef SkCodec INHERITED;
|
| +};
|
| +
|
| +#endif
|
|
|