diff --git a/docsrc/manual/images/settings-and-options/new-map-defaults.png b/docsrc/manual/images/settings-and-options/new-map-defaults.png
index 776984d1..50b557f7 100644
Binary files a/docsrc/manual/images/settings-and-options/new-map-defaults.png and b/docsrc/manual/images/settings-and-options/new-map-defaults.png differ
diff --git a/docsrc/manual/settings-and-options.rst b/docsrc/manual/settings-and-options.rst
index 359a81c8..e26dc08e 100644
--- a/docsrc/manual/settings-and-options.rst
+++ b/docsrc/manual/settings-and-options.rst
@@ -81,9 +81,11 @@ New Map Defaults
:alt: New Map Defaults
Border Metatiles
- This is a comma-separated list of metatile ID values that will be used to fill the border on new maps. If the number of metatiles in the border is not the same as the number of values in the list then the border will be filled with metatile ID ``0x000`` instead.
+ This is list of metatile ID values that will be used to fill the border on new maps. The spin boxes correspond to the top-left, top-right, bottom-left, and bottom-right border metatiles respectively.
- Defaults to ``0x014,0x015,0x01C,0x01D`` for ``pokefirered``, and ``0x1D4,0x1D5,0x1DC,0x1DD`` for other versions.
+ If ``Enable Custom Border Size`` is checked, this will instead be a comma-separated list of metatile ID values that will be used to fill the border on new maps. Values in the list will be read sequentially to fill the new border left-to-right top-to-bottom. If the number of metatiles in the border for a new map is not the same as the number of values in the list then the border will be filled with metatile ID ``0x000`` instead.
+
+ Defaults to ``0x014``, ``0x015``, ``0x01C``, ``0x01D`` for ``pokefirered``, and ``0x1D4``, ``0x1D5``, ``0x1DC``, ``0x1DD`` for other versions.
Field name: ``new_map_border_metatiles``
diff --git a/forms/projectsettingseditor.ui b/forms/projectsettingseditor.ui
index a24e8f83..7980e017 100644
--- a/forms/projectsettingseditor.ui
+++ b/forms/projectsettingseditor.ui
@@ -94,65 +94,7 @@
New Map Defaults
- -
-
-
- A comma-separated list of metatile values that will be used to fill new map borders
-
-
-
- -
-
-
- Elevation
-
-
-
- -
-
-
- Qt::Horizontal
-
-
-
- 40
- 20
-
-
-
-
- -
-
-
- Whether a separate text.inc or text.pory file will be created for new maps, alongside the scripts file
-
-
- Create separate text file
-
-
-
-
-
-
- The default elevation that will be used to fill new maps
-
-
-
- -
-
-
- Fill Metatile
-
-
-
- -
-
-
- Border Metatiles
-
-
-
- -
The default metatile value that will be used to fill new maps
@@ -165,18 +107,145 @@
- -
-
-
- Qt::Horizontal
+
-
+
+
+ Elevation
-
-
- 40
- 20
-
+
+
+ -
+
+
+ The default elevation that will be used to fill new maps
-
+
+
+ -
+
+
+ Fill Metatile
+
+
+
+ -
+
+
+ Whether a separate text.inc or text.pory file will be created for new maps, alongside the scripts file
+
+
+ Create separate text file
+
+
+
+ -
+
+
+
+ 0
+
+
+ 0
+
+
+ 0
+
+
+ 0
+
+
-
+
+
+ Border Metatiles
+
+
+
+ -
+
+
+ A comma-separated list of metatile values that will be used to fill new map borders
+
+
+
+
+
+
+ -
+
+
+
+ 0
+
+
+ 0
+
+
+ 0
+
+
+ 0
+
+
-
+
+
+ Border Metatiles
+
+
+
+ -
+
+
+ The default metatile value that will be used for the top-left border metatile on new maps.
+
+
+ 0x
+
+
+ 16
+
+
+
+ -
+
+
+ The default metatile value that will be used for the top-right border metatile on new maps.
+
+
+ 0x
+
+
+ 16
+
+
+
+ -
+
+
+ The default metatile value that will be used for the bottom-left border metatile on new maps.
+
+
+ 0x
+
+
+ 16
+
+
+
+ -
+
+
+ The default metatile value that will be used for the bottom-right border metatile on new maps.
+
+
+ 0x
+
+
+ 16
+
+
+
+
+
diff --git a/include/config.h b/include/config.h
index 96086749..7f10ce91 100644
--- a/include/config.h
+++ b/include/config.h
@@ -267,7 +267,6 @@ public:
int getNewMapElevation();
void setNewMapBorderMetatileIds(QList metatileIds);
QList getNewMapBorderMetatileIds();
- QString getNewMapBorderMetatileIdsString();
QString getDefaultPrimaryTileset();
QString getDefaultSecondaryTileset();
void setDefaultPrimaryTileset(QString tilesetName);
diff --git a/include/core/metatile.h b/include/core/metatile.h
index c3bda046..ed1f84ee 100644
--- a/include/core/metatile.h
+++ b/include/core/metatile.h
@@ -93,7 +93,15 @@ public:
static QPoint coordFromPixmapCoord(const QPointF &pixelCoord);
static int getDefaultAttributesSize(BaseGameVersion version);
static void setCustomLayout(Project*);
- static QString getMetatileIdString(uint16_t metatileId) { return "0x" + QString("%1").arg(metatileId, 3, 16, QChar('0')).toUpper(); };
+ static QString getMetatileIdString(uint16_t metatileId) {
+ return "0x" + QString("%1").arg(metatileId, 3, 16, QChar('0')).toUpper();
+ };
+ static QString getMetatileIdStringList(const QList metatileIds) {
+ QStringList metatiles;
+ for (auto metatileId : metatileIds)
+ metatiles << Metatile::getMetatileIdString(metatileId);
+ return metatiles.join(",");
+ };
private:
// Stores how each attribute should be laid out for all metatiles, according to the user's config
diff --git a/include/ui/projectsettingseditor.h b/include/ui/projectsettingseditor.h
index 5ba85813..3bd4d921 100644
--- a/include/ui/projectsettingseditor.h
+++ b/include/ui/projectsettingseditor.h
@@ -42,6 +42,10 @@ private:
bool promptSaveChanges();
bool promptRestoreDefaults();
+ void setBorderMetatilesUi(bool customSize);
+ void setBorderMetatileIds(bool customSize, QList metatileIds);
+ QList getBorderMetatileIds(bool customSize);
+
void createProjectPathsTable();
QString chooseProjectFile(const QString &defaultFilepath);
diff --git a/include/ui/uintspinbox.h b/include/ui/uintspinbox.h
index b561e219..dc08c9eb 100644
--- a/include/ui/uintspinbox.h
+++ b/include/ui/uintspinbox.h
@@ -64,4 +64,4 @@ signals:
void textChanged(const QString &text);
};
-#endif // UINTSPINBOX_H
\ No newline at end of file
+#endif // UINTSPINBOX_H
diff --git a/src/config.cpp b/src/config.cpp
index 8c51de9f..681dc3f9 100644
--- a/src/config.cpp
+++ b/src/config.cpp
@@ -735,7 +735,7 @@ QMap ProjectConfig::getKeyValueMap() {
map.insert("enable_triple_layer_metatiles", QString::number(this->enableTripleLayerMetatiles));
map.insert("new_map_metatile", Metatile::getMetatileIdString(this->newMapMetatileId));
map.insert("new_map_elevation", QString::number(this->newMapElevation));
- map.insert("new_map_border_metatiles", this->getNewMapBorderMetatileIdsString());
+ map.insert("new_map_border_metatiles", Metatile::getMetatileIdStringList(this->newMapBorderMetatileIds));
map.insert("default_primary_tileset", this->defaultPrimaryTileset);
map.insert("default_secondary_tileset", this->defaultSecondaryTileset);
map.insert("prefabs_filepath", this->prefabFilepath);
@@ -983,14 +983,6 @@ QList ProjectConfig::getNewMapBorderMetatileIds() {
return this->newMapBorderMetatileIds;
}
-QString ProjectConfig::getNewMapBorderMetatileIdsString() {
- QStringList metatiles;
- for (auto metatileId : this->newMapBorderMetatileIds){
- metatiles << Metatile::getMetatileIdString(metatileId);
- }
- return metatiles.join(",");
-}
-
QString ProjectConfig::getDefaultPrimaryTileset() {
return this->defaultPrimaryTileset;
}
diff --git a/src/project.cpp b/src/project.cpp
index 66e5aba8..588d0ee4 100644
--- a/src/project.cpp
+++ b/src/project.cpp
@@ -444,10 +444,6 @@ bool Project::readMapLayouts() {
"blockdata_filepath",
};
bool useCustomBorderSize = projectConfig.getUseCustomBorderSize();
- if (useCustomBorderSize) {
- requiredFields.append("border_width");
- requiredFields.append("border_height");
- }
for (int i = 0; i < layouts.size(); i++) {
QJsonObject layoutObj = layouts[i].toObject();
if (layoutObj.isEmpty())
diff --git a/src/ui/projectsettingseditor.cpp b/src/ui/projectsettingseditor.cpp
index 3afc77d1..45f79579 100644
--- a/src/ui/projectsettingseditor.cpp
+++ b/src/ui/projectsettingseditor.cpp
@@ -37,6 +37,13 @@ void ProjectSettingsEditor::connectSignals() {
connect(ui->button_ImportDefaultPrefabs, &QAbstractButton::clicked, this, &ProjectSettingsEditor::importDefaultPrefabsClicked);
connect(ui->comboBox_BaseGameVersion, &QComboBox::currentTextChanged, this, &ProjectSettingsEditor::promptRestoreDefaults);
connect(ui->comboBox_AttributesSize, &QComboBox::currentTextChanged, this, &ProjectSettingsEditor::updateAttributeLimits);
+ connect(ui->checkBox_EnableCustomBorderSize, &QCheckBox::stateChanged, [this](int state) {
+ bool customSize = (state == Qt::Checked);
+ // When switching between the spin boxes or line edit for border metatiles we set
+ // the newly-shown UI using the values from the hidden UI.
+ this->setBorderMetatileIds(customSize, this->getBorderMetatileIds(!customSize));
+ this->setBorderMetatilesUi(customSize);
+ });
// Record that there are unsaved changes if any of the settings are modified
for (auto combo : ui->centralwidget->findChildren())
@@ -69,9 +76,49 @@ void ProjectSettingsEditor::initUi() {
static const QRegularExpression expression(QString("^(%1,)*%1$").arg(regex_Hex)); // Comma-separated list of hex values
QRegularExpressionValidator *validator = new QRegularExpressionValidator(expression);
ui->lineEdit_BorderMetatiles->setValidator(validator);
+ this->setBorderMetatilesUi(projectConfig.getUseCustomBorderSize());
+ int maxMetatileId = Project::getNumMetatilesTotal() - 1;
+ ui->spinBox_FillMetatile->setMaximum(maxMetatileId);
+ ui->spinBox_BorderMetatile1->setMaximum(maxMetatileId);
+ ui->spinBox_BorderMetatile2->setMaximum(maxMetatileId);
+ ui->spinBox_BorderMetatile3->setMaximum(maxMetatileId);
+ ui->spinBox_BorderMetatile4->setMaximum(maxMetatileId);
ui->spinBox_Elevation->setMaximum(15);
- ui->spinBox_FillMetatile->setMaximum(Project::getNumMetatilesTotal() - 1);
+}
+
+void ProjectSettingsEditor::setBorderMetatilesUi(bool customSize) {
+ ui->widget_DefaultSizeBorderMetatiles->setVisible(!customSize);
+ ui->widget_CustomSizeBorderMetatiles->setVisible(customSize);
+}
+
+void ProjectSettingsEditor::setBorderMetatileIds(bool customSize, QList metatileIds) {
+ if (customSize) {
+ ui->lineEdit_BorderMetatiles->setText(Metatile::getMetatileIdStringList(metatileIds));
+ } else {
+ ui->spinBox_BorderMetatile1->setValue(metatileIds.value(0, 0x0));
+ ui->spinBox_BorderMetatile2->setValue(metatileIds.value(1, 0x0));
+ ui->spinBox_BorderMetatile3->setValue(metatileIds.value(2, 0x0));
+ ui->spinBox_BorderMetatile4->setValue(metatileIds.value(3, 0x0));
+ }
+}
+
+QList ProjectSettingsEditor::getBorderMetatileIds(bool customSize) {
+ QList metatileIds;
+ if (customSize) {
+ // Custom border size, read metatiles from line edit
+ for (auto s : ui->lineEdit_BorderMetatiles->text().split(",")) {
+ uint16_t metatileId = s.toUInt(nullptr, 0);
+ metatileIds.append(qMin(metatileId, static_cast(Project::getNumMetatilesTotal() - 1)));
+ }
+ } else {
+ // Default border size, read metatiles from spin boxes
+ metatileIds.append(ui->spinBox_BorderMetatile1->value());
+ metatileIds.append(ui->spinBox_BorderMetatile2->value());
+ metatileIds.append(ui->spinBox_BorderMetatile3->value());
+ metatileIds.append(ui->spinBox_BorderMetatile4->value());
+ }
+ return metatileIds;
}
void ProjectSettingsEditor::updateAttributeLimits(const QString &attrSize) {
@@ -186,8 +233,12 @@ void ProjectSettingsEditor::refresh() {
ui->spinBox_LayerTypeMask->setValue(projectConfig.getMetatileLayerTypeMask());
ui->spinBox_TerrainTypeMask->setValue(projectConfig.getMetatileTerrainTypeMask());
+ // Set (and sync) border metatile IDs
+ auto metatileIds = projectConfig.getNewMapBorderMetatileIds();
+ this->setBorderMetatileIds(false, metatileIds);
+ this->setBorderMetatileIds(true, metatileIds);
+
// Set line edit texts
- ui->lineEdit_BorderMetatiles->setText(projectConfig.getNewMapBorderMetatileIdsString());
ui->lineEdit_PrefabsPath->setText(projectConfig.getPrefabFilepath());
for (auto lineEdit : ui->scrollAreaContents_ProjectPaths->findChildren())
lineEdit->setText(projectConfig.getFilePath(lineEdit->objectName(), true));
@@ -230,14 +281,7 @@ void ProjectSettingsEditor::save() {
projectConfig.setPrefabFilepath(ui->lineEdit_PrefabsPath->text());
for (auto lineEdit : ui->scrollAreaContents_ProjectPaths->findChildren())
projectConfig.setFilePath(lineEdit->objectName(), lineEdit->text());
-
- // Parse and save border metatile list
- QList metatileIds;
- for (auto s : ui->lineEdit_BorderMetatiles->text().split(",")) {
- uint16_t metatileId = s.toUInt(nullptr, 0);
- metatileIds.append(qMin(metatileId, static_cast(Project::getNumMetatilesTotal() - 1)));
- }
- projectConfig.setNewMapBorderMetatileIds(metatileIds);
+ projectConfig.setNewMapBorderMetatileIds(this->getBorderMetatileIds(ui->checkBox_EnableCustomBorderSize->isChecked()));
projectConfig.setSaveDisabled(false);
projectConfig.save();