2003-07-10 16:13:42 +06:00
|
|
|
// SMESH SMESHDS : management of mesh data and SMESH document
|
2003-05-19 19:25:06 +06:00
|
|
|
//
|
2003-07-10 16:13:42 +06:00
|
|
|
// Copyright (C) 2003 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
|
|
|
|
// CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
|
|
|
|
//
|
|
|
|
// This library is free software; you can redistribute it and/or
|
|
|
|
// modify it under the terms of the GNU Lesser General Public
|
|
|
|
// License as published by the Free Software Foundation; either
|
|
|
|
// version 2.1 of the License.
|
|
|
|
//
|
|
|
|
// This library 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
|
|
|
|
// Lesser General Public License for more details.
|
|
|
|
//
|
|
|
|
// You should have received a copy of the GNU Lesser General Public
|
|
|
|
// License along with this library; if not, write to the Free Software
|
|
|
|
// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
|
|
//
|
2006-06-01 17:39:17 +06:00
|
|
|
// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
|
2003-05-19 19:25:06 +06:00
|
|
|
//
|
2003-07-10 16:13:42 +06:00
|
|
|
//
|
|
|
|
//
|
|
|
|
// File : SMESHDS_Command.hxx
|
|
|
|
// Module : SMESH
|
|
|
|
|
2003-05-19 19:25:06 +06:00
|
|
|
#ifndef _SMESHDS_Command_HeaderFile
|
|
|
|
#define _SMESHDS_Command_HeaderFile
|
|
|
|
|
|
|
|
#include "SMESHDS_CommandType.hxx"
|
2003-09-04 13:14:51 +06:00
|
|
|
#include <list>
|
2005-06-07 19:22:20 +06:00
|
|
|
#include <vector>
|
2003-09-04 13:14:51 +06:00
|
|
|
|
|
|
|
class SMESHDS_Command
|
|
|
|
{
|
|
|
|
|
|
|
|
public:
|
|
|
|
SMESHDS_Command(const SMESHDS_CommandType aType);
|
|
|
|
void AddNode(int NewNodeID, double x, double y, double z);
|
|
|
|
void AddEdge(int NewEdgeID, int idnode1, int idnode2);
|
|
|
|
void AddFace(int NewFaceID, int idnode1, int idnode2, int idnode3);
|
|
|
|
void AddFace(int NewFaceID, int idnode1, int idnode2, int idnode3,
|
|
|
|
int idnode4);
|
|
|
|
void AddVolume(int NewVolID, int idnode1, int idnode2, int idnode3,
|
|
|
|
int idnode4);
|
|
|
|
void AddVolume(int NewVolID, int idnode1, int idnode2, int idnode3,
|
|
|
|
int idnode4, int idnode5);
|
|
|
|
void AddVolume(int NewVolID, int idnode1, int idnode2, int idnode3,
|
|
|
|
int idnode4, int idnode5, int idnode6);
|
|
|
|
void AddVolume(int NewVolID, int idnode1, int idnode2, int idnode3,
|
|
|
|
int idnode4, int idnode5, int idnode6, int idnode7, int idnode8);
|
2005-06-07 19:22:20 +06:00
|
|
|
void AddPolygonalFace (const int ElementID,
|
|
|
|
std::vector<int> nodes_ids);
|
|
|
|
void AddPolyhedralVolume (const int ElementID,
|
|
|
|
std::vector<int> nodes_ids,
|
|
|
|
std::vector<int> quantities);
|
2006-03-13 20:29:49 +05:00
|
|
|
// special methods for quadratic elements
|
|
|
|
void AddEdge(int NewEdgeID, int n1, int n2, int n12);
|
|
|
|
void AddFace(int NewFaceID, int n1, int n2, int n3,
|
|
|
|
int n12, int n23, int n31);
|
|
|
|
void AddFace(int NewFaceID, int n1, int n2, int n3, int n4,
|
|
|
|
int n12, int n23, int n34, int n41);
|
|
|
|
void AddVolume(int NewVolID, int n1, int n2, int n3, int n4,
|
|
|
|
int n12, int n23, int n31, int n14, int n24, int n34);
|
|
|
|
void AddVolume(int NewVolID, int n1, int n2, int n3, int n4, int n5,
|
|
|
|
int n12, int n23, int n34, int n41,
|
|
|
|
int n15, int n25, int n35, int n45);
|
|
|
|
void AddVolume(int NewVolID, int n1, int n2, int n3,
|
|
|
|
int n4, int n5, int n6,
|
|
|
|
int n12, int n23, int n31,
|
|
|
|
int n45, int n56, int n64,
|
|
|
|
int n14, int n25, int n36);
|
|
|
|
void AddVolume(int NewVolID, int n1, int n2, int n3, int n4,
|
|
|
|
int n5, int n6, int n7, int n8,
|
|
|
|
int n12, int n23, int n34, int n41,
|
|
|
|
int n56, int n67, int n78, int n85,
|
|
|
|
int n15, int n26, int n37, int n48);
|
|
|
|
|
2003-09-04 13:14:51 +06:00
|
|
|
void MoveNode(int NewNodeID, double x, double y, double z);
|
|
|
|
void RemoveNode(int NodeID);
|
|
|
|
void RemoveElement(int ElementID);
|
2004-12-01 15:48:31 +05:00
|
|
|
void ChangeElementNodes(int ElementID, int nodes[], int nbnodes);
|
2005-06-07 19:22:20 +06:00
|
|
|
void ChangePolyhedronNodes(const int ElementID,
|
|
|
|
std::vector<int> nodes_ids,
|
|
|
|
std::vector<int> quantities);
|
2004-12-01 15:48:31 +05:00
|
|
|
void Renumber (const bool isNodes, const int startID, const int deltaID);
|
2003-09-04 13:14:51 +06:00
|
|
|
SMESHDS_CommandType GetType();
|
|
|
|
int GetNumber();
|
2004-12-01 15:48:31 +05:00
|
|
|
const std::list<int> & GetIndexes();
|
|
|
|
const std::list<double> & GetCoords();
|
2003-09-04 13:14:51 +06:00
|
|
|
~SMESHDS_Command();
|
|
|
|
private:
|
|
|
|
SMESHDS_CommandType myType;
|
|
|
|
int myNumber;
|
2004-12-01 15:48:31 +05:00
|
|
|
std::list<double> myReals;
|
|
|
|
std::list<int> myIntegers;
|
2003-05-19 19:25:06 +06:00
|
|
|
};
|
|
|
|
#endif
|