Version: 9.12.0
StdMeshers_RadialQuadrangle_1D2D.hxx
Go to the documentation of this file.
1 // Copyright (C) 2007-2023 CEA, EDF, OPEN CASCADE
2 //
3 // This library is free software; you can redistribute it and/or
4 // modify it under the terms of the GNU Lesser General Public
5 // License as published by the Free Software Foundation; either
6 // version 2.1 of the License, or (at your option) any later version.
7 //
8 // This library is distributed in the hope that it will be useful,
9 // but WITHOUT ANY WARRANTY; without even the implied warranty of
10 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
11 // Lesser General Public License for more details.
12 //
13 // You should have received a copy of the GNU Lesser General Public
14 // License along with this library; if not, write to the Free Software
15 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
16 //
17 // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
18 //
19 
20 // SMESH SMESH : implementation of SMESH idl descriptions
21 // File : StdMeshers_RadialQuadrangle_1D2D.hxx
22 // Module : SMESH
23 //
24 #ifndef _SMESH_RadialQuadrangle_1D2D_HXX_
25 #define _SMESH_RadialQuadrangle_1D2D_HXX_
26 
28 
29 #include <vector>
30 
33 
40 {
41 public:
44 
45  virtual bool CheckHypothesis(SMESH_Mesh& aMesh,
46  const TopoDS_Shape& aShape,
48 
49  virtual bool Compute(SMESH_Mesh& aMesh, const TopoDS_Shape& aShape);
50 
51  virtual bool Evaluate(SMESH_Mesh & aMesh, const TopoDS_Shape & aShape,
52  MapShapeNbElems& aResMap);
53 
54  // Allow algo to do something after persistent restoration
55  virtual void SubmeshRestored(SMESH_subMesh* subMesh);
56 
57  // Sets event listener to a submesh
58  virtual void SetEventListener(SMESH_subMesh* subMesh);
59 
60  virtual bool IsApplicableToShape(const TopoDS_Shape & shape, bool toCheckAll) const
61  {
62  return IsApplicable( shape, toCheckAll );
63  }
64  static bool IsApplicable(const TopoDS_Shape & aShape, bool toCheckAll);
65 
66  protected:
67 
68  int computeLayerPositions(StdMeshers_FaceSidePtr linSide,
69  std::vector< double >& positions,
70  int* nbEdgesComputed = 0,
71  bool useHalf = false);
72 
73 
76 };
77 
78 #endif
std::map< SMESH_subMesh *, std::vector< smIdType > > MapShapeNbElems
Definition: SMESH_Algo.hxx:61
#define STDMESHERS_EXPORT
Definition: SMESH_StdMeshers.hxx:38
boost::shared_ptr< StdMeshers_FaceSide > StdMeshers_FaceSidePtr
Definition: StdMeshers_FaceSide.hxx:56
virtual void SetEventListener(SMESH_subMesh *subMesh)
Sets event listener to submeshes if necessary.
Definition: SMESH_Algo.cxx:825
virtual void SubmeshRestored(SMESH_subMesh *subMesh)
Allow algo to do something after persistent restoration.
Definition: SMESH_Algo.cxx:838
Definition: SMESH_Gen.hxx:68
Hypothesis_Status
Definition: SMESH_Hypothesis.hxx:51
Definition: SMESH_Mesh.hxx:80
Definition: SMESH_subMesh.hxx:61
This hypothesis is used by "Radial prism" algorithm.
Definition: StdMeshers_LayerDistribution.hxx:51
This hypothesis is used by "Radial prism" algorithm.
Definition: StdMeshers_NumberOfLayers.hxx:49
Definition: StdMeshers_Quadrangle_2D.hxx:136
static bool IsApplicable(const TopoDS_Shape &aShape, bool toCheckAll)
Return true if the algorithm can mesh this shape.
Definition: StdMeshers_Quadrangle_2D.cxx:1005
virtual bool Evaluate(SMESH_Mesh &aMesh, const TopoDS_Shape &aShape, MapShapeNbElems &aResMap)
Evaluate.
Definition: StdMeshers_Quadrangle_2D.cxx:910
virtual bool CheckHypothesis(SMESH_Mesh &aMesh, const TopoDS_Shape &aShape, Hypothesis_Status &aStatus)
Check hypothesis definition to mesh a shape.
Definition: StdMeshers_Quadrangle_2D.cxx:121
virtual bool Compute(SMESH_Mesh &aMesh, const TopoDS_Shape &aShape)
Compute the mesh on the given shape.
Definition: StdMeshers_Quadrangle_2D.cxx:211
Algorithm generating quadrangles on a full or a part of an elliptic face.
Definition: StdMeshers_RadialQuadrangle_1D2D.hxx:40
const StdMeshers_LayerDistribution * myDistributionHypo
Definition: StdMeshers_RadialQuadrangle_1D2D.hxx:75
virtual bool IsApplicableToShape(const TopoDS_Shape &shape, bool toCheckAll) const
Return true if the algorithm can mesh a given shape.
Definition: StdMeshers_RadialQuadrangle_1D2D.hxx:60
const StdMeshers_NumberOfLayers * myNbLayerHypo
Definition: StdMeshers_RadialQuadrangle_1D2D.hxx:74