X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fgraphics%2Fimageloader.cpp;h=965c7b3cb78dbaa76c659efd0ff3be60a9a00787;hb=5715968065256daa4c43d5365cf5e268d75e007a;hp=6cdaef912e65062740c284559b3851c742bd102b;hpb=0466fc5fe92ae03189f45f8872fb070ef7022290;p=libs%2Fgui.git diff --git a/source/graphics/imageloader.cpp b/source/graphics/imageloader.cpp index 6cdaef9..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) { } @@ -40,24 +49,42 @@ ImageLoader *ImageLoader::open_file(const string &fn) 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); - io.seek(0, IO::S_BEG); - - // 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); + (void)RegisteredImageLoader::reg; +#endif +#ifdef WITH_LIBJPEG + (void)RegisteredImageLoader::reg; #endif #ifdef WITH_DEVIL - else if(DevilLoader::detect(sig)) - loader = new DevilLoader(io); + (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