2015-02-13 13:38:35 +05:00
|
|
|
// Copyright (C) 2007-2015 CEA/DEN, EDF R&D, OPEN CASCADE
|
2009-02-17 10:27:49 +05:00
|
|
|
//
|
2012-08-09 16:03:55 +06:00
|
|
|
// Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
|
|
|
|
// CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
|
2009-02-17 10:27:49 +05:00
|
|
|
//
|
2012-08-09 16:03:55 +06:00
|
|
|
// 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
|
2014-02-20 18:25:37 +06:00
|
|
|
// version 2.1 of the License, or (at your option) any later version.
|
2003-05-19 19:25:06 +06:00
|
|
|
//
|
2012-08-09 16:03:55 +06:00
|
|
|
// 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.
|
2003-05-19 19:25:06 +06:00
|
|
|
//
|
2012-08-09 16:03:55 +06:00
|
|
|
// 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
|
2003-07-10 16:13:42 +06:00
|
|
|
//
|
2012-08-09 16:03:55 +06:00
|
|
|
// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
|
2003-07-10 16:13:42 +06:00
|
|
|
//
|
2012-08-09 16:03:55 +06:00
|
|
|
|
2009-02-17 10:27:49 +05:00
|
|
|
// SMESH SMESHDS : management of mesh data and SMESH document
|
2003-07-10 16:13:42 +06:00
|
|
|
// File : SMESHDS_Script.hxx
|
|
|
|
// Module : SMESH
|
2009-02-17 10:27:49 +05:00
|
|
|
//
|
2003-05-19 19:25:06 +06:00
|
|
|
#ifndef _SMESHDS_Script_HeaderFile
|
|
|
|
#define _SMESHDS_Script_HeaderFile
|
|
|
|
|
2008-03-07 12:47:05 +05:00
|
|
|
#include "SMESH_SMESHDS.hxx"
|
|
|
|
|
2003-09-04 13:14:51 +06:00
|
|
|
#include "SMESHDS_Command.hxx"
|
2004-12-01 15:48:31 +05:00
|
|
|
|
2003-09-04 13:14:51 +06:00
|
|
|
#include <list>
|
2005-06-07 19:22:20 +06:00
|
|
|
#include <vector>
|
2004-12-01 15:48:31 +05:00
|
|
|
|
2003-09-04 13:14:51 +06:00
|
|
|
|
2008-03-07 12:47:05 +05:00
|
|
|
class SMESHDS_EXPORT SMESHDS_Script
|
2003-09-04 13:14:51 +06:00
|
|
|
{
|
|
|
|
public:
|
2012-08-09 16:03:55 +06:00
|
|
|
SMESHDS_Script(bool theIsEmbeddedMode);
|
|
|
|
~SMESHDS_Script();
|
2006-03-13 20:29:49 +05:00
|
|
|
|
|
|
|
void SetModified(bool theModified);
|
|
|
|
bool IsModified();
|
|
|
|
|
2012-08-09 16:03:55 +06:00
|
|
|
void AddNode(int NewNodeID, double x, double y, double z);
|
|
|
|
void Add0DElement(int New0DElementID, int idnode);
|
|
|
|
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);
|
|
|
|
void AddVolume(int NewVolID, int idnode1, int idnode2, int idnode3,
|
|
|
|
int idnode4, int idnode5, int idnode6, int idnode7, int idnode8,
|
|
|
|
int idnode9, int idnode10, int idnode11, int idnode12);
|
2005-06-07 19:22:20 +06:00
|
|
|
|
2012-08-09 16:03:55 +06:00
|
|
|
void AddPolygonalFace (const int NewFaceID,
|
|
|
|
const std::vector<int>& nodes_ids);
|
2015-06-24 14:17:07 +05:00
|
|
|
void AddQuadPolygonalFace (const int NewFaceID,
|
|
|
|
const std::vector<int>& nodes_ids);
|
2012-08-09 16:03:55 +06:00
|
|
|
void AddPolyhedralVolume (const int NewVolID,
|
|
|
|
const std::vector<int>& nodes_ids,
|
|
|
|
const std::vector<int>& quantities);
|
|
|
|
void AddBall(int NewBallID, int node, double diameter);
|
2005-06-07 19:22:20 +06:00
|
|
|
|
2006-03-13 20:29:49 +05:00
|
|
|
// special methods for quadratic elements
|
2012-08-09 16:03:55 +06:00
|
|
|
void AddEdge(int NewEdgeID, int n1, int n2, int n12);
|
2006-03-13 20:29:49 +05:00
|
|
|
void AddFace(int NewFaceID, int n1, int n2, int n3,
|
|
|
|
int n12, int n23, int n31);
|
2013-05-16 22:30:18 +06:00
|
|
|
void AddFace(int NewFaceID, int n1, int n2, int n3,
|
|
|
|
int n12, int n23, int n31, int nCenter);
|
2006-03-13 20:29:49 +05:00
|
|
|
void AddFace(int NewFaceID, int n1, int n2, int n3, int n4,
|
|
|
|
int n12, int n23, int n34, int n41);
|
2012-08-09 16:03:55 +06:00
|
|
|
void AddFace(int NewFaceID, int n1, int n2, int n3, int n4,
|
|
|
|
int n12, int n23, int n34, int n41, int nCenter);
|
2006-03-13 20:29:49 +05:00
|
|
|
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);
|
2012-08-09 16:03:55 +06:00
|
|
|
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,
|
|
|
|
int n1234,int n1256,int n2367,int n3478,
|
|
|
|
int n1458,int n5678,int nCenter);
|
2005-06-07 19:22:20 +06:00
|
|
|
void MoveNode(int NewNodeID, double x, double y, double z);
|
2012-08-09 16:03:55 +06:00
|
|
|
void RemoveNode(int NodeID);
|
|
|
|
void RemoveElement(int ElementID);
|
|
|
|
void ChangeElementNodes(int ElementID, int nodes[], int nbnodes);
|
|
|
|
void ChangePolyhedronNodes(const int ElementID,
|
|
|
|
const std::vector<int>& nodes_ids,
|
|
|
|
const std::vector<int>& quantities);
|
|
|
|
void Renumber (const bool isNodes, const int startID, const int deltaID);
|
|
|
|
void ClearMesh();
|
|
|
|
void Clear();
|
|
|
|
const std::list<SMESHDS_Command*> & GetCommands();
|
2006-03-13 20:29:49 +05:00
|
|
|
|
2003-09-04 13:14:51 +06:00
|
|
|
private:
|
2012-08-09 16:03:55 +06:00
|
|
|
SMESHDS_Command* getCommand(const SMESHDS_CommandType aType);
|
2004-12-01 15:48:31 +05:00
|
|
|
|
2012-08-09 16:03:55 +06:00
|
|
|
std::list<SMESHDS_Command*> myCommands;
|
2006-03-13 20:29:49 +05:00
|
|
|
|
|
|
|
bool myIsEmbeddedMode;
|
|
|
|
bool myIsModified;
|
2003-05-19 19:25:06 +06:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|