dust3d/src/imageforever.cpp

70 lines
1.9 KiB
C++

#include <map>
#include <QMutex>
#include <QMutexLocker>
#include <QBuffer>
#include "imageforever.h"
struct ImageForeverItem
{
QImage *image;
QUuid id;
QByteArray *imageByteArray;
};
static std::map<QUuid, ImageForeverItem> g_foreverMap;
static QMutex g_mapMutex;
const QImage *ImageForever::get(const QUuid &id)
{
QMutexLocker locker(&g_mapMutex);
auto findResult = g_foreverMap.find(id);
if (findResult == g_foreverMap.end())
return nullptr;
return findResult->second.image;
}
void ImageForever::copy(const QUuid &id, QImage &image)
{
QMutexLocker locker(&g_mapMutex);
auto findResult = g_foreverMap.find(id);
if (findResult == g_foreverMap.end())
return;
image = *findResult->second.image;
}
const QByteArray *ImageForever::getPngByteArray(const QUuid &id)
{
QMutexLocker locker(&g_mapMutex);
auto findResult = g_foreverMap.find(id);
if (findResult == g_foreverMap.end())
return nullptr;
return findResult->second.imageByteArray;
}
QUuid ImageForever::add(const QImage *image, QUuid toId)
{
QMutexLocker locker(&g_mapMutex);
if (nullptr == image)
return QUuid();
QUuid newId = toId.isNull() ? QUuid::createUuid() : toId;
if (g_foreverMap.find(newId) != g_foreverMap.end())
return newId;
QImage *newImage = new QImage(*image);
QByteArray *imageByteArray = new QByteArray();
QBuffer pngBuffer(imageByteArray);
pngBuffer.open(QIODevice::WriteOnly);
newImage->save(&pngBuffer, "PNG");
g_foreverMap[newId] = {newImage, newId, imageByteArray};
return newId;
}
void ImageForever::remove(const QUuid &id)
{
QMutexLocker locker(&g_mapMutex);
auto findImage = g_foreverMap.find(id);
if (findImage == g_foreverMap.end())
return;
delete findImage->second.image;
delete findImage->second.imageByteArray;
g_foreverMap.erase(id);
}