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.

184 lines
5.0 KiB

2 years ago
/*=========================================================================
Program: Visualization Toolkit
Module: $RCSfile: vtkPolyDataMapper.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 "vtkPolyDataMapper.h"
#include "vtkExecutive.h"
#include "vtkGraphicsFactory.h"
#include "vtkInformation.h"
#include "vtkMath.h"
#include "vtkPolyData.h"
#include "vtkRenderWindow.h"
vtkCxxRevisionMacro(vtkPolyDataMapper, "$Revision: 1.38 $");
//----------------------------------------------------------------------------
// Needed when we don't use the vtkStandardNewMacro.
vtkInstantiatorNewMacro(vtkPolyDataMapper);
//----------------------------------------------------------------------------
// return the correct type of PolyDataMapper
vtkPolyDataMapper *vtkPolyDataMapper::New()
{
// First try to create the object from the vtkObjectFactory
vtkObject* ret = vtkGraphicsFactory::CreateInstance("vtkPolyDataMapper");
return (vtkPolyDataMapper*)ret;
}
//----------------------------------------------------------------------------
vtkPolyDataMapper::vtkPolyDataMapper()
{
this->Piece = 0;
this->NumberOfPieces = 1;
this->NumberOfSubPieces = 1;
this->GhostLevel = 0;
}
void vtkPolyDataMapper::Render(vtkRenderer *ren, vtkActor *act)
{
if (this->Static)
{
this->RenderPiece(ren,act);
return;
}
int currentPiece, nPieces;
vtkPolyData *input = this->GetInput();
if (input == NULL)
{
vtkErrorMacro("Mapper has no input.");
return;
}
nPieces = this->NumberOfPieces * this->NumberOfSubPieces;
for(int i=0; i<this->NumberOfSubPieces; i++)
{
// If more than one pieces, render in loop.
currentPiece = this->NumberOfSubPieces * this->Piece + i;
input->SetUpdateExtent(currentPiece, nPieces, this->GhostLevel);
this->RenderPiece(ren, act);
}
}
//----------------------------------------------------------------------------
void vtkPolyDataMapper::SetInput(vtkPolyData *input)
{
if(input)
{
this->SetInputConnection(0, input->GetProducerPort());
}
else
{
// Setting a NULL input removes the connection.
this->SetInputConnection(0, 0);
}
}
//----------------------------------------------------------------------------
// Specify the input data or filter.
vtkPolyData *vtkPolyDataMapper::GetInput()
{
return vtkPolyData::SafeDownCast(
this->GetExecutive()->GetInputData(0, 0));
}
// Update the network connected to this mapper.
void vtkPolyDataMapper::Update()
{
if (this->Static)
{
return;
}
int currentPiece, nPieces = this->NumberOfPieces;
vtkPolyData* input = this->GetInput();
// If the estimated pipeline memory usage is larger than
// the memory limit, break the current piece into sub-pieces.
if (input)
{
currentPiece = this->NumberOfSubPieces * this->Piece;
input->SetUpdateExtent(currentPiece, this->NumberOfSubPieces*nPieces,
this->GhostLevel);
}
this->vtkMapper::Update();
}
// Get the bounds for the input of this mapper as
// (Xmin,Xmax,Ymin,Ymax,Zmin,Zmax).
double *vtkPolyDataMapper::GetBounds()
{
static double bounds[] = {-1.0,1.0, -1.0,1.0, -1.0,1.0};
// do we have an input
if ( ! this->GetNumberOfInputConnections(0))
{
return bounds;
}
else
{
if (!this->Static)
{
this->Update();
this->GetInput()->GetBounds(this->Bounds);
}
// if the bounds indicate NAN and subpieces are being used then
// return NULL
if (!vtkMath::AreBoundsInitialized(this->Bounds)
&& this->NumberOfSubPieces > 1)
{
return NULL;
}
return this->Bounds;
}
}
void vtkPolyDataMapper::ShallowCopy(vtkAbstractMapper *mapper)
{
vtkPolyDataMapper *m = vtkPolyDataMapper::SafeDownCast(mapper);
if ( m != NULL )
{
this->SetInput(m->GetInput());
this->SetGhostLevel(m->GetGhostLevel());
this->SetNumberOfPieces(m->GetNumberOfPieces());
this->SetNumberOfSubPieces(m->GetNumberOfSubPieces());
}
// Now do superclass
this->vtkMapper::ShallowCopy(mapper);
}
void vtkPolyDataMapper::PrintSelf(ostream& os, vtkIndent indent)
{
this->Superclass::PrintSelf(os,indent);
os << indent << "Piece : " << this->Piece << endl;
os << indent << "NumberOfPieces : " << this->NumberOfPieces << endl;
os << indent << "GhostLevel: " << this->GhostLevel << endl;
os << indent << "Number of sub pieces: " << this->NumberOfSubPieces
<< endl;
}
//----------------------------------------------------------------------------
int vtkPolyDataMapper::FillInputPortInformation(
int vtkNotUsed( port ), vtkInformation* info)
{
info->Set(vtkAlgorithm::INPUT_REQUIRED_DATA_TYPE(), "vtkPolyData");
return 1;
}