VTK
|
00001 /*========================================================================= 00002 00003 Program: Visualization Toolkit 00004 Module: vtkVRMLExporter.h 00005 00006 Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen 00007 All rights reserved. 00008 See Copyright.txt or http://www.kitware.com/Copyright.htm for details. 00009 00010 This software is distributed WITHOUT ANY WARRANTY; without even 00011 the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR 00012 PURPOSE. See the above copyright notice for more information. 00013 00014 =========================================================================*/ 00029 #ifndef __vtkVRMLExporter_h 00030 #define __vtkVRMLExporter_h 00031 00032 #include "vtkIOExportModule.h" // For export macro 00033 #include "vtkExporter.h" 00034 00035 class vtkLight; 00036 class vtkActor; 00037 class vtkPoints; 00038 class vtkDataArray; 00039 class vtkUnsignedCharArray; 00040 class vtkPolyData; 00041 class vtkPointData; 00042 00043 class VTKIOEXPORT_EXPORT vtkVRMLExporter : public vtkExporter 00044 { 00045 public: 00046 static vtkVRMLExporter *New(); 00047 vtkTypeMacro(vtkVRMLExporter,vtkExporter); 00048 void PrintSelf(ostream& os, vtkIndent indent); 00049 00051 00052 vtkSetStringMacro(FileName); 00053 vtkGetStringMacro(FileName); 00055 00057 00058 vtkSetMacro(Speed,double); 00059 vtkGetMacro(Speed,double); 00061 00064 void SetFilePointer(FILE *); 00065 00066 protected: 00067 vtkVRMLExporter(); 00068 ~vtkVRMLExporter(); 00069 00070 void WriteData(); 00071 void WriteALight(vtkLight *aLight, FILE *fp); 00072 void WriteAnActor(vtkActor *anActor, FILE *fp); 00073 void WritePointData(vtkPoints *points, vtkDataArray *normals, 00074 vtkDataArray *tcoords, vtkUnsignedCharArray *colors, 00075 FILE *fp); 00076 void WriteShapeBegin(vtkActor* actor, FILE *fileP, 00077 vtkPolyData *polyData,vtkPointData *pntData, 00078 vtkUnsignedCharArray *color); 00079 void WriteShapeEnd( FILE *fileP ); 00080 char *FileName; 00081 FILE *FilePointer; 00082 double Speed; 00083 private: 00084 vtkVRMLExporter(const vtkVRMLExporter&); // Not implemented. 00085 void operator=(const vtkVRMLExporter&); // Not implemented. 00086 }; 00087 00088 #endif 00089