Version: 9.12.0
DriverGMF_Write.hxx
Go to the documentation of this file.
1 // Copyright (C) 2007-2023 CEA, EDF, OPEN CASCADE
2 //
3 // Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
4 // CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
5 //
6 // This library is free software; you can redistribute it and/or
7 // modify it under the terms of the GNU Lesser General Public
8 // License as published by the Free Software Foundation; either
9 // version 2.1 of the License, or (at your option) any later version.
10 //
11 // This library is distributed in the hope that it will be useful,
12 // but WITHOUT ANY WARRANTY; without even the implied warranty of
13 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 // Lesser General Public License for more details.
15 //
16 // You should have received a copy of the GNU Lesser General Public
17 // License along with this library; if not, write to the Free Software
18 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
19 //
20 // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
21 //
22 // File : DriverGMF_Write.hxx
23 // Created : Mon Sep 17 15:36:47 2012
24 // Author : Edward AGAPOV (eap)
25 
26 
27 #ifndef __DriverGMF_Write_HXX__
28 #define __DriverGMF_Write_HXX__
29 
30 #include "SMESH_DriverGMF.hxx"
31 
32 #include "Driver_SMESHDS_Mesh.h"
33 #include "SMDSAbs_ElementType.hxx"
34 #include "SMDS_ElemIterator.hxx"
35 #include "SMESH_ControlPnt.hxx"
36 
41 {
42 public:
43 
45  ~DriverGMF_Write();
46 
47  void SetExportRequiredGroups( bool toExport )
48  {
49  _exportRequiredGroups = toExport;
50  }
51 
52  virtual Status Perform();
53 
54  // Size Maps
55  Status PerformSizeMap( const std::vector<SMESHUtils::ControlPnt>& points );
56  void SetSizeMapPrefix( std::string prefix )
57  {
58  myVerticesFile = prefix + ".mesh";
59  mySolFile = prefix + ".sol";
60  };
61  std::vector<std::string> GetSizeMapFiles();
62 
63  private:
64 
65  SMDS_ElemIteratorPtr elementIterator(SMDSAbs_ElementType type);
66  SMDS_ElemIteratorPtr elementIterator(SMDSAbs_EntityType type);
67  SMDS_ElemIteratorPtr elementIterator(SMDSAbs_GeometryType type);
68 
70  std::string myVerticesFile;
71  std::string mySolFile;
72 };
73 
74 #endif
SMDSAbs_GeometryType
enumeration for element geometry type
Definition: SMDSAbs_ElementType.hxx:47
SMDSAbs_ElementType
Type (node, edge, face or volume) of elements.
Definition: SMDSAbs_ElementType.hxx:34
SMDSAbs_EntityType
Enumeration of entity type used in mesh info array.
Definition: SMDSAbs_ElementType.hxx:79
boost::shared_ptr< SMDS_Iterator< const SMDS_MeshElement * > > SMDS_ElemIteratorPtr
Definition: SMDS_ElemIterator.hxx:43
Driver Writing a mesh into a GMF file.
Definition: DriverGMF_Write.hxx:41
void SetExportRequiredGroups(bool toExport)
Definition: DriverGMF_Write.hxx:47
void SetSizeMapPrefix(std::string prefix)
Definition: DriverGMF_Write.hxx:56
std::string myVerticesFile
Definition: DriverGMF_Write.hxx:70
bool _exportRequiredGroups
Definition: DriverGMF_Write.hxx:69
std::string mySolFile
Definition: DriverGMF_Write.hxx:71
virtual Status Perform()=0
Definition: Driver_SMESHDS_Mesh.h:31
#define MESHDriverGMF_EXPORT
Definition: libmesh5.h:28