00001 /*---------------------------------------------------------------------------*\ 00002 ========= | 00003 \\ / F ield | OpenFOAM: The Open Source CFD Toolbox 00004 \\ / O peration | 00005 \\ / A nd | Copyright (C) 1991-2010 OpenCFD Ltd. 00006 \\/ M anipulation | 00007 ------------------------------------------------------------------------------- 00008 License 00009 This file is part of OpenFOAM. 00010 00011 OpenFOAM is free software: you can redistribute it and/or modify it 00012 under the terms of the GNU General Public License as published by 00013 the Free Software Foundation, either version 3 of the License, or 00014 (at your option) any later version. 00015 00016 OpenFOAM is distributed in the hope that it will be useful, but WITHOUT 00017 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 00018 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License 00019 for more details. 00020 00021 You should have received a copy of the GNU General Public License 00022 along with OpenFOAM. If not, see <http://www.gnu.org/licenses/>. 00023 00024 Class 00025 Foam::vtkSurfaceWriter 00026 00027 Description 00028 00029 SourceFiles 00030 vtkSurfaceWriter.C 00031 00032 \*---------------------------------------------------------------------------*/ 00033 00034 #ifndef vtkSurfaceWriter_H 00035 #define vtkSurfaceWriter_H 00036 00037 #include <sampling/surfaceWriter.H> 00038 00039 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * // 00040 00041 namespace Foam 00042 { 00043 00044 /*---------------------------------------------------------------------------*\ 00045 Class vtkSurfaceWriter Declaration 00046 \*---------------------------------------------------------------------------*/ 00047 00048 template<class Type> 00049 class vtkSurfaceWriter 00050 : 00051 public surfaceWriter<Type> 00052 { 00053 // Private Member Functions 00054 00055 static void writeGeometry(Ostream&, const pointField&, const faceList&); 00056 00057 static void writeData(Ostream&, const Field<Type>& values); 00058 00059 00060 public: 00061 00062 //- Runtime type information 00063 TypeName("vtk"); 00064 00065 00066 // Constructors 00067 00068 //- Construct null 00069 vtkSurfaceWriter(); 00070 00071 00072 // Destructor 00073 00074 virtual ~vtkSurfaceWriter(); 00075 00076 00077 // Member Functions 00078 00079 // Write 00080 00081 //- Write geometry to file. 00082 virtual void write 00083 ( 00084 const fileName& outputDir, 00085 const fileName& surfaceName, 00086 const pointField& points, 00087 const faceList& faces, 00088 const bool verbose = false 00089 ) const; 00090 00091 00092 //- Writes single surface to file. 00093 virtual void write 00094 ( 00095 const fileName& outputDir, 00096 const fileName& surfaceName, 00097 const pointField& points, 00098 const faceList& faces, 00099 const fileName& fieldName, 00100 const Field<Type>& values, 00101 const bool verbose = false 00102 ) const; 00103 }; 00104 00105 00106 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * // 00107 00108 } // End namespace Foam 00109 00110 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * // 00111 00112 #ifdef NoRepository 00113 # include "vtkSurfaceWriter.C" 00114 #endif 00115 00116 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * // 00117 00118 #endif 00119 00120 // ************************ vim: set sw=4 sts=4 et: ************************ //