mirror of
https://github.com/OPM/ResInsight.git
synced 2025-01-07 14:43:10 -06:00
3590c52cdc
* Deprecate single summary plots and plot collections. Replace functionality using summary multi plots. Clean up some code. Fix crash when trying to normalize an empty curve
130 lines
4.8 KiB
C++
130 lines
4.8 KiB
C++
/////////////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// Copyright (C) 2017- Statoil ASA
|
|
//
|
|
// ResInsight is free software: you can redistribute it and/or modify
|
|
// it under the terms of the GNU General Public License as published by
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
// (at your option) any later version.
|
|
//
|
|
// ResInsight is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
// WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
// FITNESS FOR A PARTICULAR PURPOSE.
|
|
//
|
|
// See the GNU General Public License at <http://www.gnu.org/licenses/gpl.html>
|
|
// for more details.
|
|
//
|
|
/////////////////////////////////////////////////////////////////////////////////
|
|
|
|
#include "RicReloadSummaryCaseFeature.h"
|
|
|
|
#include "RiaLogging.h"
|
|
#include "RiaSummaryTools.h"
|
|
#include "RicReplaceSummaryCaseFeature.h"
|
|
|
|
#include "RimMainPlotCollection.h"
|
|
#include "RimObservedDataCollection.h"
|
|
#include "RimObservedSummaryData.h"
|
|
#include "RimProject.h"
|
|
#include "RimSummaryCase.h"
|
|
#include "RimSummaryCaseCollection.h"
|
|
#include "RimSummaryCaseMainCollection.h"
|
|
#include "RimSummaryMultiPlot.h"
|
|
#include "RimSummaryMultiPlotCollection.h"
|
|
#include "RimSummaryPlot.h"
|
|
|
|
#include "cafPdmObject.h"
|
|
#include "cafSelectionManager.h"
|
|
|
|
#include <QAction>
|
|
|
|
CAF_CMD_SOURCE_INIT( RicReloadSummaryCaseFeature, "RicReloadSummaryCaseFeature" );
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
bool RicReloadSummaryCaseFeature::isCommandEnabled()
|
|
{
|
|
std::vector<RimSummaryCase*> caseSelection = selectedSummaryCases();
|
|
|
|
return !caseSelection.empty();
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
void RicReloadSummaryCaseFeature::onActionTriggered( bool isChecked )
|
|
{
|
|
RimSummaryMultiPlotCollection* summaryPlotColl = RiaSummaryTools::summaryMultiPlotCollection();
|
|
|
|
std::vector<RimSummaryCase*> caseSelection = selectedSummaryCases();
|
|
for ( RimSummaryCase* summaryCase : caseSelection )
|
|
{
|
|
summaryCase->createSummaryReaderInterface();
|
|
summaryCase->createRftReaderInterface();
|
|
summaryCase->refreshMetaData();
|
|
|
|
RicReplaceSummaryCaseFeature::updateRequredCalculatedCurves( summaryCase );
|
|
|
|
RiaLogging::info( QString( "Reloaded data for %1" ).arg( summaryCase->summaryHeaderFilename() ) );
|
|
}
|
|
|
|
for ( RimSummaryMultiPlot* multiPlot : summaryPlotColl->multiPlots() )
|
|
{
|
|
for ( RimSummaryPlot* summaryPlot : multiPlot->summaryPlots() )
|
|
{
|
|
summaryPlot->loadDataAndUpdate();
|
|
}
|
|
}
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
void RicReloadSummaryCaseFeature::setupActionLook( QAction* actionToSetup )
|
|
{
|
|
actionToSetup->setText( "Reload" );
|
|
actionToSetup->setIcon( QIcon( ":/Refresh.svg" ) );
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
std::vector<RimSummaryCase*> RicReloadSummaryCaseFeature::selectedSummaryCases()
|
|
{
|
|
std::vector<RimSummaryCaseMainCollection*> mainCollectionSelection;
|
|
caf::SelectionManager::instance()->objectsByType( &mainCollectionSelection );
|
|
|
|
if ( mainCollectionSelection.size() > 0 )
|
|
{
|
|
return mainCollectionSelection[0]->allSummaryCases();
|
|
}
|
|
|
|
std::vector<RimSummaryCase*> caseSelection;
|
|
caf::SelectionManager::instance()->objectsByType( &caseSelection );
|
|
|
|
{
|
|
std::vector<RimSummaryCaseCollection*> collectionSelection;
|
|
caf::SelectionManager::instance()->objectsByType( &collectionSelection );
|
|
|
|
for ( auto collection : collectionSelection )
|
|
{
|
|
std::vector<RimSummaryCase*> summaryCaseCollection = collection->allSummaryCases();
|
|
caseSelection.insert( caseSelection.end(), summaryCaseCollection.begin(), summaryCaseCollection.end() );
|
|
}
|
|
}
|
|
|
|
{
|
|
std::vector<RimObservedDataCollection*> collectionSelection;
|
|
caf::SelectionManager::instance()->objectsByType( &collectionSelection );
|
|
|
|
for ( auto collection : collectionSelection )
|
|
{
|
|
std::vector<RimObservedSummaryData*> observedCases = collection->allObservedSummaryData();
|
|
caseSelection.insert( caseSelection.end(), observedCases.begin(), observedCases.end() );
|
|
}
|
|
}
|
|
|
|
return caseSelection;
|
|
}
|