Chromium Code Reviews| Index: include/codec/SkScaledCodec.h |
| diff --git a/include/codec/SkScaledCodec.h b/include/codec/SkScaledCodec.h |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..94e44edfb3a537b5748ba783c5f7af58cc641919 |
| --- /dev/null |
| +++ b/include/codec/SkScaledCodec.h |
| @@ -0,0 +1,80 @@ |
| +/* |
| + * 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 SkScaledCodec_DEFINED |
| +#define SkScaledCodec_DEFINED |
| + |
| +#include "SkCodec.h" |
| +#include "SkScanlineDecoder.h" |
| + |
| +class SkScanlineDecoder; |
| +class SkStream; |
| + |
| +/** |
| + * This class implements scaling, by sampling scanlines in the y direction. |
| + * x-wise sampling is implemented in the swizzler, when getScanlines() is called. |
| + */ |
| +class SkScaledCodec : public SkCodec { |
| +public: |
| + static SkCodec* NewFromStream(SkStream*); |
| + static SkCodec* NewFromData(SkData*); |
| + |
| + virtual ~SkScaledCodec(); |
| + |
| + /** |
| + * returns a sample size based on the input src and dst dimensions |
| + * can only down sample, so dstDimension must be <= than srcDimension |
| + */ |
| + static int GetSampleSize(int srcDimension, int dstDimension) { |
| + SkASSERT(dstDimension <= srcDimension); |
| + return srcDimension / dstDimension; |
| + } |
| + |
| + /** |
| + * returns whether a destination's dimensions are supported for down sampling |
| + */ |
| + static bool DimensionsSupportedForSampling(const SkImageInfo& srcInfo, |
| + const SkImageInfo& dstInfo) { |
| + // heights must be equal as no native y sampling is supported |
| + if (dstInfo.height() != srcInfo.height()) { |
| + return false; |
| + } |
| + // only support down sampling, dstWidth cannot be larger that srcWidth |
| + if(dstInfo.width() > srcInfo.width()) { |
| + return false; |
| + } |
| + return true; |
| + } |
| + |
| +protected: |
| + /** |
| + * Recommend a set of destination dimensions given a requested scale |
| + */ |
| + SkISize onGetScaledDimensions(float desiredScale) const override; |
| + |
| + Result onGetPixels(const SkImageInfo&, void*, size_t, const Options&, SkPMColor*, int*) |
| + override; |
| + SkEncodedFormat onGetEncodedFormat() const override { |
| + return fCodec->getEncodedFormat(); |
| + } |
| + |
| + SkScanlineDecoder* onGetScanlineDecoder(const SkImageInfo& dstInfo, const Options& options, |
| + SkPMColor ctable[], int* ctableCount) override { |
| + return fCodec->getScanlineDecoder(dstInfo, &options, ctable, ctableCount); |
| + } |
| + |
| + bool onReallyHasAlpha() const override { |
| + return fCodec->reallyHasAlpha(); |
| + } |
| + |
| +private: |
| + SkAutoTDelete<SkCodec> fCodec; |
| + |
| + SkScaledCodec(SkCodec*); |
|
scroggo
2015/08/03 19:16:20
nit: Please label this constructor as explicit
emmaleer
2015/08/04 18:56:53
Acknowledged.
|
| + |
| + typedef SkCodec INHERITED; |
| +}; |
| +#endif // SkScaledCodec_DEFINED |