mirror of
https://github.com/OPM/ResInsight.git
synced 2025-02-25 18:55:39 -06:00
201 lines
7.0 KiB
C++
201 lines
7.0 KiB
C++
/////////////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// Copyright (C) 2020- Equinor 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 "RimVfpPlotCollection.h"
|
|
|
|
#include "RimVfpDeck.h"
|
|
#include "RimVfpTableData.h"
|
|
|
|
#include "cafCmdFeatureMenuBuilder.h"
|
|
|
|
CAF_PDM_SOURCE_INIT( RimVfpPlotCollection, "RimVfpPlotCollection" );
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
RimVfpPlotCollection::RimVfpPlotCollection()
|
|
{
|
|
CAF_PDM_InitObject( "VFP Plots", ":/VfpPlotCollection.svg" );
|
|
|
|
CAF_PDM_InitFieldNoDefault( &m_vfpPlots, "VfpPlots", "Vertical Flow Performance Plots" );
|
|
CAF_PDM_InitFieldNoDefault( &m_vfpDecks, "VfpDecks", "Vertical Flow Performance Decks" );
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
RimVfpPlot* RimVfpPlotCollection::createAndAppendPlots( RimVfpTableData* tableData )
|
|
{
|
|
if ( !tableData ) return nullptr;
|
|
|
|
tableData->ensureDataIsImported();
|
|
|
|
if ( !tableData->vfpTables() ) return nullptr;
|
|
|
|
RimVfpPlot* firstPlot = nullptr;
|
|
|
|
if ( tableData->tableCount() > 1 )
|
|
{
|
|
auto* deck = new RimVfpDeck();
|
|
deck->setDataSource( tableData );
|
|
addDeck( deck );
|
|
deck->loadDataAndUpdate();
|
|
deck->updateAllRequiredEditors();
|
|
|
|
auto plots = deck->plots();
|
|
if ( !plots.empty() )
|
|
{
|
|
firstPlot = plots.front();
|
|
}
|
|
}
|
|
else
|
|
{
|
|
auto vfpPlot = new RimVfpPlot();
|
|
vfpPlot->setDataSource( tableData );
|
|
vfpPlot->initializeObject();
|
|
|
|
addPlot( vfpPlot );
|
|
vfpPlot->loadDataAndUpdate();
|
|
|
|
firstPlot = vfpPlot;
|
|
}
|
|
|
|
return firstPlot;
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
void RimVfpPlotCollection::addPlot( RimVfpPlot* newPlot )
|
|
{
|
|
m_vfpPlots.push_back( newPlot );
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
void RimVfpPlotCollection::insertPlot( RimVfpPlot* vfpPlot, size_t index )
|
|
{
|
|
m_vfpPlots.insert( index, vfpPlot );
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
std::vector<RimVfpPlot*> RimVfpPlotCollection::plots() const
|
|
{
|
|
return m_vfpPlots.childrenByType();
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
RimVfpPlot* RimVfpPlotCollection::plotForTableNumber( int tableNumber ) const
|
|
{
|
|
for ( auto plot : plots() )
|
|
{
|
|
if ( plot->tableNumber() == tableNumber )
|
|
{
|
|
return plot;
|
|
}
|
|
}
|
|
|
|
return nullptr;
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
size_t RimVfpPlotCollection::plotCount() const
|
|
{
|
|
return m_vfpPlots.size();
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
void RimVfpPlotCollection::removePlot( RimVfpPlot* vfpPlot )
|
|
{
|
|
m_vfpPlots.removeChild( vfpPlot );
|
|
updateAllRequiredEditors();
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
void RimVfpPlotCollection::addDeck( RimVfpDeck* deck )
|
|
{
|
|
m_vfpDecks.push_back( deck );
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
void RimVfpPlotCollection::deleteAllPlots()
|
|
{
|
|
m_vfpPlots.deleteChildren();
|
|
m_vfpDecks.deleteChildren();
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
void RimVfpPlotCollection::addImportItems( caf::CmdFeatureMenuBuilder& menuBuilder )
|
|
{
|
|
// A variant with a true value is used to indicate that the VFP data is imported from a file
|
|
// This is used to distinguish between VFP data imported from a file and VFP data imported from a simulator
|
|
QVariant variant( QVariant::fromValue( true ) );
|
|
menuBuilder.addCmdFeatureWithUserData( "RicImportVfpDataFeature", "Import VFP Files", variant );
|
|
menuBuilder.addCmdFeature( "RicImportVfpDataFeature", "Import VFP from Simulator Files" );
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
void RimVfpPlotCollection::onChildrenUpdated( caf::PdmChildArrayFieldHandle* childArray, std::vector<caf::PdmObjectHandle*>& updatedObjects )
|
|
{
|
|
for ( auto plot : plots() )
|
|
{
|
|
plot->updateMdiWindowVisibility();
|
|
}
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
void RimVfpPlotCollection::loadDataAndUpdateAllPlots()
|
|
{
|
|
for ( auto plot : plots() )
|
|
{
|
|
plot->loadDataAndUpdate();
|
|
}
|
|
|
|
for ( auto deck : m_vfpDecks.childrenByType() )
|
|
{
|
|
deck->loadDataAndUpdate();
|
|
}
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
void RimVfpPlotCollection::appendMenuItems( caf::CmdFeatureMenuBuilder& menuBuilder ) const
|
|
{
|
|
addImportItems( menuBuilder );
|
|
}
|