fmt(RGB),
width(0),
height(0),
- data(0)
+ pixels(0)
{ }
+Image::Data::Data(const Data &other):
+ fmt(other.fmt),
+ width(other.width),
+ height(other.height),
+ stride(other.stride),
+ pixels(other.pixels ? new char[stride*height] : 0)
+{
+ if(pixels)
+ copy(other.pixels, other.pixels+stride*height, pixels);
+}
+
+Image::Data &Image::Data::operator=(const Data &other)
+{
+ delete[] pixels;
+ pixels = 0;
+
+ fmt = other.fmt;
+ width = other.width;
+ height = other.height;
+ stride = other.stride;
+
+ if(other.pixels)
+ {
+ pixels = new char[stride*height];
+ copy(other.pixels, other.pixels+stride*height, pixels);
+ }
+
+ return *this;
+}
+
Image::Data::~Data()
{
- delete[] data;
+ delete[] pixels;
}
load(*loader);
}
-void Image::load_io(IO::Base &io)
+void Image::load_io(IO::Seekable &io)
{
RefPtr<ImageLoader> loader = ImageLoader::open_io(io);
load(*loader);