From 7cb75d6f015f40ff2ab00326ce286d4a71bc4163 Mon Sep 17 00:00:00 2001 From: lassoan Date: Wed, 18 Dec 2019 17:29:17 +0000 Subject: [PATCH] BUG: Fix markups control points table update Point positions in simple widget were not updating when points were moved. Batch updates might have been missed in qSlicerMarkupsModuleWidget. git-svn-id: http://svn.slicer.org/Slicer4/trunk@28693 3bd1e089-480b-0410-8dfb-8563597acbee --- .../Widgets/qSlicerSimpleMarkupsWidget.cxx | 3 +- .../Markups/qSlicerMarkupsModuleWidget.cxx | 67 ++++++------------- .../Markups/qSlicerMarkupsModuleWidget.h | 4 -- 3 files changed, 23 insertions(+), 51 deletions(-) diff --git a/Modules/Loadable/Markups/Widgets/qSlicerSimpleMarkupsWidget.cxx b/Modules/Loadable/Markups/Widgets/qSlicerSimpleMarkupsWidget.cxx index ffa4c114b82..2971398e4d9 100644 --- a/Modules/Loadable/Markups/Widgets/qSlicerSimpleMarkupsWidget.cxx +++ b/Modules/Loadable/Markups/Widgets/qSlicerSimpleMarkupsWidget.cxx @@ -182,6 +182,8 @@ void qSlicerSimpleMarkupsWidget::setCurrentNode(vtkMRMLNode* currentNode) this->qvtkReconnect(d->CurrentMarkupsNode, currentMarkupsNode, vtkCommand::ModifiedEvent, this, SLOT(updateWidget())); this->qvtkReconnect(d->CurrentMarkupsNode, currentMarkupsNode, vtkMRMLMarkupsNode::PointAddedEvent, this, SLOT(onPointAdded())); this->qvtkReconnect(d->CurrentMarkupsNode, currentMarkupsNode, vtkMRMLMarkupsNode::PointRemovedEvent, this, SLOT(updateWidget())); + this->qvtkReconnect(d->CurrentMarkupsNode, currentMarkupsNode, vtkMRMLMarkupsNode::PointModifiedEvent, this, SLOT(updateWidget())); + d->CurrentMarkupsNode = currentMarkupsNode; this->updateWidget(); @@ -623,7 +625,6 @@ void qSlicerSimpleMarkupsWidget::onPointAdded() d->MarkupsControlPointsTableWidget->scrollToBottom(); } - //------------------------------------------------------------------------------ void qSlicerSimpleMarkupsWidget::setMRMLScene(vtkMRMLScene* scene) { diff --git a/Modules/Loadable/Markups/qSlicerMarkupsModuleWidget.cxx b/Modules/Loadable/Markups/qSlicerMarkupsModuleWidget.cxx index fb7f34ff01e..147a73d1f5c 100644 --- a/Modules/Loadable/Markups/qSlicerMarkupsModuleWidget.cxx +++ b/Modules/Loadable/Markups/qSlicerMarkupsModuleWidget.cxx @@ -2131,53 +2131,26 @@ void qSlicerMarkupsModuleWidget::setMRMLMarkupsNode(vtkMRMLMarkupsNode* markupsN this->updateWidgetFromMRML(); } -//----------------------------------------------------------------------------- -void qSlicerMarkupsModuleWidget::onActiveMarkupsNodeLockModifiedEvent() -{ - Q_D(qSlicerMarkupsModuleWidget); - - // get the active list - vtkMRMLNode *mrmlNode = d->activeMarkupTreeView->currentNode(); - if (!mrmlNode) - { - return; - } - vtkMRMLMarkupsNode *markupsNode = vtkMRMLMarkupsNode::SafeDownCast(mrmlNode); - if (!markupsNode) - { - return; - } -} - -//----------------------------------------------------------------------------- -void qSlicerMarkupsModuleWidget::onActiveMarkupsNodeLabelFormatModifiedEvent() -{ - Q_D(qSlicerMarkupsModuleWidget); - if (!d->MarkupsNode) - { - return; - } - d->nameFormatLineEdit->setText(d->MarkupsNode->GetMarkupLabelFormat().c_str()); -} - //----------------------------------------------------------------------------- void qSlicerMarkupsModuleWidget::onActiveMarkupsNodePointModifiedEvent(vtkObject *caller, vtkObject *callData) { // the call data should be the index n - if (caller == nullptr || callData == nullptr) + if (caller == nullptr) { return; } - int *nPtr = nullptr; - int n = -1; - nPtr = reinterpret_cast(callData); - if (nPtr) + int* nPtr = reinterpret_cast(callData); + int n = (nPtr ? *nPtr : -1); + if (n>=0) { - n = *nPtr; + this->updateRow(n); + } + else + { + // batch update finished + this->updateWidgetFromMRML(); } - - this->updateRow(n); } //----------------------------------------------------------------------------- @@ -2207,21 +2180,23 @@ void qSlicerMarkupsModuleWidget::onActiveMarkupsNodePointRemovedEvent(vtkObject { Q_D(qSlicerMarkupsModuleWidget); - // the call data should be the index n - if (caller == nullptr || callData == nullptr) + if (caller == nullptr) { return; } - int *nPtr = nullptr; - int n = -1; - nPtr = reinterpret_cast(callData); - if (nPtr) + // the call data should be the index n + int *nPtr = reinterpret_cast(callData); + int n = (nPtr ? *nPtr : -1); + if (n >= 0) { - n = *nPtr; + d->activeMarkupTableWidget->removeRow(n); + } + else + { + // batch update finished + this->updateWidgetFromMRML(); } - - d->activeMarkupTableWidget->removeRow(n); } //----------------------------------------------------------------------------- diff --git a/Modules/Loadable/Markups/qSlicerMarkupsModuleWidget.h b/Modules/Loadable/Markups/qSlicerMarkupsModuleWidget.h index fba8bd5b32b..a5db1796ca5 100644 --- a/Modules/Loadable/Markups/qSlicerMarkupsModuleWidget.h +++ b/Modules/Loadable/Markups/qSlicerMarkupsModuleWidget.h @@ -202,10 +202,6 @@ public slots: /// Update table when markups node is modified void onActiveMarkupsNodeModifiedEvent(); - /// Enable/disable editing the table if the markups node is un/locked - void onActiveMarkupsNodeLockModifiedEvent(); - /// Update the format text entry from the node - void onActiveMarkupsNodeLabelFormatModifiedEvent(); /// Update the table with the modified point information if the node is active void onActiveMarkupsNodePointModifiedEvent(vtkObject *caller, vtkObject *callData); /// Update the table with the new point information if the node is active