small fixes
- connect DEL key to event deletion action - update checks for unsaved changes to map - add an asterisk next to the map name in the window title when a map has unsaved changes
This commit is contained in:
parent
4c154501f1
commit
c3defd6887
6 changed files with 47 additions and 24 deletions
|
@ -28,7 +28,8 @@ enum CommandId {
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
///
|
/// Implements a command to commit metatile paint actions
|
||||||
|
/// onto the map using the pencil tool.
|
||||||
class PaintMetatile : public QUndoCommand {
|
class PaintMetatile : public QUndoCommand {
|
||||||
public:
|
public:
|
||||||
PaintMetatile(Map *map,
|
PaintMetatile(Map *map,
|
||||||
|
@ -53,7 +54,7 @@ private:
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
///
|
/// Implements a command to commit paint actions on the map border.
|
||||||
class PaintBorder : public QUndoCommand {
|
class PaintBorder : public QUndoCommand {
|
||||||
public:
|
public:
|
||||||
PaintBorder(Map *map,
|
PaintBorder(Map *map,
|
||||||
|
@ -78,7 +79,8 @@ private:
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
///
|
/// Implements a command to commit flood fill metatile actions
|
||||||
|
/// with the bucket tool onto the map.
|
||||||
class BucketFillMetatile : public PaintMetatile {
|
class BucketFillMetatile : public PaintMetatile {
|
||||||
public:
|
public:
|
||||||
BucketFillMetatile(Map *map,
|
BucketFillMetatile(Map *map,
|
||||||
|
@ -92,7 +94,8 @@ public:
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
///
|
/// Implements a command to commit magic fill metatile actions
|
||||||
|
/// with the bucket or paint tool onto the map.
|
||||||
class MagicFillMetatile : public PaintMetatile {
|
class MagicFillMetatile : public PaintMetatile {
|
||||||
public:
|
public:
|
||||||
MagicFillMetatile(Map *map,
|
MagicFillMetatile(Map *map,
|
||||||
|
@ -107,7 +110,7 @@ public:
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
///
|
/// Implements a command to commit metatile shift actions.
|
||||||
class ShiftMetatiles : public QUndoCommand {
|
class ShiftMetatiles : public QUndoCommand {
|
||||||
public:
|
public:
|
||||||
ShiftMetatiles(Map *map,
|
ShiftMetatiles(Map *map,
|
||||||
|
@ -133,7 +136,7 @@ private:
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
///
|
/// Implements a command to commit a map or border resize action.
|
||||||
class ResizeMap : public QUndoCommand {
|
class ResizeMap : public QUndoCommand {
|
||||||
public:
|
public:
|
||||||
ResizeMap(Map *map, QSize oldMapDimensions, QSize newMapDimensions,
|
ResizeMap(Map *map, QSize oldMapDimensions, QSize newMapDimensions,
|
||||||
|
@ -171,7 +174,8 @@ private:
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
///
|
/// Implements a command to commit a single- or multi-Event move action.
|
||||||
|
/// Actions are merged into one until the mouse is released.
|
||||||
class EventMove : public QUndoCommand {
|
class EventMove : public QUndoCommand {
|
||||||
public:
|
public:
|
||||||
EventMove(QList<Event *> events,
|
EventMove(QList<Event *> events,
|
||||||
|
@ -195,7 +199,7 @@ private:
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
///
|
/// Implements a command to commit Event shift actions.
|
||||||
class EventShift : public EventMove {
|
class EventShift : public EventMove {
|
||||||
public:
|
public:
|
||||||
EventShift(QList<Event *> events,
|
EventShift(QList<Event *> events,
|
||||||
|
@ -208,7 +212,8 @@ public:
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
///
|
/// Implements a command to commit Event create actions.
|
||||||
|
/// Works for a single Event only.
|
||||||
class EventCreate : public QUndoCommand {
|
class EventCreate : public QUndoCommand {
|
||||||
public:
|
public:
|
||||||
EventCreate(Editor *editor, Map *map, Event *event,
|
EventCreate(Editor *editor, Map *map, Event *event,
|
||||||
|
@ -229,7 +234,8 @@ private:
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
///
|
/// Implements a command to commit Event deletions.
|
||||||
|
/// Applies to every currently selected Event.
|
||||||
class EventDelete : public QUndoCommand {
|
class EventDelete : public QUndoCommand {
|
||||||
public:
|
public:
|
||||||
EventDelete(Editor *editor, Map *map, QList<Event *> selectedEvents,
|
EventDelete(Editor *editor, Map *map, QList<Event *> selectedEvents,
|
||||||
|
|
|
@ -30,7 +30,6 @@ public:
|
||||||
Blockdata *cached_blockdata = nullptr;
|
Blockdata *cached_blockdata = nullptr;
|
||||||
Blockdata *cached_collision = nullptr;
|
Blockdata *cached_collision = nullptr;
|
||||||
Blockdata *cached_border = nullptr;
|
Blockdata *cached_border = nullptr;
|
||||||
bool has_unsaved_changes = false;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // MAPLAYOUT_H
|
#endif // MAPLAYOUT_H
|
||||||
|
|
|
@ -290,6 +290,8 @@ private:
|
||||||
void checkToolButtons();
|
void checkToolButtons();
|
||||||
void clickToolButtonFromEditMode(QString editMode);
|
void clickToolButtonFromEditMode(QString editMode);
|
||||||
|
|
||||||
|
void showWindowTitle();
|
||||||
|
|
||||||
void initWindow();
|
void initWindow();
|
||||||
void initCustomUI();
|
void initCustomUI();
|
||||||
void initExtraShortcuts();
|
void initExtraShortcuts();
|
||||||
|
|
|
@ -14,6 +14,7 @@
|
||||||
|
|
||||||
Map::Map(QObject *parent) : QObject(parent)
|
Map::Map(QObject *parent) : QObject(parent)
|
||||||
{
|
{
|
||||||
|
editHistory.setClean();
|
||||||
}
|
}
|
||||||
|
|
||||||
void Map::setName(QString mapName) {
|
void Map::setName(QString mapName) {
|
||||||
|
@ -466,5 +467,5 @@ void Map::addEvent(Event *event) {
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Map::hasUnsavedChanges() {
|
bool Map::hasUnsavedChanges() {
|
||||||
return !metatileHistory.isSaved() || !isPersistedToFile || layout->has_unsaved_changes;
|
return !editHistory.isClean() || !isPersistedToFile;
|
||||||
}
|
}
|
||||||
|
|
|
@ -107,6 +107,7 @@ void MainWindow::initExtraShortcuts() {
|
||||||
new QShortcut(QKeySequence("Ctrl+0"), this, SLOT(resetMapViewScale()));
|
new QShortcut(QKeySequence("Ctrl+0"), this, SLOT(resetMapViewScale()));
|
||||||
new QShortcut(QKeySequence("Ctrl+G"), ui->checkBox_ToggleGrid, SLOT(toggle()));
|
new QShortcut(QKeySequence("Ctrl+G"), ui->checkBox_ToggleGrid, SLOT(toggle()));
|
||||||
new QShortcut(QKeySequence("Ctrl+D"), this, SLOT(duplicate()));
|
new QShortcut(QKeySequence("Ctrl+D"), this, SLOT(duplicate()));
|
||||||
|
new QShortcut(QKeySequence::Delete, this, SLOT(on_toolButton_deleteObject_clicked()));
|
||||||
ui->actionZoom_In->setShortcuts({QKeySequence("Ctrl++"), QKeySequence("Ctrl+=")});
|
ui->actionZoom_In->setShortcuts({QKeySequence("Ctrl++"), QKeySequence("Ctrl+=")});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -168,6 +169,9 @@ void MainWindow::initEditor() {
|
||||||
//ui->comboBox_History->setSizeAdjustPolicy(QComboBox::AdjustToMinimumContentsLength);
|
//ui->comboBox_History->setSizeAdjustPolicy(QComboBox::AdjustToMinimumContentsLength);
|
||||||
//ui->comboBox_History->setModel(undoView->model());
|
//ui->comboBox_History->setModel(undoView->model());
|
||||||
//ui->comboBox_History->setView(undoView);
|
//ui->comboBox_History->setView(undoView);
|
||||||
|
|
||||||
|
// Toggle an asterisk in the window title when the undo state is changed
|
||||||
|
connect(&editor->editGroup, &QUndoGroup::cleanChanged, this, &MainWindow::showWindowTitle);
|
||||||
}
|
}
|
||||||
|
|
||||||
void MainWindow::initMiscHeapObjects() {
|
void MainWindow::initMiscHeapObjects() {
|
||||||
|
@ -211,6 +215,16 @@ void MainWindow::initMapSortOrder() {
|
||||||
sortOrder->setChecked(true);
|
sortOrder->setChecked(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void MainWindow::showWindowTitle() {
|
||||||
|
if (editor->map) {
|
||||||
|
setWindowTitle(QString("%1%2 - %3")
|
||||||
|
.arg(editor->map->hasUnsavedChanges() ? "* " : "")
|
||||||
|
.arg(editor->map->name)
|
||||||
|
.arg(editor->project->getProjectTitle())
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void MainWindow::setProjectSpecificUIVisibility()
|
void MainWindow::setProjectSpecificUIVisibility()
|
||||||
{
|
{
|
||||||
ui->actionUse_Encounter_Json->setChecked(projectConfig.getEncounterJsonActive());
|
ui->actionUse_Encounter_Json->setChecked(projectConfig.getEncounterJsonActive());
|
||||||
|
@ -399,7 +413,7 @@ bool MainWindow::openProject(QString dir) {
|
||||||
}
|
}
|
||||||
|
|
||||||
if (success) {
|
if (success) {
|
||||||
setWindowTitle(editor->project->getProjectTitle());
|
showWindowTitle();
|
||||||
this->statusBar()->showMessage(QString("Opened project %1").arg(nativeDir));
|
this->statusBar()->showMessage(QString("Opened project %1").arg(nativeDir));
|
||||||
} else {
|
} else {
|
||||||
this->statusBar()->showMessage(QString("Failed to open project %1").arg(nativeDir));
|
this->statusBar()->showMessage(QString("Failed to open project %1").arg(nativeDir));
|
||||||
|
@ -515,7 +529,7 @@ bool MainWindow::setMap(QString map_name, bool scrollTreeView) {
|
||||||
|
|
||||||
ui->mapList->setExpanded(mapListProxyModel->mapFromSource(mapListIndexes.value(map_name)), true);
|
ui->mapList->setExpanded(mapListProxyModel->mapFromSource(mapListIndexes.value(map_name)), true);
|
||||||
|
|
||||||
setWindowTitle(map_name + " - " + editor->project->getProjectTitle());
|
showWindowTitle();
|
||||||
|
|
||||||
connect(editor->map, SIGNAL(mapChanged(Map*)), this, SLOT(onMapChanged(Map *)));
|
connect(editor->map, SIGNAL(mapChanged(Map*)), this, SLOT(onMapChanged(Map *)));
|
||||||
connect(editor->map, SIGNAL(mapNeedsRedrawing()), this, SLOT(onMapNeedsRedrawing()));
|
connect(editor->map, SIGNAL(mapNeedsRedrawing()), this, SLOT(onMapNeedsRedrawing()));
|
||||||
|
@ -2108,9 +2122,11 @@ void MainWindow::on_horizontalSlider_CollisionTransparency_valueChanged(int valu
|
||||||
this->editor->collision_item->draw(true);
|
this->editor->collision_item->draw(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO: connect this to the DEL key when undo/redo history is extended to events
|
void MainWindow::on_toolButton_deleteObject_clicked() {
|
||||||
void MainWindow::on_toolButton_deleteObject_clicked()
|
if (ui->mainTabBar->currentIndex() != 1) {
|
||||||
{
|
// do not delete an event when not on event tab
|
||||||
|
return;
|
||||||
|
}
|
||||||
if (editor && editor->selected_events) {
|
if (editor && editor->selected_events) {
|
||||||
if (editor->selected_events->length()) {
|
if (editor->selected_events->length()) {
|
||||||
DraggablePixmapItem *next_selected_event = nullptr;
|
DraggablePixmapItem *next_selected_event = nullptr;
|
||||||
|
@ -2311,7 +2327,6 @@ void MainWindow::onLoadMapRequested(QString mapName, QString fromMapName) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void MainWindow::onMapChanged(Map *map) {
|
void MainWindow::onMapChanged(Map *map) {
|
||||||
map->layout->has_unsaved_changes = true;
|
|
||||||
updateMapList();
|
updateMapList();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1120,7 +1120,7 @@ void Project::saveTilesetPalettes(Tileset *tileset) {
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Project::loadMapTilesets(Map* map) {
|
bool Project::loadMapTilesets(Map* map) {
|
||||||
if (map->layout->has_unsaved_changes) {
|
if (map->hasUnsavedChanges()) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1179,8 +1179,8 @@ Tileset* Project::loadTileset(QString label, Tileset *tileset) {
|
||||||
return tileset;
|
return tileset;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Project::loadBlockdata(Map* map) {
|
bool Project::loadBlockdata(Map *map) {
|
||||||
if (!map->isPersistedToFile || map->layout->has_unsaved_changes) {
|
if (map->hasUnsavedChanges()) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1198,7 +1198,7 @@ bool Project::loadBlockdata(Map* map) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
void Project::setNewMapBlockdata(Map* map) {
|
void Project::setNewMapBlockdata(Map *map) {
|
||||||
Blockdata *blockdata = new Blockdata;
|
Blockdata *blockdata = new Blockdata;
|
||||||
for (int i = 0; i < map->getWidth() * map->getHeight(); i++) {
|
for (int i = 0; i < map->getWidth() * map->getHeight(); i++) {
|
||||||
blockdata->addBlock(qint16(0x3001));
|
blockdata->addBlock(qint16(0x3001));
|
||||||
|
@ -1207,7 +1207,7 @@ void Project::setNewMapBlockdata(Map* map) {
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Project::loadMapBorder(Map *map) {
|
bool Project::loadMapBorder(Map *map) {
|
||||||
if (!map->isPersistedToFile || map->layout->has_unsaved_changes) {
|
if (map->hasUnsavedChanges()) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1461,7 +1461,7 @@ void Project::saveMap(Map *map) {
|
||||||
updateMapLayout(map);
|
updateMapLayout(map);
|
||||||
|
|
||||||
map->isPersistedToFile = true;
|
map->isPersistedToFile = true;
|
||||||
map->layout->has_unsaved_changes = false;
|
map->editHistory.setClean();
|
||||||
}
|
}
|
||||||
|
|
||||||
void Project::updateMapLayout(Map* map) {
|
void Project::updateMapLayout(Map* map) {
|
||||||
|
|
Loading…
Reference in a new issue