///////////////////////////////////////////////////////////////////////////////// // // 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 "RiaEclipseUnitTools.h" #include "Rim3dWellLogCurve.h" #include "cafPdmField.h" #include "cafPdmObject.h" #include "cafPdmPointer.h" #include "cafPdmChildField.h" #include "cafAppEnum.h" // Include to make Pdm work for cvf::Color #include "cafPdmFieldCvfColor.h" #include "cafPdmChildArrayField.h" #include "cvfObject.h" #include class RifWellPathImporter; class RifWellPathFormationsImporter; class RigWellPath; class RimProject; class RimWellLogFile; class RimFractureTemplateCollection; class RimFishboneWellPathCollection; class RimFishbonesCollection; class RimPerforationCollection; class RimWellPathCompletions; class RigWellPathFormations; class RimWellPathFractureCollection; class Rim3dWellLogCurveCollection; //================================================================================================== /// /// //================================================================================================== class RimWellPath : public caf::PdmObject { CAF_PDM_HEADER_INIT; static const char SIM_WELL_NONE_UI_TEXT[]; public: RimWellPath(); virtual ~RimWellPath(); void addWellLogFile(RimWellLogFile* logFileInfo); void deleteWellLogFile(RimWellLogFile* logFileInfo); void detachWellLogFile(RimWellLogFile* logFileInfo); void setFormationsGeometry(cvf::ref wellPathFormations); bool readWellPathFormationsFile(QString* errorMessage, RifWellPathFormationsImporter* wellPathFormationsImporter); bool reloadWellPathFormationsFile(QString* errorMessage, RifWellPathFormationsImporter* wellPathFormationsImporter); bool hasFormations() const; const RigWellPathFormations* formationsGeometry() const; void add3dWellLogCurve(Rim3dWellLogCurve* rim3dWellLogCurve); Rim3dWellLogCurveCollection* rim3dWellLogCurveCollection() const; virtual caf::PdmFieldHandle* userDescriptionField() override; virtual caf::PdmFieldHandle* objectToggleField() override; virtual void fieldChangedByUi( const caf::PdmFieldHandle* changedField, const QVariant& oldValue, const QVariant& newValue ) override; virtual QList calculateValueOptions(const caf::PdmFieldHandle* fieldNeedingOptions, bool * useOptionsOnly) override; virtual void initAfterRead() override; QString name() const; void setName(const QString& name); std::vector wellLogFiles() const; caf::PdmField filepath; caf::PdmField wellPathIndexInFile; // -1 means none. caf::PdmField m_simWellName; caf::PdmField m_branchIndex; caf::PdmField showWellPathLabel; caf::PdmField showWellPath; caf::PdmField wellPathColor; double wellPathRadius(double characteristicCellSize) const; caf::PdmField wellPathRadiusScaleFactor; RimFishbonesCollection* fishbonesCollection(); const RimFishbonesCollection* fishbonesCollection() const; RimPerforationCollection* perforationIntervalCollection(); const RimPerforationCollection* perforationIntervalCollection() const; const RimWellPathCompletions* completions() const; RimWellPathFractureCollection* fractureCollection(); const RimWellPathFractureCollection* fractureCollection() const; RigWellPath* wellPathGeometry(); const RigWellPath* wellPathGeometry() const; bool readWellPathFile(QString * errorMessage, RifWellPathImporter* wellPathImporter); void updateFilePathsFromProjectPath(const QString& newProjectPath, const QString& oldProjectPath); double combinedScaleFactor() const; void setUnitSystem(RiaEclipseUnitTools::UnitSystem unitSystem); RiaEclipseUnitTools::UnitSystem unitSystem() const; static RimWellPath* fromFilePath(QString filePath); const QString associatedSimulationWellName() const; int associatedSimulationWellBranch() const; bool tryAssociateWithSimulationWell(); bool isAssociatedWithSimulationWell() const; bool tryMatchName(QString wellPathName, const std::vector& simWellNames, std::function stringFormatter = nullptr); private: void setWellPathGeometry(RigWellPath* wellPathModel); QString surveyType() { return m_surveyType; } void setSurveyType(QString surveyType); virtual void defineUiOrdering( QString uiConfigName, caf::PdmUiOrdering& uiOrdering ) override; virtual void defineUiTreeOrdering(caf::PdmUiTreeOrdering& uiTreeOrdering, QString uiConfigName) override; bool isStoredInCache(); QString getCacheFileName(); QString getCacheDirectoryPath(); virtual void setupBeforeSave() override; static size_t simulationWellBranchCount(const QString& simWellName); private: caf::PdmField id; caf::PdmField sourceSystem; caf::PdmField utmZone; caf::PdmField updateDate; caf::PdmField updateUser; caf::PdmField m_surveyType; caf::PdmField m_datumElevation; caf::PdmField m_unitSystem; caf::PdmChildField m_completions; cvf::ref m_wellPath; cvf::ref m_wellPathFormations; caf::PdmField m_name; caf::PdmField m_wellPathFormationFilePath; caf::PdmField m_formationKeyInFile; caf::PdmChildArrayField m_wellLogFiles; caf::PdmChildField m_3dWellLogCurves; caf::PdmChildField m_wellLogFile_OBSOLETE; };