TrianglesMeshWriter.hpp
00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030 #ifndef _TRIANGLESMESHWRITER_HPP_
00031 #define _TRIANGLESMESHWRITER_HPP_
00032
00033 #include "AbstractTetrahedralMeshWriter.hpp"
00034 #include "OutputFileHandler.hpp"
00035
00036
00040 template<unsigned ELEMENT_DIM, unsigned SPACE_DIM>
00041 class TrianglesMeshWriter : public AbstractTetrahedralMeshWriter<ELEMENT_DIM, SPACE_DIM>
00042 {
00043 public:
00044
00052 TrianglesMeshWriter(const std::string& rDirectory,
00053 const std::string& rBaseName,
00054 const bool clearOutputDir=true);
00060 void SetWriteFilesAsBinary();
00061
00065 void WriteFiles();
00066
00070 void WriteElementsAsFaces();
00071
00075 void WriteFacesAsEdges();
00076
00088 template<class T_DATA, class T_ATTR>
00089 void WriteItem(out_stream &pFile, unsigned itemNumber, const std::vector<T_DATA> &dataPacket, T_ATTR attribute);
00090
00099 template<class T_DATA>
00100 void WriteItem(out_stream &pFile, unsigned itemNumber, const std::vector<T_DATA> &dataPacket);
00101
00102
00106 virtual ~TrianglesMeshWriter();
00107 };
00108
00109 #endif //_TRIANGLESMESHWRITER_HPP_