update swap section feature for rme
This commit is contained in:
parent
4334e5b2e9
commit
cff77ad58e
6 changed files with 57 additions and 45 deletions
|
@ -68,7 +68,7 @@ public:
|
||||||
void resetSquare(int index);
|
void resetSquare(int index);
|
||||||
void clearLayout();
|
void clearLayout();
|
||||||
void clearImage();
|
void clearImage();
|
||||||
void replaceSectionId(unsigned oldId, unsigned newId);
|
void replaceSection(QString oldSection, QString newSection);
|
||||||
|
|
||||||
unsigned getTileId(int index);
|
unsigned getTileId(int index);
|
||||||
shared_ptr<TilemapTile> getTile(int index);
|
shared_ptr<TilemapTile> getTile(int index);
|
||||||
|
@ -101,6 +101,8 @@ public:
|
||||||
QList<LayoutSquare> getLayout(QString layer);
|
QList<LayoutSquare> getLayout(QString layer);
|
||||||
void setLayout(QString layer, QList<LayoutSquare> layout);
|
void setLayout(QString layer, QList<LayoutSquare> layout);
|
||||||
|
|
||||||
|
bool layoutEnabled() { return this->layout_format != LayoutFormat::None; }
|
||||||
|
|
||||||
QMap<QString, QList<LayoutSquare>> getAllLayouts();
|
QMap<QString, QList<LayoutSquare>> getAllLayouts();
|
||||||
void setAllLayouts(QMap<QString, QList<LayoutSquare>> newLayouts);
|
void setAllLayouts(QMap<QString, QList<LayoutSquare>> newLayouts);
|
||||||
|
|
||||||
|
@ -143,7 +145,7 @@ private:
|
||||||
// TODO: defaults needed?
|
// TODO: defaults needed?
|
||||||
tsl::ordered_map<QString, MapSectionEntry> *region_map_entries = nullptr;
|
tsl::ordered_map<QString, MapSectionEntry> *region_map_entries = nullptr;
|
||||||
|
|
||||||
QString alias;
|
QString alias = "";
|
||||||
|
|
||||||
int tilemap_width;
|
int tilemap_width;
|
||||||
int tilemap_height;
|
int tilemap_height;
|
||||||
|
@ -174,16 +176,15 @@ private:
|
||||||
QStringList layout_constants;
|
QStringList layout_constants;
|
||||||
QString layout_qualifiers;
|
QString layout_qualifiers;
|
||||||
|
|
||||||
|
#if QT_VERSION < QT_VERSION_CHECK(6, 0, 0)
|
||||||
|
QVector<shared_ptr<TilemapTile>> tilemap;
|
||||||
|
#else
|
||||||
QList<shared_ptr<TilemapTile>> tilemap;
|
QList<shared_ptr<TilemapTile>> tilemap;
|
||||||
|
#endif
|
||||||
|
|
||||||
QStringList layout_layers; // TODO: is this used?
|
QStringList layout_layers;
|
||||||
QString current_layer;
|
QString current_layer;
|
||||||
|
QMap<QString, QList<LayoutSquare>> layouts;
|
||||||
// TODO: just use ordered map?
|
|
||||||
QMap<QString, QList<LayoutSquare>> layouts; // key: layer, value: layout
|
|
||||||
|
|
||||||
// TODO
|
|
||||||
QString city_map_tiles_path;
|
|
||||||
|
|
||||||
int get_tilemap_index(int x, int y);
|
int get_tilemap_index(int x, int y);
|
||||||
int get_layout_index(int x, int y);
|
int get_layout_index(int x, int y);
|
||||||
|
|
|
@ -112,6 +112,7 @@ private:
|
||||||
void displayCityMap(QString name);
|
void displayCityMap(QString name);
|
||||||
void displayRegionMapEntryOptions();
|
void displayRegionMapEntryOptions();
|
||||||
void updateRegionMapEntryOptions(QString);
|
void updateRegionMapEntryOptions(QString);
|
||||||
|
void setRegionMap(RegionMap *map);
|
||||||
|
|
||||||
bool createCityMap(QString name);
|
bool createCityMap(QString name);
|
||||||
bool tryInsertNewMapEntry(QString);
|
bool tryInsertNewMapEntry(QString);
|
||||||
|
|
|
@ -33,8 +33,5 @@
|
||||||
},
|
},
|
||||||
"layout": null
|
"layout": null
|
||||||
}
|
}
|
||||||
],
|
]
|
||||||
"entries": {
|
|
||||||
"path": "src/data/region_map/region_map_sections.json"
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -84,8 +84,5 @@
|
||||||
"path": "src/data/region_map/region_map_layout_sevii_67.h"
|
"path": "src/data/region_map/region_map_layout_sevii_67.h"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
],
|
]
|
||||||
"revion_map_sections": {
|
|
||||||
"path": "src/data/region_map/region_map_sections.json"
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -80,7 +80,6 @@ bool RegionMap::loadTilemap(poryjson::Json tilemapJson) {
|
||||||
this->tileset_path = tilemapObject["tileset_path"].string_value();
|
this->tileset_path = tilemapObject["tileset_path"].string_value();
|
||||||
this->tilemap_path = tilemapObject["tilemap_path"].string_value();
|
this->tilemap_path = tilemapObject["tilemap_path"].string_value();
|
||||||
|
|
||||||
//! TODO: set a config option for this
|
|
||||||
if (tilemapObject.contains("palette")) {
|
if (tilemapObject.contains("palette")) {
|
||||||
this->palette_path = tilemapObject["palette"].string_value();
|
this->palette_path = tilemapObject["palette"].string_value();
|
||||||
}
|
}
|
||||||
|
@ -346,9 +345,13 @@ void RegionMap::clearImage() {
|
||||||
this->setTilemap(zeros);
|
this->setTilemap(zeros);
|
||||||
}
|
}
|
||||||
|
|
||||||
void RegionMap::replaceSectionId(unsigned oldId, unsigned newId) {
|
void RegionMap::replaceSection(QString oldSection, QString newSection) {
|
||||||
// TODO
|
for (auto &square : this->layouts[this->current_layer]) {
|
||||||
|
if (square.map_section == oldSection) {
|
||||||
|
square.map_section = newSection;
|
||||||
|
square.has_map = (newSection != "MAPSEC_NONE");
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void RegionMap::resize(int newWidth, int newHeight) {
|
void RegionMap::resize(int newWidth, int newHeight) {
|
||||||
|
|
|
@ -409,6 +409,8 @@ bool RegionMapEditor::load() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
// TODO: put this first? so can fall back on the above if parse errors
|
||||||
|
// TODO: verify this object before assignment
|
||||||
logInfo("Region map configuration file found.");
|
logInfo("Region map configuration file found.");
|
||||||
ParseUtil parser;
|
ParseUtil parser;
|
||||||
OrderedJson::object obj;
|
OrderedJson::object obj;
|
||||||
|
@ -443,16 +445,31 @@ bool RegionMapEditor::load() {
|
||||||
|
|
||||||
// display the first region map in the list
|
// display the first region map in the list
|
||||||
if (!region_maps.empty()) {
|
if (!region_maps.empty()) {
|
||||||
this->region_map = region_maps.begin()->second;
|
setRegionMap(region_maps.begin()->second);
|
||||||
this->currIndex = this->region_map->firstLayoutIndex();
|
|
||||||
this->region_map->editHistory.setActive();
|
|
||||||
|
|
||||||
displayRegionMap();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void RegionMapEditor::setRegionMap(RegionMap *map) {
|
||||||
|
//
|
||||||
|
this->region_map = map;
|
||||||
|
this->currIndex = this->region_map->firstLayoutIndex();
|
||||||
|
this->region_map->editHistory.setActive();
|
||||||
|
|
||||||
|
if (this->region_map->layoutEnabled()) {
|
||||||
|
this->ui->tabWidget_Region_Map->setTabEnabled(1, true);
|
||||||
|
this->ui->tabWidget_Region_Map->setTabEnabled(2, true);
|
||||||
|
} else {
|
||||||
|
this->ui->tabWidget_Region_Map->setTabEnabled(1, false);
|
||||||
|
this->ui->tabWidget_Region_Map->setTabEnabled(2, false);
|
||||||
|
}
|
||||||
|
|
||||||
|
this->ui->tabWidget_Region_Map->setCurrentIndex(0);
|
||||||
|
|
||||||
|
displayRegionMap();
|
||||||
|
}
|
||||||
|
|
||||||
bool RegionMapEditor::loadCityMaps() {
|
bool RegionMapEditor::loadCityMaps() {
|
||||||
// unused
|
// unused
|
||||||
// TODO
|
// TODO
|
||||||
|
@ -505,15 +522,7 @@ void RegionMapEditor::updateLayerDisplayed() {
|
||||||
void RegionMapEditor::on_comboBox_regionSelector_textActivated(const QString ®ion) {
|
void RegionMapEditor::on_comboBox_regionSelector_textActivated(const QString ®ion) {
|
||||||
//
|
//
|
||||||
if (this->region_maps.contains(region)) {
|
if (this->region_maps.contains(region)) {
|
||||||
this->region_map = region_maps.at(region);
|
setRegionMap(region_maps.at(region));
|
||||||
this->region_map->editHistory.setActive();
|
|
||||||
this->currIndex = this->region_map->firstLayoutIndex();
|
|
||||||
// TODO: make the above into a function that takes an alias string? in case there is more to it
|
|
||||||
|
|
||||||
// TODO: anything else needed here?
|
|
||||||
displayRegionMap();
|
|
||||||
|
|
||||||
//this->editGroup.setActiveStack(&(this->region_map->editHistory));
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -572,6 +581,8 @@ void RegionMapEditor::displayRegionMapLayout() {
|
||||||
}
|
}
|
||||||
|
|
||||||
void RegionMapEditor::displayRegionMapLayoutOptions() {
|
void RegionMapEditor::displayRegionMapLayoutOptions() {
|
||||||
|
if (!this->region_map->layoutEnabled()) return;
|
||||||
|
|
||||||
this->ui->comboBox_RM_ConnectedMap->clear();
|
this->ui->comboBox_RM_ConnectedMap->clear();
|
||||||
this->ui->comboBox_RM_ConnectedMap->addItems(this->project->mapSectionValueToName.values());
|
this->ui->comboBox_RM_ConnectedMap->addItems(this->project->mapSectionValueToName.values());
|
||||||
|
|
||||||
|
@ -634,6 +645,8 @@ void RegionMapEditor::displayRegionMapEntriesImage() {
|
||||||
}
|
}
|
||||||
|
|
||||||
void RegionMapEditor::displayRegionMapEntryOptions() {
|
void RegionMapEditor::displayRegionMapEntryOptions() {
|
||||||
|
if (!this->region_map->layoutEnabled()) return;
|
||||||
|
|
||||||
this->ui->comboBox_RM_Entry_MapSection->addItems(this->project->mapSectionValueToName.values());
|
this->ui->comboBox_RM_Entry_MapSection->addItems(this->project->mapSectionValueToName.values());
|
||||||
int width = this->region_map->tilemapWidth() - this->region_map->padLeft() - this->region_map->padRight();
|
int width = this->region_map->tilemapWidth() - this->region_map->padLeft() - this->region_map->padRight();
|
||||||
int height = this->region_map->tilemapHeight() - this->region_map->padTop() - this->region_map->padBottom();
|
int height = this->region_map->tilemapHeight() - this->region_map->padTop() - this->region_map->padBottom();
|
||||||
|
@ -646,6 +659,8 @@ void RegionMapEditor::displayRegionMapEntryOptions() {
|
||||||
}
|
}
|
||||||
|
|
||||||
void RegionMapEditor::updateRegionMapEntryOptions(QString section) {
|
void RegionMapEditor::updateRegionMapEntryOptions(QString section) {
|
||||||
|
if (!this->region_map->layoutEnabled()) return;
|
||||||
|
|
||||||
bool enabled = (section != "MAPSEC_NONE") && (this->region_map_entries.contains(section));
|
bool enabled = (section != "MAPSEC_NONE") && (this->region_map_entries.contains(section));
|
||||||
|
|
||||||
this->ui->lineEdit_RM_MapName->setEnabled(enabled);
|
this->ui->lineEdit_RM_MapName->setEnabled(enabled);
|
||||||
|
@ -671,8 +686,6 @@ void RegionMapEditor::updateRegionMapEntryOptions(QString section) {
|
||||||
this->ui->spinBox_RM_Entry_width->setValue(entry.width);
|
this->ui->spinBox_RM_Entry_width->setValue(entry.width);
|
||||||
this->ui->spinBox_RM_Entry_height->setValue(entry.height);
|
this->ui->spinBox_RM_Entry_height->setValue(entry.height);
|
||||||
|
|
||||||
// TODO: if not enabled, button to enable, otherwise button to disable / remove entry from map
|
|
||||||
|
|
||||||
this->ui->lineEdit_RM_MapName->blockSignals(false);
|
this->ui->lineEdit_RM_MapName->blockSignals(false);
|
||||||
this->ui->spinBox_RM_Entry_x->blockSignals(false);
|
this->ui->spinBox_RM_Entry_x->blockSignals(false);
|
||||||
this->ui->spinBox_RM_Entry_y->blockSignals(false);
|
this->ui->spinBox_RM_Entry_y->blockSignals(false);
|
||||||
|
@ -1007,6 +1020,7 @@ void RegionMapEditor::on_comboBox_layoutLayer_textActivated(const QString &text)
|
||||||
|
|
||||||
void RegionMapEditor::on_spinBox_RM_Entry_x_valueChanged(int x) {
|
void RegionMapEditor::on_spinBox_RM_Entry_x_valueChanged(int x) {
|
||||||
//tryInsertNewMapEntry(activeEntry);
|
//tryInsertNewMapEntry(activeEntry);
|
||||||
|
qDebug() << "spinBox_RM_Entry_x valueChanged" << x;
|
||||||
if (!this->region_map_entries.contains(activeEntry)) return;
|
if (!this->region_map_entries.contains(activeEntry)) return;
|
||||||
MapSectionEntry oldEntry = this->region_map_entries[activeEntry];
|
MapSectionEntry oldEntry = this->region_map_entries[activeEntry];
|
||||||
this->region_map_entries[activeEntry].x = x;
|
this->region_map_entries[activeEntry].x = x;
|
||||||
|
@ -1213,8 +1227,6 @@ void RegionMapEditor::resize(int w, int h) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void RegionMapEditor::on_action_Swap_triggered() {
|
void RegionMapEditor::on_action_Swap_triggered() {
|
||||||
// TODO: does this function still work?
|
|
||||||
// TODO: fix for string ids not uint8 ids
|
|
||||||
QDialog popup(this, Qt::WindowTitleHint | Qt::WindowCloseButtonHint);
|
QDialog popup(this, Qt::WindowTitleHint | Qt::WindowCloseButtonHint);
|
||||||
popup.setWindowTitle("Swap Map Sections");
|
popup.setWindowTitle("Swap Map Sections");
|
||||||
popup.setWindowModality(Qt::NonModal);
|
popup.setWindowModality(Qt::NonModal);
|
||||||
|
@ -1232,21 +1244,22 @@ void RegionMapEditor::on_action_Swap_triggered() {
|
||||||
form.addRow(&buttonBox);
|
form.addRow(&buttonBox);
|
||||||
|
|
||||||
QString beforeSection, afterSection;
|
QString beforeSection, afterSection;
|
||||||
uint8_t oldId, newId;
|
|
||||||
connect(&buttonBox, &QDialogButtonBox::rejected, &popup, &QDialog::reject);
|
connect(&buttonBox, &QDialogButtonBox::rejected, &popup, &QDialog::reject);
|
||||||
connect(&buttonBox, &QDialogButtonBox::accepted, [this, &popup, &oldSecBox, &newSecBox,
|
connect(&buttonBox, &QDialogButtonBox::accepted, [this, &popup, &oldSecBox, &newSecBox, &beforeSection, &afterSection](){
|
||||||
&beforeSection, &afterSection, &oldId, &newId](){
|
|
||||||
beforeSection = oldSecBox->currentText();
|
beforeSection = oldSecBox->currentText();
|
||||||
afterSection = newSecBox->currentText();
|
afterSection = newSecBox->currentText();
|
||||||
if (!beforeSection.isEmpty() && !afterSection.isEmpty()) {
|
if (!beforeSection.isEmpty() && !afterSection.isEmpty()) {
|
||||||
oldId = static_cast<uint8_t>(this->project->mapSectionNameToValue.value(beforeSection));
|
|
||||||
newId = static_cast<uint8_t>(this->project->mapSectionNameToValue.value(afterSection));
|
|
||||||
popup.accept();
|
popup.accept();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
if (popup.exec() == QDialog::Accepted) {
|
if (popup.exec() == QDialog::Accepted) {
|
||||||
this->region_map->replaceSectionId(oldId, newId);
|
QList<LayoutSquare> oldLayout = this->region_map->getLayout(this->region_map->getLayer());
|
||||||
|
this->region_map->replaceSection(beforeSection, afterSection);
|
||||||
|
QList<LayoutSquare> newLayout = this->region_map->getLayout(this->region_map->getLayer());
|
||||||
|
EditLayout *commit = new EditLayout(this->region_map, this->region_map->getLayer(), -2, oldLayout, newLayout);
|
||||||
|
commit->setText("Swap Layout Sections " + beforeSection + " >> " + afterSection);
|
||||||
|
this->region_map->editHistory.push(commit);
|
||||||
displayRegionMapLayout();
|
displayRegionMapLayout();
|
||||||
this->region_map_layout_item->select(this->region_map_layout_item->selectedTile);
|
this->region_map_layout_item->select(this->region_map_layout_item->selectedTile);
|
||||||
this->hasUnsavedChanges = true;
|
this->hasUnsavedChanges = true;
|
||||||
|
|
Loading…
Reference in a new issue