You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
220 lines
7.7 KiB
Plaintext
220 lines
7.7 KiB
Plaintext
/*=========================================================================
|
|
|
|
Program: Visualization Toolkit
|
|
Module: vtkMappedUnstructuredGrid.txx
|
|
|
|
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 "vtkMappedUnstructuredGrid.h"
|
|
|
|
#include "vtkGenericCell.h"
|
|
#include <algorithm>
|
|
|
|
//------------------------------------------------------------------------------
|
|
template <class Implementation, class CellIterator>
|
|
void vtkMappedUnstructuredGrid<Implementation, CellIterator>::PrintSelf(
|
|
ostream& os, vtkIndent indent)
|
|
{
|
|
os << indent << "Implementation:";
|
|
if (this->Impl == nullptr)
|
|
{
|
|
os << " nullptr" << endl;
|
|
}
|
|
else
|
|
{
|
|
os << endl;
|
|
this->Impl->PrintSelf(os, indent.GetNextIndent());
|
|
}
|
|
}
|
|
|
|
//------------------------------------------------------------------------------
|
|
template <class Implementation, class CellIterator>
|
|
void vtkMappedUnstructuredGrid<Implementation, CellIterator>::CopyStructure(vtkDataSet* ds)
|
|
{
|
|
if (ThisType* grid = ThisType::SafeDownCast(ds))
|
|
{
|
|
this->SetImplementation(grid->GetImplementation());
|
|
}
|
|
|
|
this->Superclass::CopyStructure(ds);
|
|
}
|
|
|
|
//------------------------------------------------------------------------------
|
|
template <class Implementation, class CellIterator>
|
|
void vtkMappedUnstructuredGrid<Implementation, CellIterator>::ShallowCopy(vtkDataObject* src)
|
|
{
|
|
if (ThisType* grid = ThisType::SafeDownCast(src))
|
|
{
|
|
this->SetImplementation(grid->GetImplementation());
|
|
}
|
|
|
|
this->Superclass::ShallowCopy(src);
|
|
}
|
|
|
|
//------------------------------------------------------------------------------
|
|
template <class Implementation, class CellIterator>
|
|
vtkIdType vtkMappedUnstructuredGrid<Implementation, CellIterator>::GetNumberOfCells()
|
|
{
|
|
return this->Impl->GetNumberOfCells();
|
|
}
|
|
|
|
//------------------------------------------------------------------------------
|
|
template <class Implementation, class CellIterator>
|
|
vtkCell* vtkMappedUnstructuredGrid<Implementation, CellIterator>::GetCell(vtkIdType cellId)
|
|
{
|
|
this->GetCell(cellId, this->TempCell);
|
|
return this->TempCell;
|
|
}
|
|
|
|
//------------------------------------------------------------------------------
|
|
template <class Implementation, class CellIterator>
|
|
void vtkMappedUnstructuredGrid<Implementation, CellIterator>::GetCell(
|
|
vtkIdType cellId, vtkGenericCell* cell)
|
|
{
|
|
cell->SetCellType(this->Impl->GetCellType(cellId));
|
|
this->Impl->GetCellPoints(cellId, cell->PointIds);
|
|
this->Points->GetPoints(cell->PointIds, cell->Points);
|
|
|
|
if (cell->RequiresInitialization())
|
|
{
|
|
cell->Initialize();
|
|
}
|
|
}
|
|
|
|
//------------------------------------------------------------------------------
|
|
template <class Implementation, class CellIterator>
|
|
int vtkMappedUnstructuredGrid<Implementation, CellIterator>::GetCellType(vtkIdType cellId)
|
|
{
|
|
return this->Impl->GetCellType(cellId);
|
|
}
|
|
|
|
//------------------------------------------------------------------------------
|
|
template <class Implementation, class CellIterator>
|
|
void vtkMappedUnstructuredGrid<Implementation, CellIterator>::GetCellPoints(
|
|
vtkIdType cellId, vtkIdList* ptIds)
|
|
{
|
|
this->Impl->GetCellPoints(cellId, ptIds);
|
|
}
|
|
|
|
//------------------------------------------------------------------------------
|
|
template <class Implementation, class CellIterator>
|
|
vtkCellIterator* vtkMappedUnstructuredGrid<Implementation, CellIterator>::NewCellIterator()
|
|
{
|
|
CellIteratorType* cellIterator = CellIteratorType::New();
|
|
cellIterator->SetMappedUnstructuredGrid(this);
|
|
return cellIterator;
|
|
}
|
|
|
|
//------------------------------------------------------------------------------
|
|
template <class Implementation, class CellIterator>
|
|
void vtkMappedUnstructuredGrid<Implementation, CellIterator>::GetPointCells(
|
|
vtkIdType ptId, vtkIdList* cellIds)
|
|
{
|
|
this->Impl->GetPointCells(ptId, cellIds);
|
|
}
|
|
|
|
//------------------------------------------------------------------------------
|
|
template <class Implementation, class CellIterator>
|
|
int vtkMappedUnstructuredGrid<Implementation, CellIterator>::GetMaxCellSize()
|
|
{
|
|
return this->Impl->GetMaxCellSize();
|
|
}
|
|
|
|
//------------------------------------------------------------------------------
|
|
template <class Implementation, class CellIterator>
|
|
void vtkMappedUnstructuredGrid<Implementation, CellIterator>::GetIdsOfCellsOfType(
|
|
int type, vtkIdTypeArray* array)
|
|
{
|
|
this->Impl->GetIdsOfCellsOfType(type, array);
|
|
}
|
|
|
|
//------------------------------------------------------------------------------
|
|
template <class Implementation, class CellIterator>
|
|
int vtkMappedUnstructuredGrid<Implementation, CellIterator>::IsHomogeneous()
|
|
{
|
|
return this->Impl->IsHomogeneous();
|
|
}
|
|
|
|
//------------------------------------------------------------------------------
|
|
template <class Implementation, class CellIterator>
|
|
void vtkMappedUnstructuredGrid<Implementation, CellIterator>::Allocate(vtkIdType numCells, int)
|
|
{
|
|
return this->Impl->Allocate(numCells);
|
|
}
|
|
|
|
//------------------------------------------------------------------------------
|
|
template <class Implementation, class CellIterator>
|
|
vtkIdType vtkMappedUnstructuredGrid<Implementation, CellIterator>::InternalInsertNextCell(
|
|
int type, vtkIdList* ptIds)
|
|
{
|
|
return this->Impl->InsertNextCell(type, ptIds);
|
|
}
|
|
|
|
//------------------------------------------------------------------------------
|
|
template <class Implementation, class CellIterator>
|
|
vtkIdType vtkMappedUnstructuredGrid<Implementation, CellIterator>::InternalInsertNextCell(
|
|
int type, vtkIdType npts, const vtkIdType ptIds[])
|
|
{
|
|
return this->Impl->InsertNextCell(type, npts, ptIds);
|
|
}
|
|
|
|
//------------------------------------------------------------------------------
|
|
template <class Implementation, class CellIterator>
|
|
vtkIdType vtkMappedUnstructuredGrid<Implementation, CellIterator>::InternalInsertNextCell(
|
|
int type, vtkIdType npts, const vtkIdType ptIds[], vtkIdType nfaces, const vtkIdType faces[])
|
|
{
|
|
return this->Impl->InsertNextCell(type, npts, ptIds, nfaces, faces);
|
|
}
|
|
|
|
//------------------------------------------------------------------------------
|
|
template <class Implementation, class CellIterator>
|
|
void vtkMappedUnstructuredGrid<Implementation, CellIterator>::InternalReplaceCell(
|
|
vtkIdType cellId, int npts, const vtkIdType pts[])
|
|
{
|
|
this->Impl->ReplaceCell(cellId, npts, pts);
|
|
}
|
|
|
|
//------------------------------------------------------------------------------
|
|
template <class Implementation, class CellIterator>
|
|
vtkMTimeType vtkMappedUnstructuredGrid<Implementation, CellIterator>::GetMTime()
|
|
{
|
|
return std::max(this->MTime.GetMTime(), this->Impl->GetMTime());
|
|
}
|
|
|
|
//------------------------------------------------------------------------------
|
|
template <class Implementation, class CellIterator>
|
|
vtkMappedUnstructuredGrid<Implementation, CellIterator>::vtkMappedUnstructuredGrid()
|
|
: Impl(nullptr)
|
|
{
|
|
}
|
|
|
|
//------------------------------------------------------------------------------
|
|
template <class Implementation, class CellIterator>
|
|
vtkMappedUnstructuredGrid<Implementation, CellIterator>::~vtkMappedUnstructuredGrid()
|
|
{
|
|
}
|
|
|
|
//------------------------------------------------------------------------------
|
|
template <class Implementation, class CellIterator>
|
|
void vtkMappedUnstructuredGrid<Implementation, CellIterator>::SetImplementation(
|
|
Implementation* impl)
|
|
{
|
|
this->Impl = impl;
|
|
this->Modified();
|
|
}
|
|
|
|
//------------------------------------------------------------------------------
|
|
template <class Implementation, class CellIterator>
|
|
Implementation* vtkMappedUnstructuredGrid<Implementation, CellIterator>::GetImplementation()
|
|
{
|
|
return this->Impl;
|
|
}
|