VTK
dox/IO/Export/vtkVRMLExporter.h
Go to the documentation of this file.
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