From cc4655e9c7f2b54edd58a179513bd7b8f9957b91 Mon Sep 17 00:00:00 2001 From: Aesylwinn Date: Tue, 24 May 2016 18:19:05 -0400 Subject: [PATCH] Cleanup and slight change to pathgrid editing controls. Now that there is a drag indicator, it is easy to tell if an operation is active or not. --- apps/opencs/model/world/commands.cpp | 6 +----- apps/opencs/model/world/nestedcoladapterimp.cpp | 3 ++- apps/opencs/view/render/pagedworldspacewidget.cpp | 2 +- apps/opencs/view/render/pathgridmode.cpp | 6 ++++-- 4 files changed, 8 insertions(+), 9 deletions(-) diff --git a/apps/opencs/model/world/commands.cpp b/apps/opencs/model/world/commands.cpp index 308b5386e..d53d3f17c 100644 --- a/apps/opencs/model/world/commands.cpp +++ b/apps/opencs/model/world/commands.cpp @@ -36,6 +36,7 @@ CSMWorld::ModifyCommand::ModifyCommand (QAbstractItemModel& model, const QModelI { IdTree& tree = static_cast(*mModel); + // ModifyNestedCommand will add its own command to change the modify status if needed mModifyNestedCommand = new ModifyNestedCommand(tree, mIndex, new_, this); setText(mModifyNestedCommand->text()); } @@ -48,12 +49,7 @@ CSMWorld::ModifyCommand::ModifyCommand (QAbstractItemModel& model, const QModelI { mHasRecordState = true; int stateColumnIndex = table->findColumnIndex(Columns::ColumnId_Modification); - int rowIndex = mIndex.row(); - if (mIndex.parent().isValid()) - { - rowIndex = mIndex.parent().row(); - } mRecordStateIndex = table->index(rowIndex, stateColumnIndex); mOldRecordState = static_cast(table->data(mRecordStateIndex).toInt()); diff --git a/apps/opencs/model/world/nestedcoladapterimp.cpp b/apps/opencs/model/world/nestedcoladapterimp.cpp index 814406a7c..1fad55329 100644 --- a/apps/opencs/model/world/nestedcoladapterimp.cpp +++ b/apps/opencs/model/world/nestedcoladapterimp.cpp @@ -265,6 +265,7 @@ namespace CSMWorld case 0: return; // return without saving case 1: { + // Remove current and add new while adjusting each points connection count edges.erase(edges.begin()+subRowIndex); if (static_cast(edge.mV0) < points.size()) @@ -272,10 +273,10 @@ namespace CSMWorld edge.mV0 = value.toInt(); - // Place in correct order if (static_cast(edge.mV0) < points.size()) ++points[edge.mV0].mConnectionNum; + // Place in correct order ESM::Pathgrid::EdgeList::iterator it = edges.begin(); for (; it != edges.end(); ++it) { diff --git a/apps/opencs/view/render/pagedworldspacewidget.cpp b/apps/opencs/view/render/pagedworldspacewidget.cpp index a01df4392..1dba1306e 100644 --- a/apps/opencs/view/render/pagedworldspacewidget.cpp +++ b/apps/opencs/view/render/pagedworldspacewidget.cpp @@ -332,7 +332,7 @@ void CSVRender::PagedWorldspaceWidget::pathgridAboutToBeRemoved (const QModelInd void CSVRender::PagedWorldspaceWidget::pathgridAdded(const QModelIndex& parent, int start, int end) { - const CSMWorld::SubCellCollection& pathgrids = mDocument.getData().getPathgrids(); + const CSMWorld::SubCellCollection& pathgrids = mDocument.getData().getPathgrids(); if (!parent.isValid()) { diff --git a/apps/opencs/view/render/pathgridmode.cpp b/apps/opencs/view/render/pathgridmode.cpp index a4ab39497..fc16d7d99 100644 --- a/apps/opencs/view/render/pathgridmode.cpp +++ b/apps/opencs/view/render/pathgridmode.cpp @@ -131,9 +131,10 @@ namespace CSVRender if (!selection.empty()) { mDragMode = DragMode_Move; + return true; } - return true; + return false; } bool PathgridMode::secondaryEditStartDrag(const QPoint& pos) @@ -148,10 +149,11 @@ namespace CSVRender mFromNode = SceneUtil::getPathgridNode(static_cast(hit.index0)); tag->getPathgrid()->setupConnectionIndicator(mFromNode); + return true; } } - return true; + return false; } void PathgridMode::drag(const QPoint& pos, int diffX, int diffY, double speedFactor)