Replace offset in createImage with x/y offset
This commit is contained in:
parent
9fd6d8417a
commit
1b743f9625
4 changed files with 14 additions and 9 deletions
|
@ -45,7 +45,7 @@ public:
|
||||||
Q_INVOKABLE void addFilledRect(int x, int y, int width, int height, QString color = "#000000", int layer = 0);
|
Q_INVOKABLE void addFilledRect(int x, int y, int width, int height, QString color = "#000000", int layer = 0);
|
||||||
Q_INVOKABLE void addImage(int x, int y, QString filepath, int layer = 0, bool useCache = true);
|
Q_INVOKABLE void addImage(int x, int y, QString filepath, int layer = 0, bool useCache = true);
|
||||||
Q_INVOKABLE void createImage(int x, int y, QString filepath,
|
Q_INVOKABLE void createImage(int x, int y, QString filepath,
|
||||||
int width = -1, int height = -1, unsigned offset = 0,
|
int width = -1, int height = -1, int xOffset = 0, int yOffset = 0,
|
||||||
qreal hScale = 1, qreal vScale = 1, int paletteId = -1, bool setTransparency = false,
|
qreal hScale = 1, qreal vScale = 1, int paletteId = -1, bool setTransparency = false,
|
||||||
int layer = 0, bool useCache = true);
|
int layer = 0, bool useCache = true);
|
||||||
Q_INVOKABLE void addTileImage(int x, int y, int tileId, bool xflip, bool yflip, int paletteId, bool setTransparency = false, int layer = 0);
|
Q_INVOKABLE void addTileImage(int x, int y, int tileId, bool xflip, bool yflip, int paletteId, bool setTransparency = false, int layer = 0);
|
||||||
|
|
|
@ -95,7 +95,7 @@ public:
|
||||||
void clearItems();
|
void clearItems();
|
||||||
void addText(QString text, int x, int y, QString color = "#000000", int fontSize = 12);
|
void addText(QString text, int x, int y, QString color = "#000000", int fontSize = 12);
|
||||||
void addRect(int x, int y, int width, int height, QString color = "#000000", bool filled = false);
|
void addRect(int x, int y, int width, int height, QString color = "#000000", bool filled = false);
|
||||||
bool addImage(int x, int y, QString filepath, bool useCache = true, int width = -1, int height = -1, unsigned offset = 0, qreal hScale = 1, qreal vScale = 1, QList<QRgb> palette = QList<QRgb>(), bool setTransparency = false);
|
bool addImage(int x, int y, QString filepath, bool useCache = true, int width = -1, int height = -1, int xOffset = 0, int yOffset = 0, qreal hScale = 1, qreal vScale = 1, QList<QRgb> palette = QList<QRgb>(), bool setTransparency = false);
|
||||||
bool addImage(int x, int y, QImage image);
|
bool addImage(int x, int y, QImage image);
|
||||||
private:
|
private:
|
||||||
QList<OverlayItem*> items;
|
QList<OverlayItem*> items;
|
||||||
|
|
|
@ -144,14 +144,14 @@ void MapView::addImage(int x, int y, QString filepath, int layer, bool useCache)
|
||||||
this->scene()->update();
|
this->scene()->update();
|
||||||
}
|
}
|
||||||
|
|
||||||
void MapView::createImage(int x, int y, QString filepath, int width, int height, unsigned offset, qreal hScale, qreal vScale, int paletteId, bool setTransparency, int layer, bool useCache) {
|
void MapView::createImage(int x, int y, QString filepath, int width, int height, int xOffset, int yOffset, qreal hScale, qreal vScale, int paletteId, bool setTransparency, int layer, bool useCache) {
|
||||||
if (!this->editor || !this->editor->map || !this->editor->map->layout
|
if (!this->editor || !this->editor->map || !this->editor->map->layout
|
||||||
|| !this->editor->map->layout->tileset_primary || !this->editor->map->layout->tileset_secondary)
|
|| !this->editor->map->layout->tileset_primary || !this->editor->map->layout->tileset_secondary)
|
||||||
return;
|
return;
|
||||||
QList<QRgb> palette;
|
QList<QRgb> palette;
|
||||||
if (paletteId != -1)
|
if (paletteId != -1)
|
||||||
palette = Tileset::getPalette(paletteId, this->editor->map->layout->tileset_primary, this->editor->map->layout->tileset_secondary);
|
palette = Tileset::getPalette(paletteId, this->editor->map->layout->tileset_primary, this->editor->map->layout->tileset_secondary);
|
||||||
if (this->getOverlay(layer)->addImage(x, y, filepath, useCache, width, height, offset, hScale, vScale, palette, setTransparency))
|
if (this->getOverlay(layer)->addImage(x, y, filepath, useCache, width, height, xOffset, yOffset, hScale, vScale, palette, setTransparency))
|
||||||
this->scene()->update();
|
this->scene()->update();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -98,7 +98,7 @@ void Overlay::addRect(int x, int y, int width, int height, QString color, bool f
|
||||||
this->items.append(new OverlayRect(x, y, width, height, QColor(color), filled));
|
this->items.append(new OverlayRect(x, y, width, height, QColor(color), filled));
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Overlay::addImage(int x, int y, QString filepath, bool useCache, int width, int height, unsigned offset, qreal hScale, qreal vScale, QList<QRgb> palette, bool setTransparency) {
|
bool Overlay::addImage(int x, int y, QString filepath, bool useCache, int width, int height, int xOffset, int yOffset, qreal hScale, qreal vScale, QList<QRgb> palette, bool setTransparency) {
|
||||||
QImage image = useCache ? Scripting::getImage(filepath) : QImage(filepath);
|
QImage image = useCache ? Scripting::getImage(filepath) : QImage(filepath);
|
||||||
if (image.isNull()) {
|
if (image.isNull()) {
|
||||||
logError(QString("Failed to load image '%1'").arg(filepath));
|
logError(QString("Failed to load image '%1'").arg(filepath));
|
||||||
|
@ -108,23 +108,28 @@ bool Overlay::addImage(int x, int y, QString filepath, bool useCache, int width,
|
||||||
int fullWidth = image.width();
|
int fullWidth = image.width();
|
||||||
int fullHeight = image.height();
|
int fullHeight = image.height();
|
||||||
|
|
||||||
|
// Negative values used as an indicator for "use full dimension"
|
||||||
if (width <= 0)
|
if (width <= 0)
|
||||||
width = fullWidth;
|
width = fullWidth;
|
||||||
if (height <= 0)
|
if (height <= 0)
|
||||||
height = fullHeight;
|
height = fullHeight;
|
||||||
|
|
||||||
if ((unsigned)(width * height) + offset > (unsigned)(fullWidth * fullHeight)) {
|
if (xOffset < 0) xOffset = 0;
|
||||||
logError(QString("%1x%2 image starting at offset %3 exceeds the image size for '%4'")
|
if (yOffset < 0) yOffset = 0;
|
||||||
|
|
||||||
|
if (width + xOffset > fullWidth || height + yOffset > fullHeight) {
|
||||||
|
logError(QString("%1x%2 image starting at (%3,%4) exceeds the image size for '%5'")
|
||||||
.arg(width)
|
.arg(width)
|
||||||
.arg(height)
|
.arg(height)
|
||||||
.arg(offset)
|
.arg(xOffset)
|
||||||
|
.arg(yOffset)
|
||||||
.arg(filepath));
|
.arg(filepath));
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Get specified subset of image
|
// Get specified subset of image
|
||||||
if (width != fullWidth || height != fullHeight)
|
if (width != fullWidth || height != fullHeight)
|
||||||
image = image.copy(offset % fullWidth, offset / fullWidth, width, height);
|
image = image.copy(xOffset, yOffset, width, height);
|
||||||
|
|
||||||
if (hScale != 1 || vScale != 1)
|
if (hScale != 1 || vScale != 1)
|
||||||
image = image.transformed(QTransform().scale(hScale, vScale));
|
image = image.transformed(QTransform().scale(hScale, vScale));
|
||||||
|
|
Loading…
Reference in a new issue