///////////////////////////////////////////////////////////////////////////////// // // Copyright (C) 2011- Statoil ASA // Copyright (C) 2013- Ceetron Solutions AS // Copyright (C) 2011-2012 Ceetron AS // // 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. // ///////////////////////////////////////////////////////////////////////////////// #pragma once #include "RiaDefines.h" #include "cafAppEnum.h" #include "cafPdmChildArrayField.h" #include "cafPdmField.h" #include "cafPdmObject.h" #include "cafPdmPointer.h" // Include to make Pdm work for cvf::Color #include "cafPdmChildField.h" #include "cafPdmFieldCvfColor.h" #include "cvfObject.h" #include #include class RifWellPathImporter; class RigWellPath; class RimFileWellPath; class RimEclipseView; class RimProject; class RimWellLogFile; class RimWellPath; class RifWellPathFormationsImporter; class RimWellMeasurementCollection; class cafTreeNode; class QString; namespace cvf { class ModelBasicList; class BoundingBox; } // namespace cvf namespace caf { class DisplayCoordTransform; } //================================================================================================== /// /// //================================================================================================== class RimWellPathCollection : public caf::PdmObject { CAF_PDM_HEADER_INIT; public: RimWellPathCollection(); ~RimWellPathCollection() override; enum WellVisibilityType { FORCE_ALL_OFF, ALL_ON, FORCE_ALL_ON }; using WellVisibilityEnum = caf::AppEnum; caf::PdmField isActive; caf::PdmField showWellPathLabel; caf::PdmField wellPathLabelColor; caf::PdmField wellPathVisibility; caf::PdmField wellPathRadiusScaleFactor; caf::PdmField wellPathCrossSectionVertexCount; caf::PdmField wellPathClip; caf::PdmField wellPathClipZDistance; void loadDataAndUpdate(); std::vector addWellPaths( QStringList filePaths, QStringList* errorMessages ); std::vector allWellPaths() const; void removeWellPath( gsl::not_null wellPath ); void deleteAllWellPaths(); void deleteWell( RimWellPath* wellPath ); void groupWellPaths( const std::vector& wellPaths ); void rebuildWellPathNodes(); std::vector connectedWellPathLaterals( const RimWellPath* parentWellPath ) const; RimWellPath* mostRecentlyUpdatedWellPath(); void readWellPathFormationFiles(); void reloadAllWellPathFormations(); RimWellPath* wellPathByName( const QString& wellPathName ) const; RimWellPath* tryFindMatchingWellPath( const QString& wellName ) const; void addWellPaths( const std::vector incomingWellPaths ); void addWellPath( gsl::not_null wellPath ); std::vector addWellLogs( const QStringList& filePaths, QStringList* errorMessages ); void addWellPathFormations( const QStringList& filePaths ); void scheduleRedrawAffectedViews(); bool anyWellsContainingPerforationIntervals() const; size_t modelledWellPathCount() const; RimWellMeasurementCollection* measurementCollection(); const RimWellMeasurementCollection* measurementCollection() const; void onChildDeleted( caf::PdmChildArrayFieldHandle* childArray, std::vector& referringObjects ) override; void onChildAdded( caf::PdmFieldHandle* containerForNewObject ) override; protected: void fieldChangedByUi( const caf::PdmFieldHandle* changedField, const QVariant& oldValue, const QVariant& newValue ) override; private: void defineUiOrdering( QString uiConfigName, caf::PdmUiOrdering& uiOrdering ) override; void defineUiTreeOrdering( caf::PdmUiTreeOrdering& uiTreeOrdering, QString uiConfigName ) override; caf::PdmFieldHandle* objectToggleField() override; void readAndAddWellPaths( std::vector& wellPathArray ); void sortWellsByName(); caf::AppEnum findUnitSystemForWellPath( const RimWellPath* wellPath ); cafTreeNode* addWellToWellNode( cafTreeNode* parent, RimWellPath* wellPath ); std::vector wellPathsWithNoParent( const std::vector& sourceWellPaths ) const; std::map> wellPathsForWellNameStem( const std::vector& sourceWellPaths ) const; static void buildUiTreeOrdering( cafTreeNode* treeNode, caf::PdmUiTreeOrdering* parentUiTreeNode, const QString& uiConfigName ); static QString unGroupedText(); private: std::unique_ptr m_wellPathImporter; std::unique_ptr m_wellPathFormationsImporter; caf::PdmPointer m_mostRecentlyUpdatedWellPath; caf::PdmChildField m_wellMeasurements; caf::PdmChildArrayField m_wellPaths; caf::PdmChildArrayField m_wellPathNodes; };