vtkXMLImageDataReader.cxx 4.44 KB
Newer Older
1 2 3 4 5
/*=========================================================================

  Program:   Visualization Toolkit
  Module:    vtkXMLImageDataReader.cxx

6
  Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
7 8 9
  All rights reserved.
  See Copyright.txt or http://www.kitware.com/Copyright.htm for details.

10 11
     This software is distributed WITHOUT ANY WARRANTY; without even
     the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
12 13 14 15
     PURPOSE.  See the above copyright notice for more information.

=========================================================================*/
#include "vtkXMLImageDataReader.h"
16 17 18

#include "vtkDataArray.h"
#include "vtkImageData.h"
19
#include "vtkObjectFactory.h"
20
#include "vtkPointData.h"
21
#include "vtkXMLDataElement.h"
22 23
#include "vtkInformation.h"
#include "vtkStreamingDemandDrivenPipeline.h"
24

25
vtkCxxRevisionMacro(vtkXMLImageDataReader, "1.9");
26 27 28 29 30
vtkStandardNewMacro(vtkXMLImageDataReader);

//----------------------------------------------------------------------------
vtkXMLImageDataReader::vtkXMLImageDataReader()
{
31 32
  vtkImageData *output = vtkImageData::New();
  this->SetOutput(output);
33 34
  // Releasing data for pipeline parallism.
  // Filters will know it is empty. 
35 36
  output->ReleaseData();
  output->Delete();
37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52
}

//----------------------------------------------------------------------------
vtkXMLImageDataReader::~vtkXMLImageDataReader()
{
}

//----------------------------------------------------------------------------
void vtkXMLImageDataReader::PrintSelf(ostream& os, vtkIndent indent)
{
  this->Superclass::PrintSelf(os, indent);
}

//----------------------------------------------------------------------------
void vtkXMLImageDataReader::SetOutput(vtkImageData *output)
{
53
  this->GetExecutive()->SetOutputData(0, output);
54 55 56 57 58
}

//----------------------------------------------------------------------------
vtkImageData* vtkXMLImageDataReader::GetOutput()
{
59
  return this->GetOutput(0);
60 61
}

62 63 64
//----------------------------------------------------------------------------
vtkImageData* vtkXMLImageDataReader::GetOutput(int idx)
{
65
  return vtkImageData::SafeDownCast( this->GetOutputDataObject(idx) );
66 67 68
}


69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86
//----------------------------------------------------------------------------
const char* vtkXMLImageDataReader::GetDataSetName()
{
  return "ImageData";
}

//----------------------------------------------------------------------------
void vtkXMLImageDataReader::SetOutputExtent(int* extent)
{
  this->GetOutput()->SetExtent(extent);
}

//----------------------------------------------------------------------------
int vtkXMLImageDataReader::ReadPrimaryElement(vtkXMLDataElement* ePrimary)
{
  if(!this->Superclass::ReadPrimaryElement(ePrimary)) { return 0; }
  
  // Get the image's origin.
87
  if(ePrimary->GetVectorAttribute("Origin", this->Origin) != 3)
88 89 90 91 92 93 94
    {
    this->Origin[0] = 0;
    this->Origin[1] = 0;
    this->Origin[2] = 0;
    }
  
  // Get the image's spacing.
95
  if(ePrimary->GetVectorAttribute("Spacing", this->Spacing) != 3)
96 97 98 99 100 101 102 103 104 105
    {
    this->Spacing[0] = 1;
    this->Spacing[1] = 1;
    this->Spacing[2] = 1;
    }
  
  return 1;
}

//----------------------------------------------------------------------------
106 107
// Note that any changes (add or removing information) made to this method
// should be replicated in CopyOutputInformation
108
void vtkXMLImageDataReader::SetupOutputInformation(vtkInformation *outInfo)
109
{
110 111 112 113
  this->Superclass::SetupOutputInformation(outInfo);

  outInfo->Set(vtkDataObject::ORIGIN(), this->Origin, 3);
  outInfo->Set(vtkDataObject::SPACING(), this->Spacing, 3);
114
}
115 116


117 118
//----------------------------------------------------------------------------
void vtkXMLImageDataReader::CopyOutputInformation(vtkInformation *outInfo, int port)
119
{
120 121
  this->Superclass::CopyOutputInformation(outInfo, port);
  vtkInformation *localInfo = this->GetExecutive()->GetOutputInformation( port );
122
  
123 124 125 126 127 128 129 130
  if ( localInfo->Has(vtkDataObject::ORIGIN()) )
    {
    outInfo->CopyEntry( localInfo, vtkDataObject::ORIGIN() );
    }
  if ( localInfo->Has(vtkDataObject::SPACING()) )
    {
    outInfo->CopyEntry( localInfo, vtkDataObject::SPACING() );
    }
131 132 133 134 135
  if ( localInfo->Has(vtkStreamingDemandDrivenPipeline::WHOLE_EXTENT()) )
    {
    outInfo->CopyEntry( localInfo, vtkStreamingDemandDrivenPipeline::WHOLE_EXTENT() );
    }
}
136 137


138 139 140 141 142 143 144
//----------------------------------------------------------------------------
int vtkXMLImageDataReader::FillOutputPortInformation(int, vtkInformation* info)
{
  info->Set(vtkDataObject::DATA_TYPE_NAME(), "vtkImageData");
  return 1;
}