Chromium Code Reviews| Index: src/images/SkImageGenerator.h |
| diff --git a/src/images/SkImageGenerator.h b/src/images/SkImageGenerator.h |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..322a9a142109ab58265eaae83dd26d4abe368713 |
| --- /dev/null |
| +++ b/src/images/SkImageGenerator.h |
| @@ -0,0 +1,60 @@ |
| +/* |
| + * Copyright 2013 Google Inc. |
| + * |
| + * Use of this source code is governed by a BSD-style license that can be |
| + * found in the LICENSE file. |
| + */ |
| + |
| +#ifndef SkImageGenerator_DEFINED |
| +#define SkImageGenerator_DEFINED |
| + |
| +class SkData; |
| +class SkImageInfo; |
| + |
| +#include "SkData.h" |
| +#include "SkBitmap.h" |
|
reed1
2013/11/18 21:56:10
do you need to include SkData.h?
can we just incl
hal.canary
2013/11/19 02:06:29
Done.
|
| + |
| +/** |
| + * An interface that allows a purgable PixelRef to re-decode an image. |
| + */ |
| +class SkImageGenerator { |
| +public: |
| + virtual ~SkImageGenerator(); |
| + |
| + /** |
| + * Return a ref to the encoded (i.e. compressed) representation, |
| + * of this data. |
| + * |
| + * If non-NULL is returned, the caller is responsible for calling |
| + * unref() on the data when it is finished. |
| + */ |
| + virtual SkData* refEncodedData() { return NULL; } |
| + |
| + /** |
| + * Return some information about the image, allowing the owner fo |
| + * this ojbect to allocate pixels. |
| + * |
| + * @return false if anything goes wrong. |
| + */ |
| + virtual bool getInfo(SkImageInfo* info) = 0; |
| + |
| + /** |
| + * Decode into the given pixels, a block of memory of size at |
| + * least (info.fHeight - 1) * rowBytes + (info.fWidth * |
| + * bytesPerPixel) |
| + * |
| + * @param info Should be identical to the info returned by |
| + * getInfo so that the implementation can confirm that the |
| + * caller knows what it is asking for (config, size). |
| + * This contract also allows the caller to specify |
| + * different output-configs, which the implementation can |
| + * decide to support or not. |
| + * |
| + * @return false if anything goes wrong. |
| + */ |
| + virtual bool getPixels(const SkImageInfo& info, |
|
Alpha Left Google
2013/11/19 02:00:48
There should be a frame index here for animated im
|
| + void* pixels, |
| + size_t rowBytes) = 0; |
| +}; |
| + |
| +#endif // SkImageGenerator_DEFINED |