/*========================================================================= Program: Visualization Toolkit Module: $RCSfile: vtkXMLRectilinearGridReader.h,v $ Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen All rights reserved. See Copyright.txt or http://www.kitware.com/Copyright.htm for details. This software is distributed WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the above copyright notice for more information. =========================================================================*/ // .NAME vtkXMLRectilinearGridReader - Read VTK XML RectilinearGrid files. // .SECTION Description // vtkXMLRectilinearGridReader reads the VTK XML RectilinearGrid file // format. One rectilinear grid file can be read to produce one // output. Streaming is supported. The standard extension for this // reader's file format is "vtr". This reader is also used to read a // single piece of the parallel file format. // .SECTION See Also // vtkXMLPRectilinearGridReader #ifndef __vtkXMLRectilinearGridReader_h #define __vtkXMLRectilinearGridReader_h #include "vtkXMLStructuredDataReader.h" class vtkRectilinearGrid; class VTK_IO_EXPORT vtkXMLRectilinearGridReader : public vtkXMLStructuredDataReader { public: vtkTypeRevisionMacro(vtkXMLRectilinearGridReader,vtkXMLStructuredDataReader); void PrintSelf(ostream& os, vtkIndent indent); static vtkXMLRectilinearGridReader *New(); // Description: // Get/Set the reader's output. void SetOutput(vtkRectilinearGrid *output); vtkRectilinearGrid *GetOutput(); vtkRectilinearGrid *GetOutput(int idx); protected: vtkXMLRectilinearGridReader(); ~vtkXMLRectilinearGridReader(); const char* GetDataSetName(); void SetOutputExtent(int* extent); void SetupPieces(int numPieces); void DestroyPieces(); void SetupOutputData(); int ReadPiece(vtkXMLDataElement* ePiece); int ReadPieceData(); int ReadSubCoordinates(int* inBounds, int* outBounds, int* subBounds, vtkXMLDataElement* da, vtkDataArray* array); virtual int FillOutputPortInformation(int, vtkInformation*); // The elements representing the coordinate arrays for each piece. vtkXMLDataElement** CoordinateElements; private: vtkXMLRectilinearGridReader(const vtkXMLRectilinearGridReader&); // Not implemented. void operator=(const vtkXMLRectilinearGridReader&); // Not implemented. }; #endif