diff --git a/CHANGELOG.md b/CHANGELOG.md index 199bd659..34b75bed 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -13,6 +13,7 @@ The **"Breaking Changes"** listed below are changes that have been made in the d - Add a `Close Project` option - Add charts to the `Wild Pokémon` tab that show species and level distributions. - Add options for customizing the map grid under `View -> Grid Settings`. +- Add an option to display a dividing line between tilesets in the Tileset Editor. - An alert will be displayed when attempting to open a seemingly invalid project. - Add support for defining project values with `enum` where `#define` was expected. - Add button to enable editing map groups including renaming groups and rearranging the maps within them. diff --git a/forms/tileseteditor.ui b/forms/tileseteditor.ui index c144e5f2..8623a9bc 100644 --- a/forms/tileseteditor.ui +++ b/forms/tileseteditor.ui @@ -647,6 +647,7 @@ + @@ -799,6 +800,14 @@ Ctrl+G + + + true + + + Show Tileset Divider + + diff --git a/include/config.h b/include/config.h index 6b64b612..47bc2010 100644 --- a/include/config.h +++ b/include/config.h @@ -68,6 +68,7 @@ class PorymapConfig: public KeyValueConfigBase this->showGrid = false; this->showTilesetEditorMetatileGrid = false; this->showTilesetEditorLayerGrid = true; + this->showTilesetEditorDivider = false; this->monitorFiles = true; this->tilesetCheckerboardFill = true; this->theme = "default"; @@ -119,6 +120,7 @@ class PorymapConfig: public KeyValueConfigBase bool showGrid; bool showTilesetEditorMetatileGrid; bool showTilesetEditorLayerGrid; + bool showTilesetEditorDivider; bool monitorFiles; bool tilesetCheckerboardFill; QString theme; diff --git a/include/ui/tileseteditor.h b/include/ui/tileseteditor.h index 32bdc97f..86d53cc2 100644 --- a/include/ui/tileseteditor.h +++ b/include/ui/tileseteditor.h @@ -88,6 +88,7 @@ private slots: void on_actionShow_UnusedTiles_toggled(bool checked); void on_actionMetatile_Grid_triggered(bool checked); void on_actionLayer_Grid_triggered(bool checked); + void on_actionShow_Tileset_Divider_triggered(bool checked); void on_actionUndo_triggered(); diff --git a/include/ui/tileseteditormetatileselector.h b/include/ui/tileseteditormetatileselector.h index 6b2c9a6f..760da8e4 100644 --- a/include/ui/tileseteditormetatileselector.h +++ b/include/ui/tileseteditormetatileselector.h @@ -23,7 +23,8 @@ class TilesetEditorMetatileSelector: public SelectablePixmapItem { QVector usedMetatiles; bool selectorShowUnused = false; bool selectorShowCounts = false; - bool showGrid; + bool showGrid = false; + bool showDivider = false; protected: void mousePressEvent(QGraphicsSceneMouseEvent*); @@ -44,6 +45,7 @@ class TilesetEditorMetatileSelector: public SelectablePixmapItem { int numRows(int numMetatiles); int numRows(); void drawGrid(); + void drawDivider(); void drawFilters(); void drawUnused(); void drawCounts(); diff --git a/include/ui/tileseteditortileselector.h b/include/ui/tileseteditortileselector.h index 7e34d52a..aa2a1923 100644 --- a/include/ui/tileseteditortileselector.h +++ b/include/ui/tileseteditortileselector.h @@ -33,6 +33,7 @@ class TilesetEditorTileSelector: public SelectablePixmapItem { QVector usedTiles; bool showUnused = false; + bool showDivider = false; protected: void mousePressEvent(QGraphicsSceneMouseEvent*); diff --git a/src/config.cpp b/src/config.cpp index 3d604da6..c0c00194 100644 --- a/src/config.cpp +++ b/src/config.cpp @@ -368,6 +368,8 @@ void PorymapConfig::parseConfigKeyValue(QString key, QString value) { this->showTilesetEditorMetatileGrid = getConfigBool(key, value); } else if (key == "show_tileset_editor_layer_grid") { this->showTilesetEditorLayerGrid = getConfigBool(key, value); + } else if (key == "show_tileset_editor_divider") { + this->showTilesetEditorDivider = getConfigBool(key, value); } else if (key == "monitor_files") { this->monitorFiles = getConfigBool(key, value); } else if (key == "tileset_checkerboard_fill") { @@ -452,6 +454,7 @@ QMap PorymapConfig::getKeyValueMap() { map.insert("show_grid", this->showGrid ? "1" : "0"); map.insert("show_tileset_editor_metatile_grid", this->showTilesetEditorMetatileGrid ? "1" : "0"); map.insert("show_tileset_editor_layer_grid", this->showTilesetEditorLayerGrid ? "1" : "0"); + map.insert("show_tileset_editor_divider", this->showTilesetEditorDivider ? "1" : "0"); map.insert("monitor_files", this->monitorFiles ? "1" : "0"); map.insert("tileset_checkerboard_fill", this->tilesetCheckerboardFill ? "1" : "0"); map.insert("theme", this->theme); diff --git a/src/ui/tileseteditor.cpp b/src/ui/tileseteditor.cpp index e709bed1..49cfe147 100644 --- a/src/ui/tileseteditor.cpp +++ b/src/ui/tileseteditor.cpp @@ -99,6 +99,7 @@ void TilesetEditor::initUi() { this->paletteId = ui->spinBox_paletteSelector->value(); this->ui->spinBox_paletteSelector->setMinimum(0); this->ui->spinBox_paletteSelector->setMaximum(Project::getNumPalettesTotal() - 1); + this->ui->actionShow_Tileset_Divider->setChecked(porymapConfig.showTilesetEditorDivider); this->setAttributesUi(); this->setMetatileLabelValidator(); @@ -191,6 +192,7 @@ void TilesetEditor::initMetatileSelector() bool showGrid = porymapConfig.showTilesetEditorMetatileGrid; this->ui->actionMetatile_Grid->setChecked(showGrid); this->metatileSelector->showGrid = showGrid; + this->metatileSelector->showDivider = this->ui->actionShow_Tileset_Divider->isChecked(); this->metatilesScene = new QGraphicsScene; this->metatilesScene->addItem(this->metatileSelector); @@ -232,6 +234,8 @@ void TilesetEditor::initTileSelector() connect(this->tileSelector, &TilesetEditorTileSelector::selectedTilesChanged, this, &TilesetEditor::onSelectedTilesChanged); + this->tileSelector->showDivider = this->ui->actionShow_Tileset_Divider->isChecked(); + this->tilesScene = new QGraphicsScene; this->tilesScene->addItem(this->tileSelector); this->tileSelector->select(0); @@ -1048,6 +1052,16 @@ void TilesetEditor::on_actionLayer_Grid_triggered(bool checked) { porymapConfig.showTilesetEditorLayerGrid = checked; } +void TilesetEditor::on_actionShow_Tileset_Divider_triggered(bool checked) { + this->metatileSelector->showDivider = checked; + this->metatileSelector->draw(); + + this->tileSelector->showDivider = checked; + this->tileSelector->draw(); + + porymapConfig.showTilesetEditorDivider = checked; +} + void TilesetEditor::countMetatileUsage() { // do not double count metatileSelector->usedMetatiles.fill(0); diff --git a/src/ui/tileseteditormetatileselector.cpp b/src/ui/tileseteditormetatileselector.cpp index 778fde9c..6175a923 100644 --- a/src/ui/tileseteditormetatileselector.cpp +++ b/src/ui/tileseteditormetatileselector.cpp @@ -70,6 +70,7 @@ QImage TilesetEditorMetatileSelector::buildImage(int metatileIdStart, int numMet void TilesetEditorMetatileSelector::draw() { this->setPixmap(QPixmap::fromImage(this->buildAllMetatilesImage())); this->drawGrid(); + this->drawDivider(); this->drawSelection(); this->drawFilters(); } @@ -186,6 +187,20 @@ void TilesetEditorMetatileSelector::drawGrid() { this->setPixmap(pixmap); } +void TilesetEditorMetatileSelector::drawDivider() { + if (!this->showDivider) + return; + + const int y = this->numRows(this->primaryTileset->numMetatiles()) * 32; + + QPixmap pixmap = this->pixmap(); + QPainter painter(&pixmap); + painter.setPen(Qt::white); + painter.drawLine(0, y, this->numMetatilesWide * 32, y); + painter.end(); + this->setPixmap(pixmap); +} + void TilesetEditorMetatileSelector::drawFilters() { if (selectorShowUnused) { drawUnused(); diff --git a/src/ui/tileseteditortileselector.cpp b/src/ui/tileseteditortileselector.cpp index 7431e928..4cec089e 100644 --- a/src/ui/tileseteditortileselector.cpp +++ b/src/ui/tileseteditortileselector.cpp @@ -46,6 +46,17 @@ void TilesetEditorTileSelector::draw() { painter.drawImage(origin, tileImage); } + if (this->showDivider) { + int row = this->primaryTileset->tiles.length() / this->numTilesWide; + if (this->primaryTileset->tiles.length() % this->numTilesWide != 0) { + // Round up height for incomplete last row + row++; + } + const int y = row * 16; + painter.setPen(Qt::white); + painter.drawLine(0, y, this->numTilesWide * 16, y); + } + painter.end(); this->setPixmap(QPixmap::fromImage(image));