///////////////////////////////////////////////////////////////////////////////// // // Copyright (C) 2016- 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 // for more details. // ///////////////////////////////////////////////////////////////////////////////// #include "RicNewSummaryPlotFeature.h" #include "RiaApplication.h" #include "RiaPreferences.h" #include "RiaSummaryTools.h" #include "RicEditSummaryPlotFeature.h" #include "RicNewSummaryEnsembleCurveSetFeature.h" #include "RicSummaryCurveCreator.h" #include "RicSummaryPlotEditorDialog.h" #include "RimEnsembleCurveFilter.h" #include "RimEnsembleCurveFilterCollection.h" #include "RimProject.h" #include "RimRegularLegendConfig.h" #include "RimSummaryCase.h" #include "RimSummaryCaseCollection.h" #include "RimSummaryCaseMainCollection.h" #include "RimSummaryCurveFilter.h" #include "RimSummaryPlot.h" #include "RimSummaryPlotCollection.h" #include "RiuPlotMainWindow.h" #include "cafSelectionManagerTools.h" #include "cvfAssert.h" #include CAF_CMD_SOURCE_INIT( RicNewSummaryPlotFeature, "RicNewSummaryPlotFeature" ); //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- bool RicNewSummaryPlotFeature::isCommandEnabled() { RimSummaryPlotCollection* sumPlotColl = nullptr; caf::PdmObject* selObj = dynamic_cast( caf::SelectionManager::instance()->selectedItem() ); if ( selObj ) { sumPlotColl = RiaSummaryTools::parentSummaryPlotCollection( selObj ); } auto ensembleFilter = dynamic_cast( selObj ); auto ensembleFilterColl = dynamic_cast( selObj ); auto legendConfig = dynamic_cast( selObj ); if ( ensembleFilter || ensembleFilterColl || legendConfig ) return false; if ( sumPlotColl ) return true; // Multiple case selections std::vector selectedItems = caf::selectedObjectsByTypeStrict(); for ( auto item : selectedItems ) { if ( !dynamic_cast( item ) && !dynamic_cast( item ) ) return false; } return true; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RicNewSummaryPlotFeature::onActionTriggered( bool isChecked ) { RimProject* project = RiaApplication::instance()->project(); CVF_ASSERT( project ); std::vector selectedCases = caf::selectedObjectsByType(); std::vector selectedGroups = caf::selectedObjectsByType(); std::vector sourcesToSelect( selectedCases.begin(), selectedCases.end() ); if ( sourcesToSelect.empty() && selectedGroups.empty() ) { const auto allSingleCases = project->firstSummaryCaseMainCollection()->topLevelSummaryCases(); const auto allGroups = project->summaryGroups(); std::vector allEnsembles; for ( const auto group : allGroups ) if ( group->isEnsemble() ) allEnsembles.push_back( group ); if ( !allSingleCases.empty() ) { sourcesToSelect.push_back( allSingleCases.front() ); } else if ( !allEnsembles.empty() ) { sourcesToSelect.push_back( allEnsembles.front() ); } } // Append grouped cases for ( auto group : selectedGroups ) { if ( group->isEnsemble() ) { sourcesToSelect.push_back( group ); } else { auto groupCases = group->allSummaryCases(); sourcesToSelect.insert( sourcesToSelect.end(), groupCases.begin(), groupCases.end() ); } } auto dialog = RicEditSummaryPlotFeature::curveCreatorDialog(); if ( !dialog->isVisible() ) { dialog->show(); } else { dialog->raise(); } dialog->updateFromDefaultCases( sourcesToSelect ); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RicNewSummaryPlotFeature::setupActionLook( QAction* actionToSetup ) { actionToSetup->setText( "Open Summary Plot Editor" ); actionToSetup->setIcon( QIcon( ":/SummaryPlotLight16x16.png" ) ); } //================================================================================================== /// //================================================================================================== #include "RicNewSummaryCurveFeature.h" #include "RicSummaryPlotFeatureImpl.h" #include "RimMainPlotCollection.h" #include "RiuPlotMainWindowTools.h" CAF_CMD_SOURCE_INIT( RicNewDefaultSummaryPlotFeature, "RicNewDefaultSummaryPlotFeature" ); void extractPlotObjectsFromSelection( std::vector* selectedIndividualSummaryCases, std::vector* selectedEnsembles ) { CAF_ASSERT( selectedIndividualSummaryCases && selectedEnsembles ); // First try selected ensembles caf::SelectionManager::instance()->objectsByTypeStrict( selectedEnsembles ); if ( !selectedEnsembles->empty() ) { return; } // Second try selected summary cases caf::SelectionManager::instance()->objectsByTypeStrict( selectedIndividualSummaryCases ); if ( !selectedIndividualSummaryCases->empty() ) { return; } RimSummaryPlotCollection* sumPlotColl = caf::SelectionManager::instance()->selectedItemAncestorOfType(); if ( sumPlotColl ) { RimSummaryCase* firstIndividualSummaryCase = nullptr; RimSummaryCaseCollection* firstEnsemble = nullptr; auto sumCaseVector = RiaApplication::instance()->project()->allSummaryCases(); for ( RimSummaryCase* summaryCase : sumCaseVector ) { RimSummaryCaseCollection* parentEnsemble = nullptr; summaryCase->firstAncestorOrThisOfType( parentEnsemble ); if ( !parentEnsemble && !firstIndividualSummaryCase ) { firstIndividualSummaryCase = summaryCase; break; } else if ( parentEnsemble && !firstEnsemble ) { firstEnsemble = parentEnsemble; } } if ( firstIndividualSummaryCase ) { selectedIndividualSummaryCases->push_back( firstIndividualSummaryCase ); } else if ( firstEnsemble ) { selectedEnsembles->push_back( firstEnsemble ); } } } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- bool RicNewDefaultSummaryPlotFeature::isCommandEnabled() { std::vector selectedIndividualSummaryCases; std::vector selectedEnsembles; extractPlotObjectsFromSelection( &selectedIndividualSummaryCases, &selectedEnsembles ); return !( selectedIndividualSummaryCases.empty() && selectedEnsembles.empty() ); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RicNewDefaultSummaryPlotFeature::onActionTriggered( bool isChecked ) { std::vector selectedIndividualSummaryCases; std::vector selectedEnsembles; extractPlotObjectsFromSelection( &selectedIndividualSummaryCases, &selectedEnsembles ); if ( !selectedIndividualSummaryCases.empty() ) { RimSummaryPlotCollection* sumPlotColl = RiaApplication::instance()->project()->mainPlotCollection()->summaryPlotCollection(); RimSummaryPlot* newPlot = sumPlotColl->createSummaryPlotWithAutoTitle(); for ( RimSummaryCase* sumCase : selectedIndividualSummaryCases ) { RicSummaryPlotFeatureImpl::addDefaultCurvesToPlot( newPlot, sumCase ); } newPlot->applyDefaultCurveAppearances(); newPlot->loadDataAndUpdate(); sumPlotColl->updateConnectedEditors(); RiuPlotMainWindowTools::setExpanded( newPlot ); RiuPlotMainWindowTools::selectAsCurrentItem( newPlot ); } else { CAF_ASSERT( !selectedEnsembles.empty() ); RicNewSummaryEnsembleCurveSetFeature::createPlotForCurveSetsAndUpdate( selectedEnsembles ); } } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RicNewDefaultSummaryPlotFeature::setupActionLook( QAction* actionToSetup ) { std::vector selectedIndividualSummaryCases; std::vector selectedEnsembles; extractPlotObjectsFromSelection( &selectedIndividualSummaryCases, &selectedEnsembles ); if ( !selectedIndividualSummaryCases.empty() ) { actionToSetup->setText( "New Summary Plot" ); } else { actionToSetup->setText( "New Ensemble Summary Plot" ); } actionToSetup->setIcon( QIcon( ":/SummaryPlotLight16x16.png" ) ); }