mirror of
https://github.com/OPM/ResInsight.git
synced 2025-02-25 18:55:39 -06:00
#3736 Fix Linking issues related to Contour Maps.
* They are not allowed to be master views so a few things should be disallowed.
This commit is contained in:
@@ -23,9 +23,10 @@
|
||||
|
||||
#include "RicLinkVisibleViewsFeature.h"
|
||||
|
||||
#include "RimProject.h"
|
||||
#include "Rim3dView.h"
|
||||
#include "RimContourMapView.h"
|
||||
#include "RimGridView.h"
|
||||
#include "RimProject.h"
|
||||
#include "RimViewLinkerCollection.h"
|
||||
#include "RimViewLinker.h"
|
||||
|
||||
@@ -42,9 +43,14 @@ bool RicLinkViewFeature::isCommandEnabled()
|
||||
{
|
||||
std::vector<caf::PdmUiItem*> allSelectedItems;
|
||||
std::vector<RimGridView*> selectedGridViews;
|
||||
std::vector<RimContourMapView*> selectedContourMaps;
|
||||
|
||||
caf::SelectionManager::instance()->selectedItems(allSelectedItems);
|
||||
caf::SelectionManager::instance()->objectsByType(&selectedGridViews);
|
||||
if (selectedGridViews.size() > 1u && allSelectedItems.size() == selectedGridViews.size())
|
||||
caf::SelectionManager::instance()->objectsByType(&selectedContourMaps);
|
||||
size_t selectedRegularGridViews = selectedGridViews.size() - selectedContourMaps.size();
|
||||
|
||||
if (selectedGridViews.size() > 1u && selectedRegularGridViews >= 1u && allSelectedItems.size() == selectedGridViews.size())
|
||||
{
|
||||
return true;
|
||||
}
|
||||
@@ -80,8 +86,10 @@ void RicLinkViewFeature::onActionTriggered(bool isChecked)
|
||||
{
|
||||
std::vector<caf::PdmUiItem*> allSelectedItems;
|
||||
std::vector<RimGridView*> selectedGridViews;
|
||||
|
||||
caf::SelectionManager::instance()->selectedItems(allSelectedItems);
|
||||
caf::SelectionManager::instance()->objectsByType(&selectedGridViews);
|
||||
|
||||
if (selectedGridViews.size() > 1u && allSelectedItems.size() == selectedGridViews.size())
|
||||
{
|
||||
RicLinkVisibleViewsFeature::linkViews(selectedGridViews);
|
||||
|
||||
@@ -23,9 +23,10 @@
|
||||
|
||||
#include "RicLinkVisibleViewsFeatureUi.h"
|
||||
|
||||
#include "RimViewController.h"
|
||||
#include "RimProject.h"
|
||||
#include "RimContourMapView.h"
|
||||
#include "RimGridView.h"
|
||||
#include "RimProject.h"
|
||||
#include "RimViewController.h"
|
||||
#include "RimViewLinker.h"
|
||||
#include "RimViewLinkerCollection.h"
|
||||
|
||||
@@ -147,6 +148,15 @@ void RicLinkVisibleViewsFeature::linkViews(std::vector<RimGridView*>& views)
|
||||
RimProject* proj = RiaApplication::instance()->project();
|
||||
RimViewLinker* viewLinker = proj->viewLinkerCollection->viewLinker();
|
||||
|
||||
std::vector<RimGridView*> masterCandidates;
|
||||
for (RimGridView* view : views)
|
||||
{
|
||||
if (dynamic_cast<RimContourMapView*>(view) == nullptr)
|
||||
{
|
||||
masterCandidates.push_back(view);
|
||||
}
|
||||
}
|
||||
|
||||
if (!viewLinker)
|
||||
{
|
||||
// Create a new view linker
|
||||
@@ -155,15 +165,20 @@ void RicLinkVisibleViewsFeature::linkViews(std::vector<RimGridView*>& views)
|
||||
{
|
||||
return;
|
||||
}
|
||||
CVF_ASSERT(!masterCandidates.empty());
|
||||
|
||||
RicLinkVisibleViewsFeatureUi featureUi;
|
||||
featureUi.setViews(views);
|
||||
RimGridView* masterView = masterCandidates.front();
|
||||
if (masterCandidates.size() > 1u)
|
||||
{
|
||||
RicLinkVisibleViewsFeatureUi featureUi;
|
||||
featureUi.setViews(masterCandidates);
|
||||
|
||||
caf::PdmUiPropertyViewDialog propertyDialog(nullptr, &featureUi, "Select Master View", "");
|
||||
propertyDialog.setWindowIcon(QIcon(":/chain.png"));
|
||||
if (propertyDialog.exec() != QDialog::Accepted) return;
|
||||
caf::PdmUiPropertyViewDialog propertyDialog(nullptr, &featureUi, "Select Master View", "");
|
||||
propertyDialog.setWindowIcon(QIcon(":/chain.png"));
|
||||
if (propertyDialog.exec() != QDialog::Accepted) return;
|
||||
|
||||
RimGridView* masterView = featureUi.masterView();
|
||||
masterView = featureUi.masterView();
|
||||
}
|
||||
viewLinker = new RimViewLinker;
|
||||
proj->viewLinkerCollection()->viewLinker = viewLinker;
|
||||
viewLinker->setMasterView(masterView);
|
||||
|
||||
@@ -21,8 +21,9 @@
|
||||
|
||||
#include "RiaApplication.h"
|
||||
|
||||
#include "RimProject.h"
|
||||
#include "RimContourMapView.h"
|
||||
#include "RimGridView.h"
|
||||
#include "RimProject.h"
|
||||
#include "RimViewController.h"
|
||||
#include "RimViewLinker.h"
|
||||
#include "RimViewLinkerCollection.h"
|
||||
@@ -54,6 +55,11 @@ bool RicSetMasterViewFeature::isCommandEnabled()
|
||||
return false;
|
||||
}
|
||||
|
||||
if (dynamic_cast<RimContourMapView*>(activeView) != nullptr)
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user