Cloned library of VTK-5.0.0 with extra build files for internal package management.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

141 lines
4.6 KiB

/*=========================================================================
Program: Visualization Toolkit
Module: $RCSfile: vtkImageDataStreamer.cxx,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.
=========================================================================*/
#include "vtkImageDataStreamer.h"
#include "vtkCommand.h"
#include "vtkExtentTranslator.h"
#include "vtkImageData.h"
#include "vtkInformation.h"
#include "vtkInformationVector.h"
#include "vtkObjectFactory.h"
#include "vtkStreamingDemandDrivenPipeline.h"
vtkCxxRevisionMacro(vtkImageDataStreamer, "$Revision: 1.36 $");
vtkStandardNewMacro(vtkImageDataStreamer);
vtkCxxSetObjectMacro(vtkImageDataStreamer,ExtentTranslator,vtkExtentTranslator);
//----------------------------------------------------------------------------
vtkImageDataStreamer::vtkImageDataStreamer()
{
// default to 10 divisions
this->NumberOfStreamDivisions = 10;
this->CurrentDivision = 0;
// create default translator
this->ExtentTranslator = vtkExtentTranslator::New();
this->SetNumberOfInputPorts(1);
this->SetNumberOfOutputPorts(1);
}
vtkImageDataStreamer::~vtkImageDataStreamer()
{
if (this->ExtentTranslator)
{
this->ExtentTranslator->Delete();
}
}
//----------------------------------------------------------------------------
void vtkImageDataStreamer::PrintSelf(ostream& os, vtkIndent indent)
{
this->Superclass::PrintSelf(os,indent);
os << indent << "NumberOfStreamDivisions: " << this->NumberOfStreamDivisions << endl;
if ( this->ExtentTranslator )
{
os << indent << "ExtentTranslator:\n";
this->ExtentTranslator->PrintSelf(os,indent.GetNextIndent());
}
else
{
os << indent << "ExtentTranslator: (none)\n";
}
}
//----------------------------------------------------------------------------
int vtkImageDataStreamer::ProcessRequest(vtkInformation* request,
vtkInformationVector** inputVector,
vtkInformationVector* outputVector)
{
if(request->Has(vtkStreamingDemandDrivenPipeline::REQUEST_UPDATE_EXTENT()))
{
// we must set the extent on the input
vtkInformation* outInfo = outputVector->GetInformationObject(0);
// get the requested update extent
int outExt[6];
outInfo->Get(vtkStreamingDemandDrivenPipeline::UPDATE_EXTENT(), outExt);
// setup the inputs update extent
int inExt[6] = {0, -1, 0, -1, 0, -1};
vtkExtentTranslator *translator = this->GetExtentTranslator();
translator->SetWholeExtent(outExt);
translator->SetNumberOfPieces(this->NumberOfStreamDivisions);
translator->SetPiece(this->CurrentDivision);
if (translator->PieceToExtentByPoints())
{
translator->GetExtent(inExt);
}
inputVector[0]->GetInformationObject(0)
->Set(vtkStreamingDemandDrivenPipeline::UPDATE_EXTENT(), inExt, 6);
return 1;
}
// generate the data
else if(request->Has(vtkDemandDrivenPipeline::REQUEST_DATA()))
{
// get the output data object
vtkInformation* outInfo = outputVector->GetInformationObject(0);
vtkImageData *output =
vtkImageData::SafeDownCast(outInfo->Get(vtkDataObject::DATA_OBJECT()));
// is this the first request
if (!this->CurrentDivision)
{
// Tell the pipeline to start looping.
request->Set(vtkStreamingDemandDrivenPipeline::CONTINUE_EXECUTING(), 1);
this->AllocateOutputData(output);
}
// actually copy the data
vtkInformation* inInfo = inputVector[0]->GetInformationObject(0);
vtkImageData *input =
vtkImageData::SafeDownCast(inInfo->Get(vtkDataObject::DATA_OBJECT()));
int inExt[6];
inInfo->Get(vtkStreamingDemandDrivenPipeline::UPDATE_EXTENT(), inExt);
output->CopyAndCastFrom(input, inExt);
// update the progress
this->UpdateProgress(
(float)(this->CurrentDivision+1.0)/(float)this->NumberOfStreamDivisions);
this->CurrentDivision++;
if (this->CurrentDivision == this->NumberOfStreamDivisions)
{
// Tell the pipeline to stop looping.
request->Remove(vtkStreamingDemandDrivenPipeline::CONTINUE_EXECUTING());
this->CurrentDivision = 0;
}
return 1;
}
return this->Superclass::ProcessRequest(request, inputVector, outputVector);
}