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 |