diff options
author | initial.commit <initial.commit@0039d316-1c4b-4281-b951-d872f2087c98> | 2008-07-27 00:09:42 +0000 |
---|---|---|
committer | initial.commit <initial.commit@0039d316-1c4b-4281-b951-d872f2087c98> | 2008-07-27 00:09:42 +0000 |
commit | ae2c20f398933a9e86c387dcc465ec0f71065ffc (patch) | |
tree | de668b1411e2ee0b4e49b6d8f8b68183134ac990 /skia/ports/SkImageDecoder_Factory.cpp | |
parent | 09911bf300f1a419907a9412154760efd0b7abc3 (diff) | |
download | chromium_src-ae2c20f398933a9e86c387dcc465ec0f71065ffc.zip chromium_src-ae2c20f398933a9e86c387dcc465ec0f71065ffc.tar.gz chromium_src-ae2c20f398933a9e86c387dcc465ec0f71065ffc.tar.bz2 |
Add skia to the repository.
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@16 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'skia/ports/SkImageDecoder_Factory.cpp')
-rw-r--r-- | skia/ports/SkImageDecoder_Factory.cpp | 135 |
1 files changed, 135 insertions, 0 deletions
diff --git a/skia/ports/SkImageDecoder_Factory.cpp b/skia/ports/SkImageDecoder_Factory.cpp new file mode 100644 index 0000000..67d4dcb --- /dev/null +++ b/skia/ports/SkImageDecoder_Factory.cpp @@ -0,0 +1,135 @@ +/* libs/graphics/ports/SkImageDecoder_Factory.cpp +** +** Copyright 2006, Google Inc. +** +** Licensed under the Apache License, Version 2.0 (the "License"); +** you may not use this file except in compliance with the License. +** You may obtain a copy of the License at +** +** http://www.apache.org/licenses/LICENSE-2.0 +** +** Unless required by applicable law or agreed to in writing, software +** distributed under the License is distributed on an "AS IS" BASIS, +** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +** See the License for the specific language governing permissions and +** limitations under the License. +*/ + +#include "SkImageDecoder.h" +#include "SkMovie.h" +#include "SkStream.h" + +//#define USE_PV_FOR_JPEG + +extern SkImageDecoder* SkImageDecoder_GIF_Factory(SkStream*); +extern SkImageDecoder* SkImageDecoder_BMP_Factory(SkStream*); +extern SkImageDecoder* SkImageDecoder_ICO_Factory(SkStream*); +extern SkImageDecoder* SkImageDecoder_PNG_Factory(SkStream*); +extern SkImageDecoder* SkImageDecoder_WBMP_Factory(SkStream*); +#ifdef USE_PV_FOR_JPEG + extern SkImageDecoder* SkImageDecoder_PVJPEG_Factory(SkStream*); +#else + extern SkImageDecoder* SkImageDecoder_JPEG_Factory(SkStream*); +#endif + + +typedef SkImageDecoder* (*SkImageDecoderFactoryProc)(SkStream*); + +struct CodecFormat { + SkImageDecoderFactoryProc fProc; + SkImageDecoder::Format fFormat; +}; + +static const CodecFormat gPairs[] = { + { SkImageDecoder_GIF_Factory, SkImageDecoder::kGIF_Format }, + { SkImageDecoder_PNG_Factory, SkImageDecoder::kPNG_Format }, + { SkImageDecoder_ICO_Factory, SkImageDecoder::kICO_Format }, + { SkImageDecoder_WBMP_Factory, SkImageDecoder::kWBMP_Format }, + { SkImageDecoder_BMP_Factory, SkImageDecoder::kBMP_Format }, + // jpeg must be last, as it doesn't have a good sniffer yet +#ifdef USE_PV_FOR_JPEG + { SkImageDecoder_PVJPEG_Factory, SkImageDecoder::kJPEG_Format } +#else + { SkImageDecoder_JPEG_Factory, SkImageDecoder::kJPEG_Format } +#endif +}; + +SkImageDecoder* SkImageDecoder::Factory(SkStream* stream) { + for (size_t i = 0; i < SK_ARRAY_COUNT(gPairs); i++) { + SkImageDecoder* codec = gPairs[i].fProc(stream); + stream->rewind(); + if (NULL != codec) { + return codec; + } + } + return NULL; +} + +bool SkImageDecoder::SupportsFormat(Format format) { + for (size_t i = 0; i < SK_ARRAY_COUNT(gPairs); i++) { + if (gPairs[i].fFormat == format) { + return true; + } + } + return false; +} + +///////////////////////////////////////////////////////////////////////// + +// the movie may hold onto the stream (by calling ref()) +typedef SkMovie* (*SkMovieStreamProc)(SkStream*); +// the movie may NOT hold onto the pointer +typedef SkMovie* (*SkMovieMemoryProc)(const void*, size_t); + +extern SkMovie* SkMovie_GIF_StreamFactory(SkStream*); +extern SkMovie* SkMovie_GIF_MemoryFactory(const void*, size_t); + +static const SkMovieStreamProc gStreamProc[] = { + SkMovie_GIF_StreamFactory +}; + +static const SkMovieMemoryProc gMemoryProc[] = { + SkMovie_GIF_MemoryFactory +}; + +SkMovie* SkMovie::DecodeStream(SkStream* stream) { + for (unsigned i = 0; i < SK_ARRAY_COUNT(gStreamProc); i++) { + SkMovie* movie = gStreamProc[i](stream); + if (NULL != movie) { + return movie; + } + stream->rewind(); + } + return NULL; +} + +SkMovie* SkMovie::DecodeMemory(const void* data, size_t length) +{ + for (unsigned i = 0; i < SK_ARRAY_COUNT(gMemoryProc); i++) { + SkMovie* movie = gMemoryProc[i](data, length); + if (NULL != movie) { + return movie; + } + } + return NULL; +} + +///////////////////////////////////////////////////////////////////////// + +#ifdef SK_SUPPORT_IMAGE_ENCODE + +extern SkImageEncoder* SkImageEncoder_JPEG_Factory(); +extern SkImageEncoder* SkImageEncoder_PNG_Factory(); + +SkImageEncoder* SkImageEncoder::Create(Type t) { + switch (t) { + case kJPEG_Type: + return SkImageEncoder_JPEG_Factory(); + case kPNG_Type: + return SkImageEncoder_PNG_Factory(); + default: + return NULL; + } +} + +#endif |