///////////////////////////////////////////////////////////////////////////////// // // Copyright (C) 2015- Statoil ASA // Copyright (C) 2015- Ceetron Solutions 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 "cafPdmPtrField.h" #include "cafPdmField.h" #include "cafPdmObject.h" #include "cafPdmChildField.h" #include "cafPdmChildArrayField.h" #include "cvfBase.h" #include "cvfVector3.h" #include class Rim3dView; class RimGridView; class RimFormationNames; class RimTimeStepFilter; class Rim2dIntersectionView; class RimIntersection; class Rim2dIntersectionViewCollection; namespace cvf { class BoundingBox; } class RimCase : public caf::PdmObject { CAF_PDM_HEADER_INIT; public: RimCase(); virtual ~RimCase(); caf::PdmField caseId; caf::PdmField caseUserDescription; caf::PdmPtrField activeFormationNames; std::vector views() const; std::vector gridViews() const; virtual void updateFilePathsFromProjectPath(const QString& projectPath, const QString& oldProjectPath) = 0; virtual std::vector timeStepDates() const = 0; virtual QStringList timeStepStrings() const = 0; virtual QString timeStepName(int frameIdx) const = 0; virtual cvf::BoundingBox activeCellsBoundingBox() const = 0; virtual cvf::BoundingBox allCellsBoundingBox() const = 0; virtual cvf::Vec3d displayModelOffset() const; virtual void updateFormationNamesData() = 0; virtual void setFormationNames(RimFormationNames* formationNames); virtual double characteristicCellSize() const = 0; size_t uiToNativeTimeStepIndex(size_t uiTimeStepIndex); Rim2dIntersectionViewCollection* intersectionViewCollection(); protected: virtual QList calculateValueOptions(const caf::PdmFieldHandle* fieldNeedingOptions, bool * useOptionsOnly) override; virtual std::vector allSpecialViews() const = 0; private: virtual caf::PdmFieldHandle* userDescriptionField() override { return &caseUserDescription; } protected: caf::PdmChildField m_timeStepFilter; caf::PdmChildField m_2dIntersectionViewCollection; private: bool m_isInActiveDestruction; };