///////////////////////////////////////////////////////////////////////////////// // // 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 RimWellPathGroup; class RifWellPathFormationsImporter; class RimWellMeasurementCollection; 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 }; typedef caf::AppEnum WellVisibilityEnum; 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, bool importGrouped, QStringList* errorMessages ); std::vector topLevelWellPaths() const; std::vector allWellPaths() const; void removeWellPath( gsl::not_null wellPath ); void deleteAllWellPaths(); void groupWellPaths( const std::vector& wellPaths, bool automaticGrouping = false ); void ungroupWellPaths( const std::vector& wellPaths ); RimWellPath* mostRecentlyUpdatedWellPath(); void readWellPathFormationFiles(); void reloadAllWellPathFormations(); RimWellPath* wellPathByName( const QString& wellPathName ) const; RimWellPath* tryFindMatchingWellPath( const QString& wellName ) const; void addWellPaths( const std::vector incomingWellPaths, bool importGrouped ); void addWellPath( gsl::not_null wellPath, bool importGrouped ); std::vector addWellLogs( const QStringList& filePaths, QStringList* errorMessages ); void addWellPathFormations( const QStringList& filePaths ); void scheduleRedrawAffectedViews(); void updateFilePathsFromProjectPath( const QString& newProjectPath, const QString& oldProjectPath ); bool anyWellsContainingPerforationIntervals() const; size_t modelledWellPathCount() const; RimWellMeasurementCollection* measurementCollection(); const RimWellMeasurementCollection* measurementCollection() const; void onChildDeleted( caf::PdmChildArrayFieldHandle* childArray, std::vector& referringObjects ) override; protected: void fieldChangedByUi( const caf::PdmFieldHandle* changedField, const QVariant& oldValue, const QVariant& newValue ) override; std::vector detachWellPaths( const std::vector wellPathsToDetach ); bool detachWellPath( gsl::not_null wellPath ); 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, bool importGrouped ); void sortWellsByName(); std::vector topLevelGroups() const; RimWellPathGroup* findOrCreateWellPathGroup( gsl::not_null wellPath, const std::vector& wellPathsToGroupWith ); caf::AppEnum findUnitSystemForWellPath( const RimWellPath* wellPath ); std::unique_ptr m_wellPathImporter; std::unique_ptr m_wellPathFormationsImporter; caf::PdmPointer m_mostRecentlyUpdatedWellPath; caf::PdmChildField m_wellMeasurements; caf::PdmChildArrayField m_wellPaths; };