From 1b71e5da44e94b1d76ffdf21cfd70dcb5a993785 Mon Sep 17 00:00:00 2001 From: Michael Jackson Date: Sun, 10 Feb 2019 11:41:35 -0500 Subject: [PATCH] Mitigate crashes when user quickly rearranges pipeline views. There is some minimal flashing of the SVPipelineView at the start/end of the animation but by disabling the SVPipelineView we stop the user from putting the PipelineModel into a state that will cause crashes. updates #315 Signed-off-by: Michael Jackson --- .../Widgets/util/AddFilterCommand.cpp | 14 +++++++++++--- .../Widgets/util/RemoveFilterCommand.cpp | 15 +++++++++++---- 2 files changed, 22 insertions(+), 7 deletions(-) diff --git a/Source/SVWidgetsLib/Widgets/util/AddFilterCommand.cpp b/Source/SVWidgetsLib/Widgets/util/AddFilterCommand.cpp index 58aa6e1e4b..f7023f3b19 100644 --- a/Source/SVWidgetsLib/Widgets/util/AddFilterCommand.cpp +++ b/Source/SVWidgetsLib/Widgets/util/AddFilterCommand.cpp @@ -206,6 +206,7 @@ void AddFilterCommand::redo() // ----------------------------------------------------------------------------- void AddFilterCommand::addFilter(const AbstractFilter::Pointer &filter, int insertionIndex) { + m_PipelineView->setDisabled(true); // Reset the filter's Removing property filter->setRemoving(false); @@ -229,6 +230,7 @@ void AddFilterCommand::addFilter(const AbstractFilter::Pointer &filter, int inse { QSize size = model->data(filterIndex, Qt::SizeHintRole).toSize(); model->setData(filterIndex, size.height(), PipelineModel::Roles::HeightRole); + m_PipelineView->setEnabled(true); } else { @@ -238,8 +240,10 @@ void AddFilterCommand::addFilter(const AbstractFilter::Pointer &filter, int inse new PipelineItemSlideAnimation(model, QPersistentModelIndex(filterIndex), filterRect.width(), PipelineItemSlideAnimation::AnimationDirection::EnterRight); model->setData(QPersistentModelIndex(filterIndex), PipelineItem::AnimationType::Add, PipelineModel::Roles::AnimationTypeRole); - QObject::connect(slideAnimation, &PipelineItemSlideAnimation::finished, - [=] { model->setData(QPersistentModelIndex(filterIndex), PipelineItem::AnimationType::None, PipelineModel::Roles::AnimationTypeRole); }); + QObject::connect(slideAnimation, &PipelineItemSlideAnimation::finished, [=] { + model->setData(QPersistentModelIndex(filterIndex), PipelineItem::AnimationType::None, PipelineModel::Roles::AnimationTypeRole); + m_PipelineView->setEnabled(true); + }); slideAnimation->start(QAbstractAnimation::DeleteWhenStopped); } } @@ -258,6 +262,7 @@ void AddFilterCommand::removeFilter(const QPersistentModelIndex& index) return; } + m_PipelineView->setDisabled(true); disconnectFilterSignalsSlots(filter); QRect filterRect = m_PipelineView->visualRect(index); @@ -265,7 +270,10 @@ void AddFilterCommand::removeFilter(const QPersistentModelIndex& index) PipelineItemSlideAnimation* animation = new PipelineItemSlideAnimation(model, QPersistentModelIndex(index), filterRect.width(), PipelineItemSlideAnimation::AnimationDirection::ExitRight); model->setData(QPersistentModelIndex(index), PipelineItem::AnimationType::Remove, PipelineModel::Roles::AnimationTypeRole); - QObject::connect(animation, &PipelineItemSlideAnimation::finished, [=]() mutable { model->removeRow(index.row()); }); + QObject::connect(animation, &PipelineItemSlideAnimation::finished, [=]() mutable { + model->removeRow(index.row()); + m_PipelineView->setEnabled(true); + }); animation->start(QAbstractAnimation::DeleteWhenStopped); } diff --git a/Source/SVWidgetsLib/Widgets/util/RemoveFilterCommand.cpp b/Source/SVWidgetsLib/Widgets/util/RemoveFilterCommand.cpp index ceaa65ea59..d699b2b96f 100644 --- a/Source/SVWidgetsLib/Widgets/util/RemoveFilterCommand.cpp +++ b/Source/SVWidgetsLib/Widgets/util/RemoveFilterCommand.cpp @@ -197,7 +197,7 @@ void RemoveFilterCommand::redo() void RemoveFilterCommand::addFilter(const AbstractFilter::Pointer& filter, int insertionIndex) { filter->setRemoving(false); - + m_PipelineView->setDisabled(true); PipelineModel* model = m_PipelineView->getPipelineModel(); model->insertRow(insertionIndex); @@ -217,8 +217,10 @@ void RemoveFilterCommand::addFilter(const AbstractFilter::Pointer& filter, int i PipelineItemSlideAnimation* animation = new PipelineItemSlideAnimation(model, QPersistentModelIndex(filterIndex), filterRect.width(), PipelineItemSlideAnimation::AnimationDirection::EnterRight); model->setData(QPersistentModelIndex(filterIndex), PipelineItem::AnimationType::Add, PipelineModel::Roles::AnimationTypeRole); - QObject::connect(animation, &PipelineItemSlideAnimation::finished, - [=] { model->setData(QPersistentModelIndex(filterIndex), PipelineItem::AnimationType::None, PipelineModel::Roles::AnimationTypeRole); }); + QObject::connect(animation, &PipelineItemSlideAnimation::finished, [=] { + model->setData(QPersistentModelIndex(filterIndex), PipelineItem::AnimationType::None, PipelineModel::Roles::AnimationTypeRole); + m_PipelineView->setEnabled(true); + }); animation->start(QAbstractAnimation::DeleteWhenStopped); } @@ -233,6 +235,7 @@ void RemoveFilterCommand::removeFilter(const AbstractFilter::Pointer& filter) { return; } + m_PipelineView->setDisabled(true); filter->setRemoving(true); PipelineModel* model = m_PipelineView->getPipelineModel(); @@ -248,13 +251,17 @@ void RemoveFilterCommand::removeFilter(const AbstractFilter::Pointer& filter) if(!m_UseAnimationOnFirstRun && m_FirstRun) { model->removeRow(persistentIndex.row()); + m_PipelineView->setEnabled(true); } else { PipelineItemSlideAnimation* animation = new PipelineItemSlideAnimation(model, persistentIndex, filterRect.width(), PipelineItemSlideAnimation::AnimationDirection::ExitRight); model->setData(persistentIndex, PipelineItem::AnimationType::Remove, PipelineModel::Roles::AnimationTypeRole); - QObject::connect(animation, &PipelineItemSlideAnimation::finished, [=] { model->removeRow(persistentIndex.row()); }); + QObject::connect(animation, &PipelineItemSlideAnimation::finished, [=] { + model->removeRow(persistentIndex.row()); + m_PipelineView->setEnabled(true); + }); animation->start(QAbstractAnimation::DeleteWhenStopped); } }