1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67
|
/*=========================================================================
Program: Visualization Toolkit
Module: vtkProjectedAAHexahedraMapper.cxx
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.
=========================================================================*/
// High quality volume renderer for axis-aligned hexahedra
// Implementation by Stephane Marchesin (stephane.marchesin@gmail.com)
// CEA/DIF - Commissariat a l'Energie Atomique, Centre DAM Ile-De-France
// BP12, F-91297 Arpajon, France.
//
// This file implements the paper
// "High-Quality, Semi-Analytical Volume Rendering for AMR Data",
// Stephane Marchesin and Guillaume Colin de Verdiere, IEEE Vis 2009.
#include "vtkProjectedAAHexahedraMapper.h"
#include "vtkCellCenterDepthSort.h"
#include "vtkGarbageCollector.h"
#include "vtkObjectFactory.h"
// ----------------------------------------------------------------------------
// Return NULL if no override is supplied.
vtkAbstractObjectFactoryNewMacro(vtkProjectedAAHexahedraMapper)
// ----------------------------------------------------------------------------
vtkCxxSetObjectMacro(vtkProjectedAAHexahedraMapper,
VisibilitySort, vtkVisibilitySort);
// ----------------------------------------------------------------------------
vtkProjectedAAHexahedraMapper::vtkProjectedAAHexahedraMapper()
{
this->VisibilitySort = vtkCellCenterDepthSort::New();
}
// ----------------------------------------------------------------------------
vtkProjectedAAHexahedraMapper::~vtkProjectedAAHexahedraMapper()
{
this->SetVisibilitySort(NULL);
}
// ----------------------------------------------------------------------------
void vtkProjectedAAHexahedraMapper::PrintSelf(ostream &os,
vtkIndent indent)
{
this->Superclass::PrintSelf(os, indent);
os << indent << "VisibilitySort: " << this->VisibilitySort << endl;
}
// ----------------------------------------------------------------------------
void vtkProjectedAAHexahedraMapper::ReportReferences(
vtkGarbageCollector *collector)
{
this->Superclass::ReportReferences(collector);
vtkGarbageCollectorReport(collector, this->VisibilitySort, "VisibilitySort");
}
|