VTK  9.1.0
vtkXMLWriter.h
Go to the documentation of this file.
1 /*=========================================================================
2 
3  Program: Visualization Toolkit
4  Module: vtkXMLWriter.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 =========================================================================*/
30 #ifndef vtkXMLWriter_h
31 #define vtkXMLWriter_h
32 
33 #include "vtkIOXMLModule.h" // For export macro
34 #include "vtkXMLWriterBase.h"
35 
36 #include <sstream> // For ostringstream ivar
37 
38 class vtkAbstractArray;
39 class vtkArrayIterator;
40 
41 template <class T>
43 
44 class vtkCellData;
45 class vtkDataArray;
46 class vtkDataCompressor;
47 class vtkDataSet;
49 class vtkFieldData;
50 class vtkOutputStream;
51 class vtkPointData;
52 class vtkPoints;
53 class vtkFieldData;
54 class vtkXMLDataHeader;
55 
56 class vtkStdString;
57 class OffsetsManager; // one per piece/per time
58 class OffsetsManagerGroup; // array of OffsetsManager
59 class OffsetsManagerArray; // array of OffsetsManagerGroup
60 
61 class VTKIOXML_EXPORT vtkXMLWriter : public vtkXMLWriterBase
62 {
63 public:
65  void PrintSelf(ostream& os, vtkIndent indent) override;
66 
68 
76  vtkDataObject* GetInput() { return this->GetInput(0); }
78 
79  // See the vtkAlgorithm for a description of what these do
81  vtkInformationVector* outputVector) override;
82 
84 
87  vtkGetMacro(NumberOfTimeSteps, int);
88  vtkSetMacro(NumberOfTimeSteps, int);
90 
92 
95  void Start();
96  void Stop();
97  void WriteNextTime(double time);
99 
100 protected:
102  ~vtkXMLWriter() override;
103 
104  virtual int RequestInformation(vtkInformation* request, vtkInformationVector** inputVector,
105  vtkInformationVector* outputVector);
106  virtual int RequestData(vtkInformation* request, vtkInformationVector** inputVector,
107  vtkInformationVector* outputVector);
108 
109  // The output stream to which the XML is written.
110  ostream* Stream;
111 
112  // The stream position at which appended data starts.
113  vtkTypeInt64 AppendedDataPosition;
114 
115  // appended data offsets for field data
116  OffsetsManagerGroup* FieldDataOM; // one per array
117 
118  // We need a 32 bit signed integer type to which vtkIdType will be
119  // converted if Int32 is specified for the IdType parameter to this
120  // writer.
121 #if VTK_SIZEOF_SHORT == 4
122  typedef short Int32IdType;
123 #elif VTK_SIZEOF_INT == 4
124  typedef int Int32IdType;
125 #elif VTK_SIZEOF_LONG == 4
126  typedef long Int32IdType;
127 #else
128 #error "No native data type can represent a signed 32-bit integer."
129 #endif
130 
131  // Buffer for vtkIdType conversion.
132  Int32IdType* Int32IdTypeBuffer;
133 
134  // The byte swapping buffer.
135  unsigned char* ByteSwapBuffer;
136 
137  // Compression information.
141 
142  // The output stream used to write binary and appended data. May
143  // transparently encode the data.
145 
146  // Allow subclasses to set the data stream.
148  vtkGetObjectMacro(DataStream, vtkOutputStream);
149 
150  // Method to drive most of actual writing.
151  virtual int WriteInternal();
152 
153  // Method defined by subclasses to write data. Return 1 for
154  // success, 0 for failure.
155  virtual int WriteData() { return 1; }
156 
157  // Method defined by subclasses to specify the data set's type name.
158  virtual const char* GetDataSetName() = 0;
159 
160  // Utility methods for subclasses.
162  virtual int StartFile();
163  virtual void WriteFileAttributes();
164  virtual int EndFile();
165  void DeleteAFile();
166  void DeleteAFile(const char* name);
167 
168  virtual int WritePrimaryElement(ostream& os, vtkIndent indent);
169  virtual void WritePrimaryElementAttributes(ostream& os, vtkIndent indent);
172 
173  // Write enough space to go back and write the given attribute with
174  // at most "length" characters in the value. Returns the stream
175  // position at which attribute should be later written. The default
176  // length of 20 is enough for a 64-bit integer written in decimal or
177  // a double-precision floating point value written to 13 digits of
178  // precision (the other 7 come from a minus sign, decimal place, and
179  // a big exponent like "e+300").
180  vtkTypeInt64 ReserveAttributeSpace(const char* attr, size_t length = 20);
181 
182  vtkTypeInt64 GetAppendedDataOffset();
184  vtkTypeInt64 streamPos, vtkTypeInt64& lastoffset, const char* attr = nullptr);
186  vtkTypeInt64 streamPos, vtkTypeInt64 offset, const char* attr = nullptr);
187  void ForwardAppendedDataDouble(vtkTypeInt64 streamPos, double value, const char* attr);
188 
189  int WriteScalarAttribute(const char* name, int data);
190  int WriteScalarAttribute(const char* name, float data);
191  int WriteScalarAttribute(const char* name, double data);
192 #ifdef VTK_USE_64BIT_IDS
193  int WriteScalarAttribute(const char* name, vtkIdType data);
194 #endif
195 
196  int WriteVectorAttribute(const char* name, int length, int* data);
197  int WriteVectorAttribute(const char* name, int length, float* data);
198  int WriteVectorAttribute(const char* name, int length, double* data);
199 #ifdef VTK_USE_64BIT_IDS
200  int WriteVectorAttribute(const char* name, int length, vtkIdType* data);
201 #endif
202 
203  int WriteDataModeAttribute(const char* name);
204  int WriteWordTypeAttribute(const char* name, int dataType);
205  int WriteStringAttribute(const char* name, const char* value);
206 
207  // Returns true if any keys were written.
209 
210  void WriteArrayHeader(vtkAbstractArray* a, vtkIndent indent, const char* alternateName,
211  int writeNumTuples, int timestep);
212  virtual void WriteArrayFooter(
213  ostream& os, vtkIndent indent, vtkAbstractArray* a, int shortFormat);
214  virtual void WriteArrayInline(vtkAbstractArray* a, vtkIndent indent,
215  const char* alternateName = nullptr, int writeNumTuples = 0);
216  virtual void WriteInlineData(vtkAbstractArray* a, vtkIndent indent);
217 
219  const char* alternateName = nullptr, int writeNumTuples = 0, int timestep = 0);
223  void WriteArrayAppendedData(vtkAbstractArray* a, vtkTypeInt64 pos, vtkTypeInt64& lastoffset);
224 
225  // Methods for writing points, point data, and cell data.
226  void WriteFieldData(vtkIndent indent);
231  void WriteFieldDataAppendedData(vtkFieldData* fd, int timestep, OffsetsManagerGroup* fdManager);
233  void WritePointDataAppendedData(vtkPointData* pd, int timestep, OffsetsManagerGroup* pdManager);
235  void WriteCellDataAppendedData(vtkCellData* cd, int timestep, OffsetsManagerGroup* cdManager);
236  void WriteAttributeIndices(vtkDataSetAttributes* dsa, char** names);
238  void WritePointsAppendedData(vtkPoints* points, int timestep, OffsetsManager* pdManager);
241  vtkDataArray* xc, vtkDataArray* yc, vtkDataArray* zc, vtkIndent indent);
243  vtkIndent indent, OffsetsManagerGroup* coordManager);
245  int timestep, OffsetsManagerGroup* coordManager);
249  void WritePArray(vtkAbstractArray* a, vtkIndent indent, const char* alternateName = nullptr);
251 
252  // Internal utility methods.
253  int WriteBinaryDataBlock(unsigned char* in_data, size_t numWords, int wordType);
254  void PerformByteSwap(void* data, size_t numWords, size_t wordSize);
256  int WriteCompressionBlock(unsigned char* data, size_t size);
258  size_t GetWordTypeSize(int dataType);
259  const char* GetWordTypeName(int dataType);
260  size_t GetOutputWordTypeSize(int dataType);
261 
262  char** CreateStringArray(int numStrings);
263  void DestroyStringArray(int numStrings, char** strings);
264 
265  // The current range over which progress is moving. This allows for
266  // incrementally fine-tuned progress updates.
267  virtual void GetProgressRange(float range[2]);
268  virtual void SetProgressRange(const float range[2], int curStep, int numSteps);
269  virtual void SetProgressRange(const float range[2], int curStep, const float* fractions);
270  virtual void SetProgressPartial(float fraction);
271  virtual void UpdateProgressDiscrete(float progress);
272  float ProgressRange[2];
273 
274  // This shallows copy input field data to the passed field data and
275  // then adds any additional field arrays. For example, TimeValue.
277 
278  ostream* OutFile;
279  std::ostringstream* OutStringStream;
280 
281  int OpenStream();
282  int OpenFile();
283  int OpenString();
284  void CloseStream();
285  void CloseFile();
286  void CloseString();
287 
288  // The timestep currently being written
291 
292  // Dummy boolean var to start/stop the continue executing:
293  // when using the Start/Stop/WriteNextTime API
294  int UserContinueExecuting; // can only be -1 = invalid, 0 = stop, 1 = start
295 
296  vtkTypeInt64* NumberOfTimeValues; // one per piece / per timestep
297 
298  friend class vtkXMLWriterHelper;
299 
300 private:
301  vtkXMLWriter(const vtkXMLWriter&) = delete;
302  void operator=(const vtkXMLWriter&) = delete;
303 };
304 
305 #endif
vtkPoints
represent and manipulate 3D points
Definition: vtkPoints.h:143
vtkXMLWriter::PerformByteSwap
void PerformByteSwap(void *data, size_t numWords, size_t wordSize)
vtkXMLWriter::WriteVectorAttribute
int WriteVectorAttribute(const char *name, int length, int *data)
vtkXMLWriter::CompressionBlockNumber
size_t CompressionBlockNumber
Definition: vtkXMLWriter.h:138
vtkXMLWriter::CloseString
void CloseString()
vtkXMLWriter::WriteCellDataAppended
void WriteCellDataAppended(vtkCellData *cd, vtkIndent indent, OffsetsManagerGroup *cdManager)
vtkXMLWriter::CloseFile
void CloseFile()
vtkXMLWriter::GetInput
vtkDataObject * GetInput(int port)
Assign a data object as input.
vtkXMLWriter::ForwardAppendedDataOffset
void ForwardAppendedDataOffset(vtkTypeInt64 streamPos, vtkTypeInt64 offset, const char *attr=nullptr)
vtkXMLWriter::OutStringStream
std::ostringstream * OutStringStream
Definition: vtkXMLWriter.h:279
vtkXMLWriter::WriteArrayAppended
void WriteArrayAppended(vtkAbstractArray *a, vtkIndent indent, OffsetsManager &offs, const char *alternateName=nullptr, int writeNumTuples=0, int timestep=0)
vtkXMLWriter::~vtkXMLWriter
~vtkXMLWriter() override
vtkXMLWriter::GetWordTypeName
const char * GetWordTypeName(int dataType)
vtkXMLWriter::OutFile
ostream * OutFile
Definition: vtkXMLWriter.h:278
vtkXMLWriter::CreateCompressionHeader
int CreateCompressionHeader(size_t size)
vtkXMLWriter::WriteInformation
bool WriteInformation(vtkInformation *info, vtkIndent indent)
vtkXMLWriter::WritePCellData
void WritePCellData(vtkCellData *cd, vtkIndent indent)
vtkXMLWriter::WritePointDataAppendedData
void WritePointDataAppendedData(vtkPointData *pd, int timestep, OffsetsManagerGroup *pdManager)
vtkXMLWriter::WriteFieldDataInline
void WriteFieldDataInline(vtkFieldData *fd, vtkIndent indent)
vtkPointData
represent and manipulate point attribute data
Definition: vtkPointData.h:142
vtkX3D::value
@ value
Definition: vtkX3D.h:226
vtkXMLWriter::WriteAttributeIndices
void WriteAttributeIndices(vtkDataSetAttributes *dsa, char **names)
vtkIdType
int vtkIdType
Definition: vtkType.h:332
vtkXMLWriter::WritePrimaryElementAttributes
virtual void WritePrimaryElementAttributes(ostream &os, vtkIndent indent)
vtkXMLWriter::RequestData
virtual int RequestData(vtkInformation *request, vtkInformationVector **inputVector, vtkInformationVector *outputVector)
vtkXMLWriter::EndAppendedData
void EndAppendedData()
vtkDataSetAttributes
represent and manipulate attribute data in a dataset
Definition: vtkDataSetAttributes.h:170
vtkX3D::data
@ data
Definition: vtkX3D.h:321
vtkXMLWriter::CompressionHeader
vtkXMLDataHeader * CompressionHeader
Definition: vtkXMLWriter.h:139
vtkInformationVector
Store zero or more vtkInformation instances.
Definition: vtkInformationVector.h:145
vtkXMLWriter::CloseStream
void CloseStream()
vtkXMLWriter::GetOutputWordTypeSize
size_t GetOutputWordTypeSize(int dataType)
vtkXMLWriter::WritePrimaryElement
virtual int WritePrimaryElement(ostream &os, vtkIndent indent)
vtkArrayIteratorTemplate
Implementation template for a array iterator.
Definition: vtkArrayIteratorTemplate.h:39
vtkXMLWriter::ProcessRequest
vtkTypeBool ProcessRequest(vtkInformation *request, vtkInformationVector **inputVector, vtkInformationVector *outputVector) override
Upstream/Downstream requests form the generalized interface through which executives invoke a algorit...
vtkX3D::range
@ range
Definition: vtkX3D.h:244
vtkXMLWriter::WriteBinaryDataInternal
int WriteBinaryDataInternal(vtkAbstractArray *a)
vtkXMLWriter::CurrentTimeIndex
int CurrentTimeIndex
Definition: vtkXMLWriter.h:289
vtkXMLWriter::Stream
ostream * Stream
Definition: vtkXMLWriter.h:110
vtkXMLWriter::NumberOfTimeSteps
int NumberOfTimeSteps
Definition: vtkXMLWriter.h:290
vtkX3D::length
@ length
Definition: vtkX3D.h:399
vtkXMLWriter::CreateStringArray
char ** CreateStringArray(int numStrings)
vtkXMLWriter::WriteStringAttribute
int WriteStringAttribute(const char *name, const char *value)
vtkDataArray
abstract superclass for arrays of numeric data
Definition: vtkDataArray.h:159
vtkX3D::time
@ time
Definition: vtkX3D.h:503
vtkXMLWriterBase
Abstract base class for VTK-XML writers.
Definition: vtkXMLWriterBase.h:39
vtkXMLWriter::SetDataStream
virtual void SetDataStream(vtkOutputStream *)
vtkXMLWriter::EndFile
virtual int EndFile()
vtkXMLWriter::WriteInternal
virtual int WriteInternal()
vtkXMLWriter::OpenString
int OpenString()
vtkFieldData
represent and manipulate fields of data
Definition: vtkFieldData.h:164
vtkXMLWriter::SetProgressRange
virtual void SetProgressRange(const float range[2], int curStep, const float *fractions)
vtkXMLWriter::WriteArrayFooter
virtual void WriteArrayFooter(ostream &os, vtkIndent indent, vtkAbstractArray *a, int shortFormat)
vtkXMLWriter::WriteVectorAttribute
int WriteVectorAttribute(const char *name, int length, float *data)
vtkXMLWriter::Start
void Start()
API to interface an outside the VTK pipeline control.
vtkXMLWriter::SetProgressPartial
virtual void SetProgressPartial(float fraction)
vtkXMLWriter::FieldDataOM
OffsetsManagerGroup * FieldDataOM
Definition: vtkXMLWriter.h:116
vtkX3D::port
@ port
Definition: vtkX3D.h:453
vtkX3D::points
@ points
Definition: vtkX3D.h:452
vtkXMLWriter::vtkXMLWriter
vtkXMLWriter()
vtkXMLWriter::WritePointsAppended
void WritePointsAppended(vtkPoints *points, vtkIndent indent, OffsetsManager *manager)
vtkXMLWriter::WriteVectorAttribute
int WriteVectorAttribute(const char *name, int length, double *data)
vtkXMLWriter::WriteScalarAttribute
int WriteScalarAttribute(const char *name, int data)
vtkXMLWriter::RequestInformation
virtual int RequestInformation(vtkInformation *request, vtkInformationVector **inputVector, vtkInformationVector *outputVector)
vtkXMLWriter::Int32IdTypeBuffer
Int32IdType * Int32IdTypeBuffer
Definition: vtkXMLWriter.h:132
vtkXMLWriter::WritePointDataAppended
void WritePointDataAppended(vtkPointData *pd, vtkIndent indent, OffsetsManagerGroup *pdManager)
vtkXMLWriter
Superclass for VTK's XML file writers.
Definition: vtkXMLWriter.h:62
vtkX3D::offset
@ offset
Definition: vtkX3D.h:444
vtkXMLWriter::UpdateProgressDiscrete
virtual void UpdateProgressDiscrete(float progress)
vtkXMLWriter::WriteWordTypeAttribute
int WriteWordTypeAttribute(const char *name, int dataType)
vtkXMLWriter::WriteAppendedDataOffset
void WriteAppendedDataOffset(vtkTypeInt64 streamPos, vtkTypeInt64 &lastoffset, const char *attr=nullptr)
vtkXMLWriter::WriteBinaryData
int WriteBinaryData(vtkAbstractArray *a)
vtkXMLWriter::WriteArrayHeader
void WriteArrayHeader(vtkAbstractArray *a, vtkIndent indent, const char *alternateName, int writeNumTuples, int timestep)
vtkCellData
represent and manipulate cell attribute data
Definition: vtkCellData.h:142
vtkXMLWriter::WritePCoordinates
void WritePCoordinates(vtkDataArray *xc, vtkDataArray *yc, vtkDataArray *zc, vtkIndent indent)
vtkXMLWriter::WritePointDataInline
void WritePointDataInline(vtkPointData *pd, vtkIndent indent)
vtkXMLWriter::UserContinueExecuting
int UserContinueExecuting
Definition: vtkXMLWriter.h:294
vtkIndent
a simple class to control print indentation
Definition: vtkIndent.h:113
vtkXMLWriter::OpenStream
int OpenStream()
vtkXMLWriter::WriteCoordinatesInline
void WriteCoordinatesInline(vtkDataArray *xc, vtkDataArray *yc, vtkDataArray *zc, vtkIndent indent)
vtkXMLWriterBase.h
vtkXMLWriter::GetDataSetName
virtual const char * GetDataSetName()=0
vtkXMLWriter::WriteCellDataAppendedData
void WriteCellDataAppendedData(vtkCellData *cd, int timestep, OffsetsManagerGroup *cdManager)
vtkXMLWriter::GetProgressRange
virtual void GetProgressRange(float range[2])
vtkXMLWriter::NumberOfTimeValues
vtkTypeInt64 * NumberOfTimeValues
Definition: vtkXMLWriter.h:296
vtkDataCompressor
Abstract interface for data compression classes.
Definition: vtkDataCompressor.h:46
vtkX3D::size
@ size
Definition: vtkX3D.h:259
vtkXMLWriter::WriteData
virtual int WriteData()
Definition: vtkXMLWriter.h:155
vtkXMLWriter::AppendedDataPosition
vtkTypeInt64 AppendedDataPosition
Definition: vtkXMLWriter.h:113
vtkXMLWriter::WriteCoordinatesAppendedData
void WriteCoordinatesAppendedData(vtkDataArray *xc, vtkDataArray *yc, vtkDataArray *zc, int timestep, OffsetsManagerGroup *coordManager)
vtkXMLWriter::OpenFile
int OpenFile()
vtkXMLWriter::DeleteAFile
void DeleteAFile(const char *name)
OffsetsManagerGroup
Definition: vtkXMLOffsetsManager.h:108
vtkXMLWriter::WriteCellDataInline
void WriteCellDataInline(vtkCellData *cd, vtkIndent indent)
vtkXMLWriter::GetInput
vtkDataObject * GetInput()
Assign a data object as input.
Definition: vtkXMLWriter.h:76
vtkX3D::name
@ name
Definition: vtkX3D.h:225
vtkXMLWriter::WriteCompressionHeader
int WriteCompressionHeader()
vtkXMLWriter::UpdateFieldData
void UpdateFieldData(vtkFieldData *)
vtkXMLWriter::WritePArray
void WritePArray(vtkAbstractArray *a, vtkIndent indent, const char *alternateName=nullptr)
vtkXMLWriter::WriteFileAttributes
virtual void WriteFileAttributes()
vtkXMLWriter::WriteAsciiData
int WriteAsciiData(vtkAbstractArray *a, vtkIndent indent)
vtkXMLWriter::WriteArrayInline
virtual void WriteArrayInline(vtkAbstractArray *a, vtkIndent indent, const char *alternateName=nullptr, int writeNumTuples=0)
vtkDataSet
abstract class to specify dataset behavior
Definition: vtkDataSet.h:166
vtkAbstractArray
Abstract superclass for all arrays.
Definition: vtkAbstractArray.h:76
vtkInformation
Store vtkAlgorithm input/output information.
Definition: vtkInformation.h:183
vtkX3D::info
@ info
Definition: vtkX3D.h:382
vtkXMLWriter::WriteFieldData
void WriteFieldData(vtkIndent indent)
vtkXMLWriter::SetInputData
void SetInputData(int, vtkDataObject *)
Assign a data object as input.
OffsetsManagerArray
Definition: vtkXMLOffsetsManager.h:155
vtkXMLWriter::WriteScalarAttribute
int WriteScalarAttribute(const char *name, double data)
vtkXMLWriter::WritePointsAppendedData
void WritePointsAppendedData(vtkPoints *points, int timestep, OffsetsManager *pdManager)
vtkXMLWriter::ReserveAttributeSpace
vtkTypeInt64 ReserveAttributeSpace(const char *attr, size_t length=20)
vtkXMLWriter::DeleteAFile
void DeleteAFile()
vtkXMLWriter::ByteSwapBuffer
unsigned char * ByteSwapBuffer
Definition: vtkXMLWriter.h:135
vtkXMLWriter::WritePPointData
void WritePPointData(vtkPointData *pd, vtkIndent indent)
vtkXMLWriter::WriteNextTime
void WriteNextTime(double time)
API to interface an outside the VTK pipeline control.
vtkXMLWriter::WriteFieldDataAppended
void WriteFieldDataAppended(vtkFieldData *fd, vtkIndent indent, OffsetsManagerGroup *fdManager)
vtkXMLWriter::WriteFieldDataAppendedData
void WriteFieldDataAppendedData(vtkFieldData *fd, int timestep, OffsetsManagerGroup *fdManager)
vtkXMLWriter::WriteCompressionBlock
int WriteCompressionBlock(unsigned char *data, size_t size)
vtkArrayIterator
Abstract superclass to iterate over elements in an vtkAbstractArray.
Definition: vtkArrayIterator.h:50
vtkXMLWriter::WriteCoordinatesAppended
void WriteCoordinatesAppended(vtkDataArray *xc, vtkDataArray *yc, vtkDataArray *zc, vtkIndent indent, OffsetsManagerGroup *coordManager)
vtkXMLWriter::WriteScalarAttribute
int WriteScalarAttribute(const char *name, float data)
vtkXMLWriter::GetAppendedDataOffset
vtkTypeInt64 GetAppendedDataOffset()
vtkXMLWriter::GetWordTypeSize
size_t GetWordTypeSize(int dataType)
vtkXMLWriter::WritePPoints
void WritePPoints(vtkPoints *points, vtkIndent indent)
vtkOutputStream
Wraps a binary output stream with a VTK interface.
Definition: vtkOutputStream.h:34
vtkXMLWriter::WriteArrayAppendedData
void WriteArrayAppendedData(vtkAbstractArray *a, vtkTypeInt64 pos, vtkTypeInt64 &lastoffset)
vtkXMLWriter::DataStream
vtkOutputStream * DataStream
Definition: vtkXMLWriter.h:144
vtkXMLWriter::SetInputData
void SetInputData(vtkDataObject *)
Assign a data object as input.
vtkXMLWriter::WritePointsInline
void WritePointsInline(vtkPoints *points, vtkIndent indent)
vtkX3D::progress
@ progress
Definition: vtkX3D.h:458
OffsetsManager
Helper class due to PIMPL excess.
Definition: vtkXMLOffsetsManager.h:55
vtkXMLWriter::ForwardAppendedDataDouble
void ForwardAppendedDataDouble(vtkTypeInt64 streamPos, double value, const char *attr)
vtkStdString
Wrapper around std::string to keep symbols short.
Definition: vtkStdString.h:105
vtkXMLWriter::SetProgressRange
virtual void SetProgressRange(const float range[2], int curStep, int numSteps)
vtkXMLWriter::GetInputAsDataSet
vtkDataSet * GetInputAsDataSet()
vtkXMLWriter::CompressionHeaderPosition
vtkTypeInt64 CompressionHeaderPosition
Definition: vtkXMLWriter.h:140
vtkXMLWriter::WriteInlineData
virtual void WriteInlineData(vtkAbstractArray *a, vtkIndent indent)
vtkDataObject
general representation of visualization data
Definition: vtkDataObject.h:169
vtkXMLWriter::DestroyStringArray
void DestroyStringArray(int numStrings, char **strings)
vtkXMLWriter::PrintSelf
void PrintSelf(ostream &os, vtkIndent indent) override
Methods invoked by print to print information about the object including superclasses.
vtkXMLWriter::StartAppendedData
void StartAppendedData()
vtkXMLDataHeader
Definition: vtkXMLDataHeaderPrivate.h:30
vtkTypeBool
int vtkTypeBool
Definition: vtkABI.h:69
vtkXMLWriter::Stop
void Stop()
API to interface an outside the VTK pipeline control.
vtkXMLWriter::WriteDataModeAttribute
int WriteDataModeAttribute(const char *name)
vtkXMLWriter::WriteBinaryDataBlock
int WriteBinaryDataBlock(unsigned char *in_data, size_t numWords, int wordType)
vtkXMLWriter::StartFile
virtual int StartFile()