///////////////////////////////////////////////////////////////////////////////// // // Copyright (C) 2016- Statoil ASA // // 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 "cafPdmChildArrayField.h" #include "cafPdmField.h" #include "cafPdmObject.h" class RimEllipseFractureTemplate; class RimFractureTemplate; //================================================================================================== /// /// //================================================================================================== class RimFractureTemplateCollection : public caf::PdmObject { CAF_PDM_HEADER_INIT; public: RimFractureTemplateCollection(); ~RimFractureTemplateCollection() override; RimFractureTemplate* fractureTemplate( int id ) const; std::vector fractureTemplates() const; RimEllipseFractureTemplate* addDefaultEllipseTemplate(); void addFractureTemplate( RimFractureTemplate* templ ); RiaEclipseUnitTools::UnitSystemType defaultUnitSystemType() const; void setDefaultUnitSystemBasedOnLoadedCases(); RimFractureTemplate* firstFractureOfUnit( RiaEclipseUnitTools::UnitSystem unitSet ) const; std::vector> resultNamesAndUnits() const; void computeMinMax( const QString& uiResultName, const QString& unit, double* minValue, double* maxValue, double* posClosestToZero, double* negClosestToZero ) const; void createAndAssignTemplateCopyForNonMatchingUnit(); void loadAndUpdateData(); void updateFilePathsFromProjectPath( const QString& newProjectPath, const QString& oldProjectPath ); void onChildDeleted( caf::PdmChildArrayFieldHandle* childArray, std::vector& referringObjects ) override; protected: void initAfterRead() override; private: int nextFractureTemplateId(); caf::PdmChildArrayField m_fractureDefinitions; caf::PdmField m_defaultUnitsForFracTemplates; caf::PdmField m_nextValidFractureTemplateId; // Unique fracture template ID within a project, used to identify // a fracture template };