Add support for thumbnail
This commit is contained in:
+26
@@ -520,6 +520,7 @@ public:
|
|||||||
* @param readPixel when false it will read pixel data from file and imageData()
|
* @param readPixel when false it will read pixel data from file and imageData()
|
||||||
* will return nullptr */
|
* will return nullptr */
|
||||||
const Image& getImage(uint32_t n, bool readPixels = true);
|
const Image& getImage(uint32_t n, bool readPixels = true);
|
||||||
|
const Image& getThumbnail();
|
||||||
private:
|
private:
|
||||||
void readXISFHeader();
|
void readXISFHeader();
|
||||||
void readSignature();
|
void readSignature();
|
||||||
@@ -532,6 +533,7 @@ private:
|
|||||||
|
|
||||||
std::unique_ptr<std::istream> _io;
|
std::unique_ptr<std::istream> _io;
|
||||||
std::vector<Image> _images;
|
std::vector<Image> _images;
|
||||||
|
Image _thumbnail;
|
||||||
std::vector<Property> _properties;
|
std::vector<Property> _properties;
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -588,6 +590,19 @@ const Image& XISFReaderPrivate::getImage(uint32_t n, bool readPixels)
|
|||||||
return img;
|
return img;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const Image &XISFReaderPrivate::getThumbnail()
|
||||||
|
{
|
||||||
|
Image &img = _thumbnail;
|
||||||
|
if(_thumbnail._dataBlock.attachmentPos)
|
||||||
|
{
|
||||||
|
_io->seekg(img._dataBlock.attachmentPos);
|
||||||
|
ByteArray data(img._dataBlock.attachmentSize);
|
||||||
|
_io->read(data.data(), data.size());
|
||||||
|
img._dataBlock.decompress(data);
|
||||||
|
}
|
||||||
|
return _thumbnail;
|
||||||
|
}
|
||||||
|
|
||||||
void XISFReaderPrivate::readXISFHeader()
|
void XISFReaderPrivate::readXISFHeader()
|
||||||
{
|
{
|
||||||
uint32_t headerLen[2] = {0};
|
uint32_t headerLen[2] = {0};
|
||||||
@@ -608,6 +623,9 @@ void XISFReaderPrivate::readXISFHeader()
|
|||||||
|
|
||||||
for(auto &property : root.children("Property"))
|
for(auto &property : root.children("Property"))
|
||||||
_properties.push_back(parseProperty(property));
|
_properties.push_back(parseProperty(property));
|
||||||
|
|
||||||
|
if(root.child("Thumbnail"))
|
||||||
|
_thumbnail = parseImage(root.child("Thumbnail"));
|
||||||
}
|
}
|
||||||
else throw Error("Unknown root XML element");
|
else throw Error("Unknown root XML element");
|
||||||
}
|
}
|
||||||
@@ -784,6 +802,9 @@ Image XISFReaderPrivate::parseImage(const pugi::xml_node &node)
|
|||||||
image._iccProfile = icc.data;
|
image._iccProfile = icc.data;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(node.child("Thumbnail") && std::strcmp(node.name(), "Thumbnail"))
|
||||||
|
_thumbnail = parseImage(node.child("Thumbnail"));
|
||||||
|
|
||||||
return image;
|
return image;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1034,6 +1055,11 @@ const Image &XISFReader::getImage(uint32_t n, bool readPixels)
|
|||||||
return p->getImage(n, readPixels);
|
return p->getImage(n, readPixels);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const Image &XISFReader::getThumbnail()
|
||||||
|
{
|
||||||
|
return p->getThumbnail();
|
||||||
|
}
|
||||||
|
|
||||||
XISFWriter::XISFWriter()
|
XISFWriter::XISFWriter()
|
||||||
{
|
{
|
||||||
p = new XISFWriterPrivate;
|
p = new XISFWriterPrivate;
|
||||||
|
|||||||
@@ -364,9 +364,14 @@ public:
|
|||||||
int imagesCount() const;
|
int imagesCount() const;
|
||||||
/** Return reference to Image
|
/** Return reference to Image
|
||||||
* @param n index of image
|
* @param n index of image
|
||||||
* @param readPixel when false it will read pixel data from file and imageData()
|
* @param readPixel when false it will not read pixel data from file and imageData()
|
||||||
* will return nullptr */
|
* will return nullptr. Other properties like width, height, format etc will be returned correctly */
|
||||||
const Image& getImage(uint32_t n, bool readPixels = true);
|
const Image& getImage(uint32_t n, bool readPixels = true);
|
||||||
|
/**
|
||||||
|
* @brief getThumbnail
|
||||||
|
* @return image thumbnail
|
||||||
|
*/
|
||||||
|
const Image& getThumbnail();
|
||||||
private:
|
private:
|
||||||
XISFReaderPrivate *p;
|
XISFReaderPrivate *p;
|
||||||
};
|
};
|
||||||
|
|||||||
Reference in New Issue
Block a user