Salome HOME
Integration of PAL/SALOME V2.1.0c from OCC
[modules/smesh.git] / src / SMESH_I / SMESH_MeshEditor_i.hxx
index 0c75c7de0032a50274327fefb11572e986f8bbc4..ec9b2afd1c09896a7860f538dc27cb8c5a0718cf 100644 (file)
 #include <SALOMEconfig.h>
 #include CORBA_SERVER_HEADER(SMESH_Mesh)
 
-#include "SMESHDS_Mesh.hxx"
+#include "SMESH_Mesh.hxx"
 
 class SMESH_MeshEditor_i: public POA_SMESH::SMESH_MeshEditor
 {
 public:
-       SMESH_MeshEditor_i(SMESHDS_Mesh * theMesh);
+ public:
+  SMESH_MeshEditor_i(SMESH_Mesh * theMesh);
 
-       virtual ~ SMESH_MeshEditor_i()
-       {
-       };
+  virtual ~ SMESH_MeshEditor_i()
+  {
+  };
 
-       // --- CORBA
-       CORBA::Boolean RemoveElements(const SMESH::long_array & IDsOfElements);
-       CORBA::Boolean RemoveNodes(const SMESH::long_array & IDsOfNodes);
+  // --- CORBA
+  CORBA::Boolean RemoveElements(const SMESH::long_array & IDsOfElements);
+  CORBA::Boolean RemoveNodes(const SMESH::long_array & IDsOfNodes);
 
-       CORBA::Boolean AddNode(CORBA::Double x, CORBA::Double y, CORBA::Double z);
-       CORBA::Boolean AddEdge(const SMESH::long_array & IDsOfNodes);
-       CORBA::Boolean AddFace(const SMESH::long_array & IDsOfNodes);
-       CORBA::Boolean AddVolume(const SMESH::long_array & IDsOfNodes);
+  CORBA::Boolean AddNode(CORBA::Double x, CORBA::Double y, CORBA::Double z);
+  CORBA::Boolean AddEdge(const SMESH::long_array & IDsOfNodes);
+  CORBA::Boolean AddFace(const SMESH::long_array & IDsOfNodes);
+  CORBA::Boolean AddVolume(const SMESH::long_array & IDsOfNodes);
+  CORBA::Boolean MoveNode(CORBA::Long NodeID,
+                          CORBA::Double x, CORBA::Double y, CORBA::Double z);
 
-  private:
-       SMESH::SMESH_subMesh_var _myMesh;
-       SMESHDS_Mesh *_myMeshDS;
+  CORBA::Boolean InverseDiag(CORBA::Long NodeID1, CORBA::Long NodeID2);
+  CORBA::Boolean DeleteDiag(CORBA::Long NodeID1, CORBA::Long NodeID2);
+  CORBA::Boolean Reorient(const SMESH::long_array & IDsOfElements);
+
+  CORBA::Boolean TriToQuad(const SMESH::long_array &   IDsOfElements,
+                           SMESH::NumericalFunctor_ptr Criterion,
+                           CORBA::Double               MaxAngle);
+  CORBA::Boolean QuadToTri(const SMESH::long_array &   IDsOfElements,
+                           SMESH::NumericalFunctor_ptr Criterion);
+  CORBA::Boolean SplitQuad(const SMESH::long_array & IDsOfElements,
+                           CORBA::Boolean            Diag13);
+
+  CORBA::Boolean Smooth(const SMESH::long_array &              IDsOfElements,
+                        const SMESH::long_array &              IDsOfFixedNodes,
+                        CORBA::Long                            MaxNbOfIterations,
+                        CORBA::Double                          MaxAspectRatio,
+                        SMESH::SMESH_MeshEditor::Smooth_Method Method);
+
+  void RenumberNodes();
+  void RenumberElements();
+
+  void RotationSweep(const SMESH::long_array & IDsOfElements,
+                     const SMESH::AxisStruct &  Axis,
+                     CORBA::Double             AngleInRadians,
+                     CORBA::Long               NbOfSteps,
+                     CORBA::Double             Tolerance);
+  void ExtrusionSweep(const SMESH::long_array & IDsOfElements,
+                      const SMESH::DirStruct &   StepVector,
+                      CORBA::Long               NbOfSteps);
+
+  void Mirror(const SMESH::long_array &           IDsOfElements,
+              const SMESH::AxisStruct &            Axis,
+              SMESH::SMESH_MeshEditor::MirrorType MirrorType,
+              CORBA::Boolean                      Copy);
+  void Translate(const SMESH::long_array & IDsOfElements,
+                 const SMESH::DirStruct &   Vector,
+                 CORBA::Boolean            Copy);
+  void Rotate(const SMESH::long_array & IDsOfElements,
+              const SMESH::AxisStruct &  Axis,
+              CORBA::Double             Angle,
+              CORBA::Boolean            Copy);
+
+  void FindCoincidentNodes (CORBA::Double                  Tolerance,
+                            SMESH::array_of_long_array_out GroupsOfNodes);
+  void MergeNodes (const SMESH::array_of_long_array& GroupsOfNodes);
+  void MergeEqualElements();
+
+  CORBA::Boolean SewFreeBorders(CORBA::Long FirstNodeID1,
+                                CORBA::Long SecondNodeID1,
+                                CORBA::Long LastNodeID1,
+                                CORBA::Long FirstNodeID2,
+                                CORBA::Long SecondNodeID2,
+                                CORBA::Long LastNodeID2);
+  CORBA::Boolean SewConformFreeBorders(CORBA::Long FirstNodeID1,
+                                       CORBA::Long SecondNodeID1,
+                                       CORBA::Long LastNodeID1,
+                                       CORBA::Long FirstNodeID2,
+                                       CORBA::Long SecondNodeID2);
+  CORBA::Boolean SewBorderToSide(CORBA::Long FirstNodeIDOnFreeBorder,
+                                 CORBA::Long SecondNodeIDOnFreeBorder,
+                                 CORBA::Long LastNodeIDOnFreeBorder,
+                                 CORBA::Long FirstNodeIDOnSide,
+                                 CORBA::Long LastNodeIDOnSide);
+  CORBA::Boolean SewSideElements(const SMESH::long_array& IDsOfSide1Elements,
+                                 const SMESH::long_array& IDsOfSide2Elements,
+                                 CORBA::Long NodeID1OfSide1ToMerge,
+                                 CORBA::Long NodeID1OfSide2ToMerge,
+                                 CORBA::Long NodeID2OfSide1ToMerge,
+                                 CORBA::Long NodeID2OfSide2ToMerge);
+
+ private:
+  SMESHDS_Mesh * GetMeshDS() { return _myMesh->GetMeshDS(); }
+  SMESH_Mesh   *_myMesh;
 };
 
 #endif