VTK
vtkPDataSetWriter.h
Go to the documentation of this file.
1 /*=========================================================================
2 
3  Program: Visualization Toolkit
4  Module: vtkPDataSetWriter.h
5 
6  Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
7  All rights reserved.
8  See Copyright.txt or http://www.kitware.com/Copyright.htm for details.
9 
10  This software is distributed WITHOUT ANY WARRANTY; without even
11  the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
12  PURPOSE. See the above copyright notice for more information.
13 
14 =========================================================================*/
25 #ifndef vtkPDataSetWriter_h
26 #define vtkPDataSetWriter_h
27 
28 #include "vtkIOParallelModule.h" // For export macro
29 #include "vtkDataSetWriter.h"
30 
31 #include <map> // for keeping track of extents
32 #include <vector> // for keeping track of extents
33 
34 class vtkImageData;
35 class vtkRectilinearGrid;
36 class vtkStructuredGrid;
38 
40 {
41 public:
42  void PrintSelf(ostream& os, vtkIndent indent);
44  static vtkPDataSetWriter *New();
45 
47  virtual int Write();
48 
50 
51  void SetNumberOfPieces(int num);
52  vtkGetMacro(NumberOfPieces, int);
54 
56 
58  vtkSetMacro(GhostLevel, int);
59  vtkGetMacro(GhostLevel, int);
61 
63 
67  vtkSetMacro(StartPiece, int);
68  vtkGetMacro(StartPiece, int);
69  vtkSetMacro(EndPiece, int);
70  vtkGetMacro(EndPiece, int);
72 
74 
76  vtkSetStringMacro(FilePattern);
77  vtkGetStringMacro(FilePattern);
79 
81 
86  vtkSetMacro(UseRelativeFileNames, int);
87  vtkGetMacro(UseRelativeFileNames, int);
88  vtkBooleanMacro(UseRelativeFileNames, int);
90 
92 
95  virtual void SetController(vtkMultiProcessController*);
96  vtkGetObjectMacro(Controller, vtkMultiProcessController);
98 
99 protected:
102 
103 //BTX
104  ostream *OpenFile();
105  int WriteUnstructuredMetaData(vtkDataSet *input,
106  char *root, char *str, ostream *fptr);
107  int WriteImageMetaData(vtkImageData *input,
108  char *root, char *str, ostream *fptr);
109  int WriteRectilinearGridMetaData(vtkRectilinearGrid *input,
110  char *root, char *str, ostream *fptr);
111  int WriteStructuredGridMetaData(vtkStructuredGrid *input,
112  char *root, char *str, ostream *fptr);
113 //ETX
114 
116  int EndPiece;
119 
121 
122  char *FilePattern;
123 
124  void DeleteFiles();
125 
126  typedef std::map<int, std::vector<int> > ExtentsType;
127  ExtentsType Extents;
128 
130 
131 private:
132  vtkPDataSetWriter(const vtkPDataSetWriter&); // Not implemented
133  void operator=(const vtkPDataSetWriter&); // Not implemented
134 };
135 
136 #endif
#define VTKIOPARALLEL_EXPORT
a dataset that is topologically regular with variable spacing in the three coordinate directions ...
abstract class to specify dataset behavior
Definition: vtkDataSet.h:61
static vtkDataSetWriter * New()
void PrintSelf(ostream &os, vtkIndent indent)
std::map< int, std::vector< int > > ExtentsType
a simple class to control print indentation
Definition: vtkIndent.h:38
topologically and geometrically regular array of data
Definition: vtkImageData.h:44
Manages writing pieces of a data set.
topologically regular array of data
virtual int Write()
vtkMultiProcessController * Controller
write any type of vtk dataset to file
Multiprocessing communication superclass.