| OLD | NEW |
| 1 | 1 |
| 2 /* | 2 /* |
| 3 * Copyright 2006 The Android Open Source Project | 3 * Copyright 2006 The Android Open Source Project |
| 4 * | 4 * |
| 5 * Use of this source code is governed by a BSD-style license that can be | 5 * Use of this source code is governed by a BSD-style license that can be |
| 6 * found in the LICENSE file. | 6 * found in the LICENSE file. |
| 7 */ | 7 */ |
| 8 | 8 |
| 9 | 9 |
| 10 #ifndef SkImageDecoder_DEFINED | 10 #ifndef SkImageDecoder_DEFINED |
| 11 #define SkImageDecoder_DEFINED | 11 #define SkImageDecoder_DEFINED |
| 12 | 12 |
| 13 #include "SkBitmap.h" | 13 #include "SkBitmap.h" |
| 14 #include "SkBitmapFactory.h" | 14 #include "SkBitmapFactory.h" |
| 15 #include "SkImage.h" | 15 #include "SkImage.h" |
| 16 #include "SkRect.h" | 16 #include "SkRect.h" |
| 17 #include "SkRefCnt.h" | 17 #include "SkRefCnt.h" |
| 18 | 18 |
| 19 class SkStream; | 19 class SkStream; |
| 20 | 20 |
| 21 /** \class SkImageDecoder | 21 /** \class SkImageDecoder |
| 22 | 22 |
| 23 Base class for decoding compressed images into a SkBitmap | 23 Base class for decoding compressed images into a SkBitmap |
| 24 */ | 24 */ |
| 25 class SkImageDecoder { | 25 class SkImageDecoder { |
| 26 public: | 26 public: |
| 27 virtual ~SkImageDecoder(); | 27 virtual ~SkImageDecoder(); |
| 28 | 28 |
| 29 // Should be consistent with sFormatName | |
| 30 enum Format { | 29 enum Format { |
| 31 kUnknown_Format, | 30 kUnknown_Format, |
| 32 kBMP_Format, | 31 kBMP_Format, |
| 33 kGIF_Format, | 32 kGIF_Format, |
| 34 kICO_Format, | 33 kICO_Format, |
| 35 kJPEG_Format, | 34 kJPEG_Format, |
| 36 kPNG_Format, | 35 kPNG_Format, |
| 37 kWBMP_Format, | 36 kWBMP_Format, |
| 38 kWEBP_Format, | 37 kWEBP_Format, |
| 39 | 38 |
| 40 kLastKnownFormat = kWEBP_Format | 39 kLastKnownFormat = kWEBP_Format |
| 41 }; | 40 }; |
| 42 | 41 |
| 43 /** Return the format of image this decoder can decode. If this decoder can
decode multiple | 42 /** Return the format of image this decoder can decode. If this decoder can
decode multiple |
| 44 formats, kUnknown_Format will be returned. | 43 formats, returns the format of the data that was most recently decoded s
uccessfully. Can |
| 44 return kUnknown_Format. |
| 45 */ | 45 */ |
| 46 virtual Format getFormat() const; | 46 virtual Format getFormat() const; |
| 47 | 47 |
| 48 /** Return a readable string of the value returned by getFormat(). | 48 /** Return a readable string of the value returned by getFormat(). |
| 49 */ | 49 */ |
| 50 const char* getFormatName() const; | 50 const char* getFormatName() const; |
| 51 | 51 |
| 52 /** Returns true if the decoder should try to dither the resulting image. | 52 /** Returns true if the decoder should try to dither the resulting image. |
| 53 The default setting is true. | 53 The default setting is true. |
| 54 */ | 54 */ |
| (...skipping 354 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 409 Chooser* fChooser; | 409 Chooser* fChooser; |
| 410 SkBitmap::Allocator* fAllocator; | 410 SkBitmap::Allocator* fAllocator; |
| 411 int fSampleSize; | 411 int fSampleSize; |
| 412 SkBitmap::Config fDefaultPref; // use if fUsePrefTable is false | 412 SkBitmap::Config fDefaultPref; // use if fUsePrefTable is false |
| 413 SkBitmap::Config fPrefTable[6]; // use if fUsePrefTable is true | 413 SkBitmap::Config fPrefTable[6]; // use if fUsePrefTable is true |
| 414 bool fDitherImage; | 414 bool fDitherImage; |
| 415 bool fUsePrefTable; | 415 bool fUsePrefTable; |
| 416 mutable bool fShouldCancelDecode; | 416 mutable bool fShouldCancelDecode; |
| 417 bool fPreferQualityOverSpeed; | 417 bool fPreferQualityOverSpeed; |
| 418 | 418 |
| 419 /** Contains the image format name. | |
| 420 * This should be consistent with Format. | |
| 421 * | |
| 422 * The format name gives a more meaningful error message than enum. | |
| 423 */ | |
| 424 static const char* sFormatName[]; | |
| 425 | |
| 426 // illegal | 419 // illegal |
| 427 SkImageDecoder(const SkImageDecoder&); | 420 SkImageDecoder(const SkImageDecoder&); |
| 428 SkImageDecoder& operator=(const SkImageDecoder&); | 421 SkImageDecoder& operator=(const SkImageDecoder&); |
| 429 }; | 422 }; |
| 430 | 423 |
| 431 /** Calling newDecoder with a stream returns a new matching imagedecoder | 424 /** Calling newDecoder with a stream returns a new matching imagedecoder |
| 432 instance, or NULL if none can be found. The caller must manage its ownership | 425 instance, or NULL if none can be found. The caller must manage its ownership |
| 433 of the stream as usual, calling unref() when it is done, as the returned | 426 of the stream as usual, calling unref() when it is done, as the returned |
| 434 decoder may have called ref() (and if so, the decoder is responsible for | 427 decoder may have called ref() (and if so, the decoder is responsible for |
| 435 balancing its ownership when it is destroyed). | 428 balancing its ownership when it is destroyed). |
| (...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 468 // not all of these will be available | 461 // not all of these will be available |
| 469 DECLARE_DECODER_CREATOR(BMPImageDecoder); | 462 DECLARE_DECODER_CREATOR(BMPImageDecoder); |
| 470 DECLARE_DECODER_CREATOR(GIFImageDecoder); | 463 DECLARE_DECODER_CREATOR(GIFImageDecoder); |
| 471 DECLARE_DECODER_CREATOR(ICOImageDecoder); | 464 DECLARE_DECODER_CREATOR(ICOImageDecoder); |
| 472 DECLARE_DECODER_CREATOR(JPEGImageDecoder); | 465 DECLARE_DECODER_CREATOR(JPEGImageDecoder); |
| 473 DECLARE_DECODER_CREATOR(PNGImageDecoder); | 466 DECLARE_DECODER_CREATOR(PNGImageDecoder); |
| 474 DECLARE_DECODER_CREATOR(WBMPImageDecoder); | 467 DECLARE_DECODER_CREATOR(WBMPImageDecoder); |
| 475 DECLARE_DECODER_CREATOR(WEBPImageDecoder); | 468 DECLARE_DECODER_CREATOR(WEBPImageDecoder); |
| 476 | 469 |
| 477 #endif | 470 #endif |
| OLD | NEW |