-// Copyright (C) 2007-2014 CEA/DEN, EDF R&D, OPEN CASCADE
+// Copyright (C) 2007-2023 CEA, EDF, OPEN CASCADE
//
// Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
// CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
#include "NETGENPlugin_Hypothesis.hxx"
#include "Utils_SALOME_Exception.hxx"
-// Parameters for work of NETGEN.
+class SMESH_Group;
+
+// Parameters of NETGEN.
// This class is just to give 2D dimension, actually
// it inherits all behaviour of the parent
{
public:
- NETGENPlugin_Hypothesis_2D(int hypId, int studyId, SMESH_Gen * gen);
-
- // void SetQuadAllowed(bool theVal);
- // bool GetQuadAllowed() const { return _quadAllowed; }
- // static bool GetDefaultQuadAllowed();
-
- // Persistence
- // virtual ostream & SaveTo(ostream & save);
- // virtual istream & LoadFrom(istream & load);
+ NETGENPlugin_Hypothesis_2D(int hypId, SMESH_Gen * gen);
// private:
// bool _quadAllowed;
};
+
+// Parameters of NETGEN remesher
+//
+
+class NETGENPLUGIN_EXPORT NETGENPlugin_RemesherHypothesis_2D: public NETGENPlugin_Hypothesis
+{
+ public:
+
+ NETGENPlugin_RemesherHypothesis_2D(int hypId, SMESH_Gen * gen);
+
+ void SetRidgeAngle( double angle );
+ double GetRidgeAngle() const{ return _ridgeAngle; }
+
+ void SetEdgeCornerAngle( double angle );
+ double GetEdgeCornerAngle() const { return _edgeCornerAngle; }
+
+ void SetChartAngle( double angle );
+ double GetChartAngle() const { return _chartAngle; }
+
+ void SetOuterChartAngle( double angle );
+ double GetOuterChartAngle() const { return _outerChartAngle; }
+
+ void SetRestHChartDistFactor( double f );
+ double GetRestHChartDistFactor() const { return _restHChartDistFactor; }
+
+ void SetRestHChartDistEnable( bool enable );
+ bool GetRestHChartDistEnable() const { return _restHChartDistEnable; }
+
+ void SetRestHLineLengthFactor( double f );
+ double GetRestHLineLengthFactor() const { return _restHLineLengthFactor; }
+
+ void SetRestHLineLengthEnable( bool enable );
+ bool GetRestHLineLengthEnable() const { return _restHLineLengthEnable; }
+
+ void SetRestHCloseEdgeFactor( double f );
+ double GetRestHCloseEdgeFactor() const { return _restHCloseEdgeFactor; }
+
+ void SetRestHCloseEdgeEnable( bool enable );
+ bool GetRestHCloseEdgeEnable() const { return _restHCloseEdgeEnable; }
+
+ void SetRestHSurfCurvFactor( double f );
+ double GetRestHSurfCurvFactor() const { return _restHSurfCurvFactor; }
+
+ void SetRestHSurfCurvEnable( bool enable );
+ bool GetRestHSurfCurvEnable() const { return _restHSurfCurvEnable; }
+
+ void SetRestHEdgeAngleFactor( double f );
+ double GetRestHEdgeAngleFactor() const { return _restHEdgeAngleFactor; }
+
+ void SetRestHEdgeAngleEnable( bool enable );
+ bool GetRestHEdgeAngleEnable() const { return _restHEdgeAngleEnable; }
+
+ void SetRestHSurfMeshCurvFactor( double f );
+ double GetRestHSurfMeshCurvFactor() const { return _restHSurfMeshCurvFactor; }
+
+ void SetRestHSurfMeshCurvEnable( bool enable );
+ bool GetRestHSurfMeshCurvEnable() const { return _restHSurfMeshCurvEnable; }
+
+ void SetKeepExistingEdges( bool toKeep );
+ bool GetKeepExistingEdges() const { return _keepExistingEdges; }
+
+ void SetMakeGroupsOfSurfaces( bool toMake );
+ bool GetMakeGroupsOfSurfaces() const { return _makeGroupsOfSurfaces; }
+
+ void SetFixedEdgeGroup( const SMESH_Group* edgeGroup );
+ int GetFixedEdgeGroupID() const { return _fixedEdgeGroupID; }
+ SMESH_Group* GetFixedEdgeGroup( const SMESH_Mesh& mesh ) const;
+
+ void SetLoadMeshOnCancel( bool toLoad );
+ bool GetLoadMeshOnCancel() const { return _loadOnCancel; }
+
+ static double DefaultRidgeAngle() { return 30.; }
+ static double DefaultEdgeCornerAngle() { return 60.; }
+ static double DefaultChartAngle() { return 15.; }
+ static double DefaultOuterChartAngle() { return 70.; }
+ static double DefaultRestHChartDistFactor() { return 1.2; }
+ static bool DefaultRestHChartDistEnable() { return true; }
+ static double DefaultRestHLineLengthFactor() { return 0.5; }
+ static bool DefaultRestHLineLengthEnable() { return true; }
+ static double DefaultRestHCloseEdgeFactor() { return 1.; }
+ static bool DefaultRestHCloseEdgeEnable() { return true; }
+ static double DefaultRestHSurfCurvFactor() { return 1.; }
+ static bool DefaultRestHSurfCurvEnable() { return false; }
+ static double DefaultRestHEdgeAngleFactor() { return 1.; }
+ static bool DefaultRestHEdgeAngleEnable() { return false; }
+ static double DefaultRestHSurfMeshCurvFactor() { return 1.; }
+ static bool DefaultRestHSurfMeshCurvEnable() { return false; }
+ static bool DefaultKeepExistingEdges() { return false; }
+ static bool DefaultMakeGroupsOfSurfaces() { return false; }
+
+ virtual std::ostream & SaveTo(std::ostream & save);
+ virtual std::istream & LoadFrom(std::istream & load);
+
+ private:
+
+ // STL charts
+ double _ridgeAngle; // yellow edges angle (in degrees)
+ double _edgeCornerAngle;
+ double _chartAngle;
+ double _outerChartAngle;
+
+ // Mesh size: restrict h due to ...
+ double _restHChartDistFactor; // chart distance
+ bool _restHChartDistEnable;
+ double _restHLineLengthFactor; // line length
+ bool _restHLineLengthEnable;
+ double _restHCloseEdgeFactor; // close edges
+ bool _restHCloseEdgeEnable;
+ double _restHSurfCurvFactor; // surface curvature
+ bool _restHSurfCurvEnable;
+ double _restHEdgeAngleFactor; // edge angle
+ bool _restHEdgeAngleEnable;
+ double _restHSurfMeshCurvFactor; // surface mesh curv
+ bool _restHSurfMeshCurvEnable;
+
+ // SALOME features
+ bool _keepExistingEdges;
+ bool _makeGroupsOfSurfaces;
+ int _fixedEdgeGroupID;
+ bool _loadOnCancel;
+
+};
+
#endif