X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fgraphics%2Fimageloader.cpp;h=965c7b3cb78dbaa76c659efd0ff3be60a9a00787;hb=5715968065256daa4c43d5365cf5e268d75e007a;hp=679f797adcc2bae5d7499c7cc41f6254ef3bb723;hpb=cfd3548464e6424fc9decf0539d6cd04b031ba10;p=libs%2Fgui.git diff --git a/source/graphics/imageloader.cpp b/source/graphics/imageloader.cpp index 679f797..965c7b3 100644 --- a/source/graphics/imageloader.cpp +++ b/source/graphics/imageloader.cpp @@ -1,19 +1,28 @@ #include #include #include +#include "bmploader.h" #include "imageloader.h" #ifdef WITH_LIBPNG #include "png/pngloader.h" #endif +#ifdef WITH_LIBJPEG +#include "jpeg/jpegloader.h" +#endif #ifdef WITH_DEVIL #include "devil/devilloader.h" #endif +#ifdef WITH_QUARTZ +#include "quartz/quartzloader.h" +#endif using namespace std; namespace Msp { namespace Graphics { +bool ImageLoader::registered_loaders_changed = false; + ImageLoader::ImageLoader(): source(0) { } @@ -27,7 +36,7 @@ ImageLoader *ImageLoader::open_file(const string &fn) { try { - RefPtr file = new IO::BufferedFile(fn); + RefPtr file = new IO::BufferedFile(fn); ImageLoader *loader = open_io(*file); loader->source = file.release(); return loader; @@ -38,25 +47,44 @@ ImageLoader *ImageLoader::open_file(const string &fn) } } -ImageLoader *ImageLoader::open_io(IO::Base &io) +ImageLoader *ImageLoader::open_io(IO::Seekable &io) { - char sig_buf[8]; - unsigned sig_len = io.read(sig_buf, sizeof(sig_buf)); - string sig(sig_buf, sig_len); - - // TODO register loader classes automatically - ImageLoader *loader = 0; - if(0) - ; + (void)RegisteredImageLoader::reg; #ifdef WITH_LIBPNG - else if(PngLoader::detect(sig)) - loader = new PngLoader(io, sig); + (void)RegisteredImageLoader::reg; +#endif +#ifdef WITH_LIBJPEG + (void)RegisteredImageLoader::reg; #endif #ifdef WITH_DEVIL - else if(DevilLoader::detect(sig)) - loader = new DevilLoader(io, sig); + (void)RegisteredImageLoader::reg; +#endif +#ifdef WITH_QUARTZ + (void)RegisteredImageLoader::reg; #endif - else + + list &loaders = get_registered_loaders(); + if(registered_loaders_changed) + { + registered_loaders_changed = false; + loaders.sort(signature_size_compare); + } + + if(loaders.empty()) + throw unsupported_image_format("no loaders"); + + vector sig_buf(loaders.back()->get_signature_size()); + unsigned sig_len = io.read(&sig_buf[0], sig_buf.size()); + string signature(sig_buf.begin(), sig_buf.end()); + + ImageLoader *loader = 0; + for(list::const_iterator i=loaders.begin(); (!loader && i!=loaders.end()); ++i) + if((*i)->detect(signature)) + loader = (*i)->create(io); + + io.seek(0, IO::S_BEG); + + if(!loader) { string sig_hex; for(unsigned i=0; i &ImageLoader::get_registered_loaders() +{ + static list regs; + return regs; +} + +bool ImageLoader::signature_size_compare(RegisterBase *r1, RegisterBase *r2) +{ + return r1->get_signature_size()get_signature_size(); +} + } // namespace Graphics } // namespace Msp