Add dividing line for tilesets in Tileset Editor

This commit is contained in:
GriffinR 2024-12-18 14:25:51 -05:00
parent 883087d161
commit 64a9e2cacb
10 changed files with 60 additions and 1 deletions

View file

@ -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.

View file

@ -647,6 +647,7 @@
</property>
<addaction name="actionLayer_Grid"/>
<addaction name="actionMetatile_Grid"/>
<addaction name="actionShow_Tileset_Divider"/>
<addaction name="separator"/>
<addaction name="actionShow_Counts"/>
<addaction name="actionShow_Unused"/>
@ -799,6 +800,14 @@
<string>Ctrl+G</string>
</property>
</action>
<action name="actionShow_Tileset_Divider">
<property name="checkable">
<bool>true</bool>
</property>
<property name="text">
<string>Show Tileset Divider</string>
</property>
</action>
</widget>
<customwidgets>
<customwidget>

View file

@ -68,6 +68,7 @@ public:
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 @@ public:
bool showGrid;
bool showTilesetEditorMetatileGrid;
bool showTilesetEditorLayerGrid;
bool showTilesetEditorDivider;
bool monitorFiles;
bool tilesetCheckerboardFill;
QString theme;

View file

@ -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();

View file

@ -23,7 +23,8 @@ public:
QVector<uint16_t> usedMetatiles;
bool selectorShowUnused = false;
bool selectorShowCounts = false;
bool showGrid;
bool showGrid = false;
bool showDivider = false;
protected:
void mousePressEvent(QGraphicsSceneMouseEvent*);
@ -44,6 +45,7 @@ private:
int numRows(int numMetatiles);
int numRows();
void drawGrid();
void drawDivider();
void drawFilters();
void drawUnused();
void drawCounts();

View file

@ -33,6 +33,7 @@ public:
QVector<uint16_t> usedTiles;
bool showUnused = false;
bool showDivider = false;
protected:
void mousePressEvent(QGraphicsSceneMouseEvent*);

View file

@ -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<QString, QString> 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);

View file

@ -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);

View file

@ -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();

View file

@ -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));