Add stamp layer buttons
This commit is contained in:
parent
95a1da1930
commit
3ad9af34a6
8 changed files with 86 additions and 81 deletions
|
@ -645,7 +645,7 @@
|
||||||
</size>
|
</size>
|
||||||
</property>
|
</property>
|
||||||
<property name="currentIndex">
|
<property name="currentIndex">
|
||||||
<number>0</number>
|
<number>2</number>
|
||||||
</property>
|
</property>
|
||||||
<widget class="QWidget" name="tab_blocks">
|
<widget class="QWidget" name="tab_blocks">
|
||||||
<property name="sizePolicy">
|
<property name="sizePolicy">
|
||||||
|
@ -1291,6 +1291,38 @@
|
||||||
</property>
|
</property>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
|
<item>
|
||||||
|
<widget class="QGroupBox" name="groupBox_stampLayer">
|
||||||
|
<property name="title">
|
||||||
|
<string>Stamp Layer</string>
|
||||||
|
</property>
|
||||||
|
<layout class="QVBoxLayout" name="verticalLayout_16">
|
||||||
|
<item>
|
||||||
|
<widget class="QRadioButton" name="radioButton_stampTopLayer">
|
||||||
|
<property name="text">
|
||||||
|
<string>Top Layer</string>
|
||||||
|
</property>
|
||||||
|
<property name="checked">
|
||||||
|
<bool>true</bool>
|
||||||
|
</property>
|
||||||
|
<attribute name="buttonGroup">
|
||||||
|
<string notr="true">buttonGroup_stampLayer</string>
|
||||||
|
</attribute>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
<item>
|
||||||
|
<widget class="QRadioButton" name="radioButton_stampBottomLayer">
|
||||||
|
<property name="text">
|
||||||
|
<string>Bottom Layer</string>
|
||||||
|
</property>
|
||||||
|
<attribute name="buttonGroup">
|
||||||
|
<string notr="true">buttonGroup_stampLayer</string>
|
||||||
|
</attribute>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
</layout>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
<item>
|
<item>
|
||||||
<widget class="QGroupBox" name="groupBox_4">
|
<widget class="QGroupBox" name="groupBox_4">
|
||||||
<property name="title">
|
<property name="title">
|
||||||
|
@ -1371,7 +1403,7 @@
|
||||||
<x>0</x>
|
<x>0</x>
|
||||||
<y>0</y>
|
<y>0</y>
|
||||||
<width>411</width>
|
<width>411</width>
|
||||||
<height>468</height>
|
<height>392</height>
|
||||||
</rect>
|
</rect>
|
||||||
</property>
|
</property>
|
||||||
<property name="sizePolicy">
|
<property name="sizePolicy">
|
||||||
|
@ -1808,8 +1840,8 @@
|
||||||
<rect>
|
<rect>
|
||||||
<x>0</x>
|
<x>0</x>
|
||||||
<y>0</y>
|
<y>0</y>
|
||||||
<width>83</width>
|
<width>100</width>
|
||||||
<height>16</height>
|
<height>30</height>
|
||||||
</rect>
|
</rect>
|
||||||
</property>
|
</property>
|
||||||
<property name="sizePolicy">
|
<property name="sizePolicy">
|
||||||
|
@ -1902,8 +1934,8 @@
|
||||||
<rect>
|
<rect>
|
||||||
<x>0</x>
|
<x>0</x>
|
||||||
<y>0</y>
|
<y>0</y>
|
||||||
<width>83</width>
|
<width>100</width>
|
||||||
<height>16</height>
|
<height>30</height>
|
||||||
</rect>
|
</rect>
|
||||||
</property>
|
</property>
|
||||||
<property name="sizePolicy">
|
<property name="sizePolicy">
|
||||||
|
@ -1996,8 +2028,8 @@
|
||||||
<rect>
|
<rect>
|
||||||
<x>0</x>
|
<x>0</x>
|
||||||
<y>0</y>
|
<y>0</y>
|
||||||
<width>83</width>
|
<width>100</width>
|
||||||
<height>16</height>
|
<height>30</height>
|
||||||
</rect>
|
</rect>
|
||||||
</property>
|
</property>
|
||||||
<property name="sizePolicy">
|
<property name="sizePolicy">
|
||||||
|
@ -2096,8 +2128,8 @@
|
||||||
<rect>
|
<rect>
|
||||||
<x>0</x>
|
<x>0</x>
|
||||||
<y>0</y>
|
<y>0</y>
|
||||||
<width>83</width>
|
<width>100</width>
|
||||||
<height>16</height>
|
<height>30</height>
|
||||||
</rect>
|
</rect>
|
||||||
</property>
|
</property>
|
||||||
<property name="sizePolicy">
|
<property name="sizePolicy">
|
||||||
|
@ -2190,8 +2222,8 @@
|
||||||
<rect>
|
<rect>
|
||||||
<x>0</x>
|
<x>0</x>
|
||||||
<y>0</y>
|
<y>0</y>
|
||||||
<width>83</width>
|
<width>100</width>
|
||||||
<height>16</height>
|
<height>30</height>
|
||||||
</rect>
|
</rect>
|
||||||
</property>
|
</property>
|
||||||
<property name="sizePolicy">
|
<property name="sizePolicy">
|
||||||
|
@ -3553,4 +3585,7 @@
|
||||||
<include location="../resources/images.qrc"/>
|
<include location="../resources/images.qrc"/>
|
||||||
</resources>
|
</resources>
|
||||||
<connections/>
|
<connections/>
|
||||||
|
<buttongroups>
|
||||||
|
<buttongroup name="buttonGroup_stampLayer"/>
|
||||||
|
</buttongroups>
|
||||||
</ui>
|
</ui>
|
||||||
|
|
|
@ -156,6 +156,7 @@ public:
|
||||||
void scaleMapView(int);
|
void scaleMapView(int);
|
||||||
void openInTextEditor(const QString &path, int lineNum = 0) const;
|
void openInTextEditor(const QString &path, int lineNum = 0) const;
|
||||||
bool eventLimitReached(Event::Type type);
|
bool eventLimitReached(Event::Type type);
|
||||||
|
StampLayer getSelectedStampLayer();
|
||||||
|
|
||||||
public slots:
|
public slots:
|
||||||
void openMapScripts() const;
|
void openMapScripts() const;
|
||||||
|
|
|
@ -59,7 +59,7 @@ public:
|
||||||
MapPixmapItem::Axis lockedAxis;
|
MapPixmapItem::Axis lockedAxis;
|
||||||
QPoint selection_origin;
|
QPoint selection_origin;
|
||||||
QList<QPoint> selection;
|
QList<QPoint> selection;
|
||||||
virtual void paint(QGraphicsSceneMouseEvent*);
|
virtual void paint(QGraphicsSceneMouseEvent*, StampLayer stampLayer);
|
||||||
virtual void floodFill(QGraphicsSceneMouseEvent*);
|
virtual void floodFill(QGraphicsSceneMouseEvent*);
|
||||||
virtual void magicFill(QGraphicsSceneMouseEvent*);
|
virtual void magicFill(QGraphicsSceneMouseEvent*);
|
||||||
void magicFill(int x, int y, uint16_t metatileId, bool fromScriptCall = false);
|
void magicFill(int x, int y, uint16_t metatileId, bool fromScriptCall = false);
|
||||||
|
@ -86,7 +86,7 @@ public:
|
||||||
void shift(int xDelta, int yDelta, bool fromScriptCall = false);
|
void shift(int xDelta, int yDelta, bool fromScriptCall = false);
|
||||||
virtual void draw(bool ignoreCache = false);
|
virtual void draw(bool ignoreCache = false);
|
||||||
void updateMetatileSelection(QGraphicsSceneMouseEvent *event);
|
void updateMetatileSelection(QGraphicsSceneMouseEvent *event);
|
||||||
void paintNormal(int x, int y, bool fromScriptCall = false);
|
void paintNormal(int x, int y, StampLayer stampLayer, bool fromScriptCall = false);
|
||||||
void lockNondominantAxis(QGraphicsSceneMouseEvent *event);
|
void lockNondominantAxis(QGraphicsSceneMouseEvent *event);
|
||||||
QPoint adjustCoords(QPoint pos);
|
QPoint adjustCoords(QPoint pos);
|
||||||
|
|
||||||
|
|
|
@ -8,6 +8,12 @@
|
||||||
#include <QList>
|
#include <QList>
|
||||||
#include <QPoint>
|
#include <QPoint>
|
||||||
|
|
||||||
|
enum StampLayer {
|
||||||
|
STAMP_LAYER_BOTTOM,
|
||||||
|
STAMP_LAYER_MIDDLE,
|
||||||
|
STAMP_LAYER_TOP,
|
||||||
|
};
|
||||||
|
|
||||||
struct MetatileSelectionItem
|
struct MetatileSelectionItem
|
||||||
{
|
{
|
||||||
bool enabled;
|
bool enabled;
|
||||||
|
@ -25,7 +31,7 @@ class PaintSelection
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
QPoint dimensions;
|
QPoint dimensions;
|
||||||
virtual bool paintNormal(int, Block*, Map*, int layer) = 0;
|
virtual bool paintNormal(int, Block*, Map*, StampLayer stampLayer) = 0;
|
||||||
};
|
};
|
||||||
|
|
||||||
class MetatileSelection: public PaintSelection
|
class MetatileSelection: public PaintSelection
|
||||||
|
@ -38,7 +44,7 @@ public:
|
||||||
this->metatileItems = other.metatileItems;
|
this->metatileItems = other.metatileItems;
|
||||||
this->collisionItems = other.collisionItems;
|
this->collisionItems = other.collisionItems;
|
||||||
}
|
}
|
||||||
bool paintNormal(int index, Block *block, Map*, int layer) override;
|
bool paintNormal(int index, Block *block, Map*, StampLayer stampLayer) override;
|
||||||
bool hasCollision = false;
|
bool hasCollision = false;
|
||||||
QList<MetatileSelectionItem> metatileItems;
|
QList<MetatileSelectionItem> metatileItems;
|
||||||
QList<CollisionSelectionItem> collisionItems;
|
QList<CollisionSelectionItem> collisionItems;
|
||||||
|
@ -48,7 +54,7 @@ class StampSelection: public PaintSelection
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
StampSelection() {}
|
StampSelection() {}
|
||||||
bool paintNormal(int index, Block *block, Map*, int layer) override;
|
bool paintNormal(int index, Block *block, Map*, StampLayer stampLayer) override;
|
||||||
QList<uint16_t> stampIds;
|
QList<uint16_t> stampIds;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -1178,6 +1178,16 @@ void Editor::setStraightPathCursorMode(QGraphicsSceneMouseEvent *event) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
StampLayer Editor::getSelectedStampLayer() {
|
||||||
|
auto stampLayerButton = ui->buttonGroup_stampLayer->checkedButton();
|
||||||
|
if (stampLayerButton == ui->radioButton_stampTopLayer) {
|
||||||
|
return StampLayer::STAMP_LAYER_TOP;
|
||||||
|
} else if (stampLayerButton == ui->radioButton_stampBottomLayer) {
|
||||||
|
return StampLayer::STAMP_LAYER_BOTTOM;
|
||||||
|
}
|
||||||
|
return StampLayer::STAMP_LAYER_MIDDLE;
|
||||||
|
}
|
||||||
|
|
||||||
void Editor::mouseEvent_map(QGraphicsSceneMouseEvent *event, MapPixmapItem *item) {
|
void Editor::mouseEvent_map(QGraphicsSceneMouseEvent *event, MapPixmapItem *item) {
|
||||||
// TODO: add event tab object painting tool buttons stuff here
|
// TODO: add event tab object painting tool buttons stuff here
|
||||||
if (item->paintingMode == MapPixmapItem::PaintMode::Disabled) {
|
if (item->paintingMode == MapPixmapItem::PaintMode::Disabled) {
|
||||||
|
@ -1207,7 +1217,7 @@ void Editor::mouseEvent_map(QGraphicsSceneMouseEvent *event, MapPixmapItem *item
|
||||||
item->lockNondominantAxis(event);
|
item->lockNondominantAxis(event);
|
||||||
pos = item->adjustCoords(pos);
|
pos = item->adjustCoords(pos);
|
||||||
}
|
}
|
||||||
item->paint(event);
|
item->paint(event, getSelectedStampLayer());
|
||||||
}
|
}
|
||||||
} else if (map_edit_mode == "select") {
|
} else if (map_edit_mode == "select") {
|
||||||
item->select(event);
|
item->select(event);
|
||||||
|
|
|
@ -77,7 +77,7 @@ void MainWindow::setBlock(int x, int y, int rawValue, bool forceRedraw, bool com
|
||||||
|
|
||||||
void MainWindow::setBlocksFromSelection(int x, int y, bool forceRedraw, bool commitChanges) {
|
void MainWindow::setBlocksFromSelection(int x, int y, bool forceRedraw, bool commitChanges) {
|
||||||
if (this->editor && this->editor->map_item) {
|
if (this->editor && this->editor->map_item) {
|
||||||
this->editor->map_item->paintNormal(x, y, true);
|
this->editor->map_item->paintNormal(x, y, StampLayer::STAMP_LAYER_BOTTOM, true);
|
||||||
this->tryCommitMapChanges(commitChanges);
|
this->tryCommitMapChanges(commitChanges);
|
||||||
this->tryRedrawMapArea(forceRedraw);
|
this->tryRedrawMapArea(forceRedraw);
|
||||||
}
|
}
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
|
|
||||||
#define SWAP(a, b) do { if (a != b) { a ^= b; b ^= a; a ^= b; } } while (0)
|
#define SWAP(a, b) do { if (a != b) { a ^= b; b ^= a; a ^= b; } } while (0)
|
||||||
|
|
||||||
void MapPixmapItem::paint(QGraphicsSceneMouseEvent *event) {
|
void MapPixmapItem::paint(QGraphicsSceneMouseEvent *event, StampLayer stampLayer) {
|
||||||
if (map) {
|
if (map) {
|
||||||
if (event->type() == QEvent::GraphicsSceneMouseRelease) {
|
if (event->type() == QEvent::GraphicsSceneMouseRelease) {
|
||||||
actionId_++;
|
actionId_++;
|
||||||
|
@ -31,13 +31,13 @@ void MapPixmapItem::paint(QGraphicsSceneMouseEvent *event) {
|
||||||
if (!shiftPressed && selectionDimensions.x() == 3 && selectionDimensions.y() == 3) {
|
if (!shiftPressed && selectionDimensions.x() == 3 && selectionDimensions.y() == 3) {
|
||||||
paintSmartPath(pos.x(), pos.y());
|
paintSmartPath(pos.x(), pos.y());
|
||||||
} else {
|
} else {
|
||||||
paintNormal(pos.x(), pos.y());
|
paintNormal(pos.x(), pos.y(), stampLayer);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (shiftPressed && selectionDimensions.x() == 3 && selectionDimensions.y() == 3) {
|
if (shiftPressed && selectionDimensions.x() == 3 && selectionDimensions.y() == 3) {
|
||||||
paintSmartPath(pos.x(), pos.y());
|
paintSmartPath(pos.x(), pos.y());
|
||||||
} else {
|
} else {
|
||||||
paintNormal(pos.x(), pos.y());
|
paintNormal(pos.x(), pos.y(), stampLayer);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -110,7 +110,7 @@ PaintSelection* MapPixmapItem::getActiveSelection() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void MapPixmapItem::paintNormal(int x, int y, bool fromScriptCall) {
|
void MapPixmapItem::paintNormal(int x, int y, StampLayer stampLayer, bool fromScriptCall) {
|
||||||
PaintSelection *selection = this->getActiveSelection();
|
PaintSelection *selection = this->getActiveSelection();
|
||||||
int initialX = fromScriptCall ? x : this->paint_tile_initial_x;
|
int initialX = fromScriptCall ? x : this->paint_tile_initial_x;
|
||||||
int initialY = fromScriptCall ? y : this->paint_tile_initial_y;
|
int initialY = fromScriptCall ? y : this->paint_tile_initial_y;
|
||||||
|
@ -137,7 +137,7 @@ void MapPixmapItem::paintNormal(int x, int y, bool fromScriptCall) {
|
||||||
Block block;
|
Block block;
|
||||||
if (map->getBlock(actualX, actualY, &block)) {
|
if (map->getBlock(actualX, actualY, &block)) {
|
||||||
int index = j * selectionWidth + i;
|
int index = j * selectionWidth + i;
|
||||||
if (selection->paintNormal(index, &block, map, 2)) {
|
if (selection->paintNormal(index, &block, map, stampLayer)) {
|
||||||
map->setBlock(actualX, actualY, block, !fromScriptCall);
|
map->setBlock(actualX, actualY, block, !fromScriptCall);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
#include "metatile.h"
|
#include "metatile.h"
|
||||||
#include "log.h"
|
#include "log.h"
|
||||||
|
|
||||||
bool MetatileSelection::paintNormal(int index, Block *block, Map *map, int layer) {
|
bool MetatileSelection::paintNormal(int index, Block *block, Map *map, StampLayer stampLayer) {
|
||||||
MetatileSelectionItem item = this->metatileItems.at(index);
|
MetatileSelectionItem item = this->metatileItems.at(index);
|
||||||
if (!item.enabled)
|
if (!item.enabled)
|
||||||
return false;
|
return false;
|
||||||
|
@ -17,71 +17,24 @@ bool MetatileSelection::paintNormal(int index, Block *block, Map *map, int layer
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
void adjustMetatileForLayer(int layer, int *baseOffset, Metatile *metatile) {
|
int getLayerOffset(StampLayer stampLayer) {
|
||||||
switch (metatile->layerType)
|
switch (stampLayer)
|
||||||
{
|
{
|
||||||
|
case StampLayer::STAMP_LAYER_BOTTOM:
|
||||||
|
return 0;
|
||||||
|
case StampLayer::STAMP_LAYER_TOP:
|
||||||
|
return 4;
|
||||||
default:
|
default:
|
||||||
case METATILE_LAYER_MIDDLE_TOP:
|
return 0;
|
||||||
switch (layer)
|
|
||||||
{
|
|
||||||
case 0:
|
|
||||||
*baseOffset = 0;
|
|
||||||
metatile->layerType = METATILE_LAYER_BOTTOM_TOP;
|
|
||||||
for (int i = 0; i < 4; i++) {
|
|
||||||
metatile->tiles[i+4] = metatile->tiles[i];
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case 1:
|
|
||||||
*baseOffset = 0;
|
|
||||||
break;
|
|
||||||
case 2:
|
|
||||||
*baseOffset = 4;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case METATILE_LAYER_BOTTOM_MIDDLE:
|
|
||||||
switch (layer)
|
|
||||||
{
|
|
||||||
case 0:
|
|
||||||
*baseOffset = 0;
|
|
||||||
break;
|
|
||||||
case 1:
|
|
||||||
*baseOffset = 4;
|
|
||||||
break;
|
|
||||||
case 2:
|
|
||||||
*baseOffset = 4;
|
|
||||||
metatile->layerType = METATILE_LAYER_MIDDLE_TOP;
|
|
||||||
for (int i = 0; i < 4; i++) {
|
|
||||||
metatile->tiles[i] = metatile->tiles[i+4];
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case METATILE_LAYER_BOTTOM_TOP:
|
|
||||||
switch (layer)
|
|
||||||
{
|
|
||||||
case 0:
|
|
||||||
*baseOffset = 0;
|
|
||||||
break;
|
|
||||||
case 1:
|
|
||||||
*baseOffset = 4;
|
|
||||||
metatile->layerType = METATILE_LAYER_BOTTOM_MIDDLE;
|
|
||||||
break;
|
|
||||||
case 2:
|
|
||||||
*baseOffset = 4;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
bool StampSelection::paintNormal(int index, Block *block, Map *map, int layer) {
|
bool StampSelection::paintNormal(int index, Block *block, Map *map, StampLayer stampLayer) {
|
||||||
Tileset *primaryTileset = map->layout->tileset_primary;
|
Tileset *primaryTileset = map->layout->tileset_primary;
|
||||||
Tileset *secondaryTileset = map->layout->tileset_secondary;
|
Tileset *secondaryTileset = map->layout->tileset_secondary;
|
||||||
// 1. Build metatile by applying the stamp to the existing block.
|
// 1. Build metatile by applying the stamp to the existing block.
|
||||||
Metatile metatile = *(Tileset::getMetatile(block->metatileId, map->layout->tileset_primary, map->layout->tileset_secondary));
|
Metatile metatile = *(Tileset::getMetatile(block->metatileId, map->layout->tileset_primary, map->layout->tileset_secondary));
|
||||||
int baseOffset;
|
int baseOffset = getLayerOffset(stampLayer);
|
||||||
adjustMetatileForLayer(layer, &baseOffset, &metatile);
|
|
||||||
metatile.tiles[baseOffset] = Tile(0x5, false, false, 2);
|
metatile.tiles[baseOffset] = Tile(0x5, false, false, 2);
|
||||||
metatile.tiles[baseOffset + 1] = Tile(0x5, true, false, 2);
|
metatile.tiles[baseOffset + 1] = Tile(0x5, true, false, 2);
|
||||||
metatile.tiles[baseOffset + 2] = Tile(0x15, false, false, 2);
|
metatile.tiles[baseOffset + 2] = Tile(0x15, false, false, 2);
|
||||||
|
|
Loading…
Reference in a new issue