2012-05-18 02:45:23 -05:00
|
|
|
/////////////////////////////////////////////////////////////////////////////////
|
|
|
|
//
|
2014-09-23 08:04:57 -05:00
|
|
|
// Copyright (C) 2011- Statoil ASA
|
|
|
|
// Copyright (C) 2013- Ceetron Solutions AS
|
|
|
|
// Copyright (C) 2011-2012 Ceetron AS
|
2019-09-06 03:40:57 -05:00
|
|
|
//
|
2012-05-18 02:45:23 -05:00
|
|
|
// 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.
|
2019-09-06 03:40:57 -05:00
|
|
|
//
|
2012-05-18 02:45:23 -05:00
|
|
|
// 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.
|
2019-09-06 03:40:57 -05:00
|
|
|
//
|
|
|
|
// See the GNU General Public License at <http://www.gnu.org/licenses/gpl.html>
|
2012-05-18 02:45:23 -05:00
|
|
|
// for more details.
|
|
|
|
//
|
|
|
|
/////////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
2017-06-13 08:41:52 -05:00
|
|
|
#include "RiaDefines.h"
|
2017-05-31 09:16:28 -05:00
|
|
|
|
2015-08-01 16:04:04 -05:00
|
|
|
#include "cafPdmChildArrayField.h"
|
2015-07-31 11:58:23 -05:00
|
|
|
#include "cafPdmChildField.h"
|
2012-05-18 02:45:23 -05:00
|
|
|
#include "cafPdmDocument.h"
|
2017-10-11 06:52:29 -05:00
|
|
|
#include "cvfCollection.h"
|
2012-05-18 02:45:23 -05:00
|
|
|
|
2015-08-06 04:00:21 -05:00
|
|
|
#include <vector>
|
|
|
|
|
2017-01-10 02:51:39 -06:00
|
|
|
class RigEclipseCaseData;
|
2013-03-22 09:43:42 -05:00
|
|
|
class RigGridManager;
|
2013-05-06 03:55:00 -05:00
|
|
|
class RigMainGrid;
|
2017-10-11 06:52:29 -05:00
|
|
|
class RigWellPath;
|
2016-12-09 03:01:50 -06:00
|
|
|
|
2018-11-23 06:33:59 -06:00
|
|
|
class RimTextAnnotation;
|
|
|
|
class RimReachCircleAnnotation;
|
2018-11-26 07:06:17 -06:00
|
|
|
class RimPolylinesAnnotation;
|
2017-10-23 07:42:38 -05:00
|
|
|
class RimSummaryCalculationCollection;
|
2019-12-09 02:21:06 -06:00
|
|
|
class RimSummaryCalculation;
|
2015-07-31 11:58:23 -05:00
|
|
|
class RimCase;
|
2014-07-24 03:11:43 -05:00
|
|
|
class RimCommandObject;
|
2018-12-19 07:41:17 -06:00
|
|
|
class RimCommandObject;
|
2017-06-30 09:14:15 -05:00
|
|
|
class RimDialogData;
|
2015-07-31 11:58:23 -05:00
|
|
|
class RimEclipseCase;
|
2017-10-20 09:10:45 -05:00
|
|
|
class RimGeoMechCase;
|
2015-07-31 11:58:23 -05:00
|
|
|
class RimIdenticalGridCaseGroup;
|
2015-09-01 10:14:22 -05:00
|
|
|
class RimMainPlotCollection;
|
2018-12-19 07:41:17 -06:00
|
|
|
class RimMeasurement;
|
2019-09-06 03:40:57 -05:00
|
|
|
class RimAdvancedSnapshotExportDefinition;
|
2019-08-20 08:09:13 -05:00
|
|
|
class RimObservedSummaryData;
|
2015-07-31 11:58:23 -05:00
|
|
|
class RimOilField;
|
2020-04-30 09:54:25 -05:00
|
|
|
class RimColorLegendCollection;
|
2015-07-31 11:58:23 -05:00
|
|
|
class RimScriptCollection;
|
2016-05-31 06:42:27 -05:00
|
|
|
class RimSummaryCase;
|
2018-04-06 01:16:14 -05:00
|
|
|
class RimSummaryCaseCollection;
|
2018-06-25 08:14:47 -05:00
|
|
|
class RimSummaryCaseMainCollection;
|
2018-01-09 03:11:28 -06:00
|
|
|
class Rim3dView;
|
2018-01-15 07:52:22 -06:00
|
|
|
class RimGridView;
|
2019-11-14 13:48:11 -06:00
|
|
|
class RimPlotWindow;
|
2016-12-09 03:01:50 -06:00
|
|
|
class RimViewLinker;
|
|
|
|
class RimViewLinkerCollection;
|
2019-10-09 02:21:28 -05:00
|
|
|
class RimViewWindow;
|
2017-10-11 06:52:29 -05:00
|
|
|
class RimWellPath;
|
2017-10-20 09:10:45 -05:00
|
|
|
class RimWellPathImport;
|
2017-12-20 06:14:43 -06:00
|
|
|
class RimFractureTemplateCollection;
|
|
|
|
class RimFractureTemplate;
|
2018-12-13 12:49:37 -06:00
|
|
|
class RimValveTemplateCollection;
|
|
|
|
class RimValveTemplate;
|
|
|
|
class RimCompletionTemplateCollection;
|
2019-09-11 02:33:03 -05:00
|
|
|
class RimPlotTemplateFolderItem;
|
2012-05-18 02:45:23 -05:00
|
|
|
|
2015-08-06 08:55:17 -05:00
|
|
|
namespace caf
|
|
|
|
{
|
2019-09-06 03:40:57 -05:00
|
|
|
class PdmUiTreeOrdering;
|
2015-08-06 08:55:17 -05:00
|
|
|
}
|
|
|
|
|
2015-08-06 04:00:21 -05:00
|
|
|
class QAction;
|
2015-08-17 03:51:13 -05:00
|
|
|
class QMenu;
|
2015-08-06 04:00:21 -05:00
|
|
|
|
2012-05-18 02:45:23 -05:00
|
|
|
//==================================================================================================
|
2019-09-06 03:40:57 -05:00
|
|
|
///
|
|
|
|
///
|
2012-05-18 02:45:23 -05:00
|
|
|
//==================================================================================================
|
|
|
|
class RimProject : public caf::PdmDocument
|
|
|
|
{
|
2019-09-06 03:40:57 -05:00
|
|
|
CAF_PDM_HEADER_INIT;
|
2012-05-18 02:45:23 -05:00
|
|
|
|
|
|
|
public:
|
2019-09-06 03:40:57 -05:00
|
|
|
RimProject( void );
|
|
|
|
~RimProject( void ) override;
|
2020-04-22 07:35:25 -05:00
|
|
|
static RimProject* current();
|
2019-09-06 03:40:57 -05:00
|
|
|
|
|
|
|
caf::PdmChildArrayField<RimOilField*> oilFields;
|
2020-04-30 09:54:25 -05:00
|
|
|
caf::PdmChildField<RimColorLegendCollection*> colorLegendCollection;
|
2019-09-06 03:40:57 -05:00
|
|
|
caf::PdmChildField<RimScriptCollection*> scriptCollection;
|
|
|
|
caf::PdmChildField<RimWellPathImport*> wellPathImport;
|
|
|
|
caf::PdmChildField<RimMainPlotCollection*> mainPlotCollection;
|
|
|
|
caf::PdmChildField<RimViewLinkerCollection*> viewLinkerCollection;
|
|
|
|
caf::PdmChildField<RimSummaryCalculationCollection*> calculationCollection;
|
|
|
|
caf::PdmChildArrayField<RimCommandObject*> commandObjects;
|
|
|
|
|
2019-03-25 05:07:12 -05:00
|
|
|
caf::PdmChildArrayField<RimAdvancedSnapshotExportDefinition*> multiSnapshotDefinitions;
|
2016-12-16 07:05:11 -06:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
caf::PdmField<QString> mainWindowTreeViewState;
|
|
|
|
caf::PdmField<QString> mainWindowCurrentModelIndexPath;
|
2012-05-18 02:45:23 -05:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
caf::PdmField<QString> plotWindowTreeViewState;
|
|
|
|
caf::PdmField<QString> plotWindowCurrentModelIndexPath;
|
2015-08-25 05:40:55 -05:00
|
|
|
|
2019-12-10 07:58:47 -06:00
|
|
|
bool writeProjectFile();
|
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
void setScriptDirectories( const QString& scriptDirectories );
|
2019-09-11 02:33:03 -05:00
|
|
|
void setPlotTemplateFolders( const QStringList& plotTemplateFolders );
|
2019-05-06 03:36:05 -05:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
QString projectFileVersionString() const;
|
|
|
|
bool isProjectFileVersionEqualOrOlderThan( const QString& otherProjectFileVersion ) const;
|
|
|
|
void close();
|
2012-05-18 02:45:23 -05:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
void setProjectFileNameAndUpdateDependencies( const QString& projectFileName );
|
2013-04-08 01:44:33 -05:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
void assignCaseIdToCase( RimCase* reservoirCase );
|
|
|
|
void assignIdToCaseGroup( RimIdenticalGridCaseGroup* caseGroup );
|
2019-11-14 13:48:11 -06:00
|
|
|
void assignViewIdToView( Rim3dView* view );
|
|
|
|
void assignPlotIdToPlotWindow( RimPlotWindow* plotWindow );
|
2019-12-09 02:21:06 -06:00
|
|
|
void assignCalculationIdToCalculation( RimSummaryCalculation* calculation );
|
2020-04-08 07:30:38 -05:00
|
|
|
void assignCaseIdToSummaryCase( RimSummaryCase* summaryCase );
|
2020-04-08 09:17:47 -05:00
|
|
|
void assignIdToEnsemble( RimSummaryCaseCollection* summaryCaseCollection );
|
2013-05-15 03:51:41 -05:00
|
|
|
|
2020-04-30 13:51:25 -05:00
|
|
|
std::vector<RimCase*> allGridCases() const;
|
|
|
|
void allCases( std::vector<RimCase*>& cases ) const; // Deprecated, use allGridCases()
|
2017-12-01 02:34:43 -06:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
std::vector<RimSummaryCase*> allSummaryCases() const;
|
2018-04-06 01:16:14 -05:00
|
|
|
std::vector<RimSummaryCaseCollection*> summaryGroups() const;
|
2019-09-06 03:40:57 -05:00
|
|
|
RimSummaryCaseMainCollection* firstSummaryCaseMainCollection() const;
|
2018-06-25 08:14:47 -05:00
|
|
|
|
2019-11-04 04:34:34 -06:00
|
|
|
void allViews( std::vector<Rim3dView*>& views ) const;
|
2019-09-06 03:40:57 -05:00
|
|
|
void allVisibleViews( std::vector<Rim3dView*>& views ) const;
|
|
|
|
void allVisibleGridViews( std::vector<RimGridView*>& views ) const;
|
|
|
|
void allNotLinkedViews( std::vector<RimGridView*>& views );
|
2015-08-30 06:30:46 -05:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
void scheduleCreateDisplayModelAndRedrawAllViews();
|
Added visualization of Well Paths in reservoir views.
Added PDM objects for a list of well paths (RimWellPathCollection) and for individual well paths (RimWellPath).
RimWellPathCollection uses RivWellPathCollectionPartMgr to generate visualization parts for each well path in the collection.
RimWellPath handles geometry defined in RigWellPath, and RivWellPathPartMgr is used to generate visualization parts. The well path visualization parts are generated by reusing RivPipeGeometryGenerator (also used for well pipes).
Added features:
- Select Open Well Paths in File menu to open one or more well path files, file format supported is Statoil JSON format.
- Each well path has a label showing the name, and the PDM window will show additional info (Id, Source System, UTM Zone, Update Date and User, Survey Type, File Path).
- Possible to turn on / off visibility, set thickness, set color for individual well paths.
- List of well paths including specified parameters/settings will be stored in project file.
- Possible to clip all well paths at a specified distance to the reservoir as this is the relevant area to see, and if showing whole well path it may be problematic for auto zoom etc.
Known problems:
- Well paths are not shown in some types of reservoir views, for instance reservoir views showing well pipes. Will look into this later.
p4#: 21658
2013-05-16 07:10:22 -05:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
void computeUtmAreaOfInterest();
|
2013-05-31 06:57:16 -05:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
void allOilFields( std::vector<RimOilField*>& allOilFields ) const;
|
|
|
|
RimOilField* activeOilField();
|
|
|
|
const RimOilField* activeOilField() const;
|
2013-02-14 06:16:56 -06:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
void actionsBasedOnSelection( QMenu& contextMenu );
|
2015-08-06 04:00:21 -05:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
bool show3DWindow() const;
|
|
|
|
bool showPlotWindow() const;
|
2016-10-04 07:23:34 -05:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
bool subWindowsTiled3DWindow() const;
|
|
|
|
bool subWindowsTiledPlotWindow() const;
|
2019-04-02 12:18:00 -05:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
void setSubWindowsTiledIn3DWindow( bool tiled );
|
|
|
|
void setSubWindowsTiledInPlotWindow( bool tiled );
|
2019-04-02 12:18:00 -05:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
void reloadCompletionTypeResultsInAllViews();
|
|
|
|
void reloadCompletionTypeResultsForEclipseCase( RimEclipseCase* eclipseCase );
|
2017-06-02 03:35:52 -05:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
RimDialogData* dialogData() const;
|
2017-10-11 06:52:29 -05:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
std::vector<RimEclipseCase*> eclipseCases() const;
|
|
|
|
RimEclipseCase* eclipseCaseFromGridFileName( const QString& gridFileName ) const;
|
2021-05-18 07:28:54 -05:00
|
|
|
RimEclipseCase* eclipseCaseFromCaseId( const int caseId ) const;
|
2018-04-13 04:11:05 -05:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
std::vector<QString> simulationWellNames() const;
|
2017-12-07 07:51:58 -06:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
RimWellPath* wellPathFromSimWellName( const QString& simWellName, int branchIndex = -1 );
|
|
|
|
RimWellPath* wellPathByName( const QString& wellPathName ) const;
|
|
|
|
std::vector<RimWellPath*> allWellPaths() const;
|
|
|
|
std::vector<RimTextAnnotation*> textAnnotations() const;
|
|
|
|
std::vector<RimReachCircleAnnotation*> reachCircleAnnotations() const;
|
|
|
|
std::vector<RimPolylinesAnnotation*> polylineAnnotations() const;
|
2017-05-31 09:16:28 -05:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
std::vector<RimGeoMechCase*> geoMechCases() const;
|
2017-10-20 09:10:45 -05:00
|
|
|
|
2017-12-20 06:14:43 -06:00
|
|
|
std::vector<RimFractureTemplateCollection*> allFractureTemplateCollections() const;
|
2018-12-13 12:49:37 -06:00
|
|
|
std::vector<RimFractureTemplate*> allFractureTemplates() const;
|
|
|
|
|
|
|
|
std::vector<RimValveTemplateCollection*> allValveTemplateCollections() const;
|
|
|
|
std::vector<RimValveTemplate*> allValveTemplates() const;
|
2017-12-20 06:14:43 -06:00
|
|
|
|
2021-01-21 05:58:46 -06:00
|
|
|
caf::AppEnum<RiaDefines::EclipseUnitSystem> commonUnitSystemForAllCases() const;
|
|
|
|
RimMeasurement* measurement() const;
|
2018-08-28 04:12:05 -05:00
|
|
|
|
2019-09-11 02:33:03 -05:00
|
|
|
RimPlotTemplateFolderItem* rootPlotTemlateItem() const;
|
|
|
|
|
2020-10-12 06:17:47 -05:00
|
|
|
std::vector<caf::FilePath*> allFilePaths() const;
|
|
|
|
|
2012-05-18 02:45:23 -05:00
|
|
|
protected:
|
|
|
|
// Overridden methods
|
2019-09-06 03:40:57 -05:00
|
|
|
void initAfterRead() override;
|
|
|
|
void setupBeforeSave() override;
|
2012-05-18 02:45:23 -05:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
void defineUiTreeOrdering( caf::PdmUiTreeOrdering& uiTreeOrdering, QString uiConfigName = "" ) override;
|
2015-08-06 08:55:17 -05:00
|
|
|
|
2018-01-19 05:52:50 -06:00
|
|
|
private:
|
|
|
|
template <typename T>
|
2020-10-12 06:17:47 -05:00
|
|
|
static void fieldContentsByType( const caf::PdmObjectHandle* object, std::vector<T*>& fieldContents );
|
2018-01-19 05:52:50 -06:00
|
|
|
|
2019-12-10 07:58:47 -06:00
|
|
|
void transferPathsToGlobalPathList();
|
|
|
|
void distributePathsFromGlobalPathList();
|
|
|
|
|
2012-05-18 02:45:23 -05:00
|
|
|
private:
|
2019-12-10 07:58:47 -06:00
|
|
|
caf::PdmField<QString> m_globalPathList;
|
2019-09-06 03:40:57 -05:00
|
|
|
caf::PdmField<QString> m_projectFileVersionString;
|
2017-06-30 09:14:15 -05:00
|
|
|
|
2019-09-11 02:33:03 -05:00
|
|
|
caf::PdmChildField<RimDialogData*> m_dialogData;
|
|
|
|
caf::PdmChildField<RimPlotTemplateFolderItem*> m_plotTemplateFolderItem;
|
2017-06-30 09:14:15 -05:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
caf::PdmField<bool> m_show3DWindow;
|
|
|
|
caf::PdmField<bool> m_showPlotWindow;
|
2015-05-08 07:13:26 -05:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
caf::PdmField<bool> m_subWindowsTiled3DWindow;
|
|
|
|
caf::PdmField<bool> m_subWindowsTiledPlotWindow;
|
2019-04-02 12:18:00 -05:00
|
|
|
|
2019-10-18 08:32:20 -05:00
|
|
|
int m_nextValidCaseId;
|
|
|
|
int m_nextValidCaseGroupId;
|
|
|
|
int m_nextValidViewId;
|
2019-11-14 13:48:11 -06:00
|
|
|
int m_nextValidPlotId;
|
2019-12-09 02:21:06 -06:00
|
|
|
int m_nextValidCalculationId;
|
2020-04-08 07:30:38 -05:00
|
|
|
int m_nextValidSummaryCaseId;
|
2020-04-08 09:17:47 -05:00
|
|
|
int m_nextValidEnsembleId;
|
2019-10-18 08:32:20 -05:00
|
|
|
|
2016-10-04 07:23:34 -05:00
|
|
|
caf::PdmChildArrayField<RimEclipseCase*> casesObsolete; // obsolete
|
|
|
|
caf::PdmChildArrayField<RimIdenticalGridCaseGroup*> caseGroupsObsolete; // obsolete
|
2012-05-18 02:45:23 -05:00
|
|
|
};
|
2018-01-19 05:52:50 -06:00
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
///
|
2018-01-19 05:52:50 -06:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
template <typename T>
|
2020-10-12 06:17:47 -05:00
|
|
|
void RimProject::fieldContentsByType( const caf::PdmObjectHandle* object, std::vector<T*>& fieldContents )
|
2018-01-19 05:52:50 -06:00
|
|
|
{
|
2019-09-06 03:40:57 -05:00
|
|
|
if ( !object ) return;
|
2018-01-19 05:52:50 -06:00
|
|
|
|
|
|
|
std::vector<caf::PdmFieldHandle*> allFieldsInObject;
|
2019-09-06 03:40:57 -05:00
|
|
|
object->fields( allFieldsInObject );
|
2018-01-19 05:52:50 -06:00
|
|
|
|
|
|
|
std::vector<caf::PdmObjectHandle*> children;
|
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
for ( const auto& field : allFieldsInObject )
|
2018-01-19 05:52:50 -06:00
|
|
|
{
|
2020-03-31 07:44:31 -05:00
|
|
|
auto xmlFieldCapability = field->xmlCapability();
|
|
|
|
if ( xmlFieldCapability && !xmlFieldCapability->isIOWritable() ) continue;
|
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
caf::PdmField<T>* typedField = dynamic_cast<caf::PdmField<T>*>( field );
|
2020-01-08 02:35:14 -06:00
|
|
|
if ( typedField ) fieldContents.push_back( &typedField->v() );
|
2018-01-19 05:52:50 -06:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
caf::PdmField<std::vector<T>>* typedFieldInVector = dynamic_cast<caf::PdmField<std::vector<T>>*>( field );
|
|
|
|
if ( typedFieldInVector )
|
2018-01-19 05:52:50 -06:00
|
|
|
{
|
2019-09-06 03:40:57 -05:00
|
|
|
for ( T& typedFieldFromVector : typedFieldInVector->v() )
|
2018-01-19 05:52:50 -06:00
|
|
|
{
|
2020-01-08 02:35:14 -06:00
|
|
|
fieldContents.push_back( &typedFieldFromVector );
|
2018-01-19 05:52:50 -06:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
field->childObjects( &children );
|
2018-01-19 05:52:50 -06:00
|
|
|
}
|
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
for ( const auto& child : children )
|
2018-01-19 05:52:50 -06:00
|
|
|
{
|
2020-01-08 02:35:14 -06:00
|
|
|
fieldContentsByType( child, fieldContents );
|
2018-01-19 05:52:50 -06:00
|
|
|
}
|
|
|
|
}
|