X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fgraphics%2Fimage.h;h=bfaeef84a00fbf7b945dbac8cc51d0fc593673bd;hb=cfd3548464e6424fc9decf0539d6cd04b031ba10;hp=137f856f21f5736d40dbecae6275a26919c42536;hpb=12df88ecf9787f4ed59051646775165b74301cf0;p=libs%2Fgui.git diff --git a/source/graphics/image.h b/source/graphics/image.h index 137f856..bfaeef8 100644 --- a/source/graphics/image.h +++ b/source/graphics/image.h @@ -9,39 +9,34 @@ namespace Msp { namespace Graphics { -class unsupported_image_format: public std::runtime_error -{ -public: - unsupported_image_format(const std::string &w): std::runtime_error(w) { } - virtual ~unsupported_image_format() throw() { } -}; - -class bad_image_data: public std::runtime_error -{ -public: - bad_image_data(const std::string &w): std::runtime_error(w) { } - virtual ~bad_image_data() throw() { } -}; - +class ImageLoader; class Image { public: - struct Private; + struct Data + { + PixelFormat fmt; + unsigned width; + unsigned height; + char *data; + + Data(); + ~Data(); + }; private: - Private *priv; + Data data; public: - Image(); - ~Image(); - void load_file(const std::string &); void load_io(IO::Base &); - PixelFormat get_format() const; - unsigned get_width() const; - unsigned get_height() const; - const void *get_data() const; + void load(ImageLoader &); + + PixelFormat get_format() const { return data.fmt; } + unsigned get_width() const { return data.width; } + unsigned get_height() const { return data.height; } + const void *get_data() const { return data.data; } }; } // namespace Graphics