Files
ThirdParty-6/ParaView-5.0.1/ParaViewCore/ClientServerCore/Rendering/vtkImageVolumeRepresentation.h

166 lines
5.8 KiB
C++

/*=========================================================================
Program: ParaView
Module: vtkImageVolumeRepresentation.h
Copyright (c) Kitware, Inc.
All rights reserved.
See Copyright.txt or http://www.paraview.org/HTML/Copyright.html 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.
=========================================================================*/
// .NAME vtkImageVolumeRepresentation - representation for showing image
// datasets as a volume.
// .SECTION Description
// vtkImageVolumeRepresentation is a representation for volume rendering
// vtkImageData. Unlike other data-representations used by ParaView, this
// representation does not support delivery to client (or render server) nodes.
// In those configurations, it merely delivers a outline for the image to the
// client and render-server and those nodes simply render the outline.
#ifndef vtkImageVolumeRepresentation_h
#define vtkImageVolumeRepresentation_h
#include "vtkPVClientServerCoreRenderingModule.h" //needed for exports
#include "vtkPVDataRepresentation.h"
#include "vtkNew.h" // needed for vtkNew.
class vtkColorTransferFunction;
class vtkExtentTranslator;
class vtkFixedPointVolumeRayCastMapper;
class vtkImageData;
class vtkOutlineSource;
class vtkPExtentTranslator;
class vtkPiecewiseFunction;
class vtkPolyDataMapper;
class vtkPVCacheKeeper;
class vtkPVLODVolume;
class vtkSmartVolumeMapper;
class vtkVolumeProperty;
class VTKPVCLIENTSERVERCORERENDERING_EXPORT vtkImageVolumeRepresentation : public vtkPVDataRepresentation
{
public:
static vtkImageVolumeRepresentation* New();
vtkTypeMacro(vtkImageVolumeRepresentation, vtkPVDataRepresentation);
void PrintSelf(ostream& os, vtkIndent indent);
// Description:
// vtkAlgorithm::ProcessRequest() equivalent for rendering passes. This is
// typically called by the vtkView to request meta-data from the
// representations or ask them to perform certain tasks e.g.
// PrepareForRendering.
virtual int ProcessViewRequest(vtkInformationRequestKey* request_type,
vtkInformation* inInfo, vtkInformation* outInfo);
// Description:
// This needs to be called on all instances of vtkGeometryRepresentation when
// the input is modified. This is essential since the geometry filter does not
// have any real-input on the client side which messes with the Update
// requests.
virtual void MarkModified();
// Description:
// Get/Set the visibility for this representation. When the visibility of
// representation of false, all view passes are ignored.
virtual void SetVisibility(bool val);
//***************************************************************************
// Forwarded to Actor.
void SetOrientation(double, double, double);
void SetOrigin(double, double, double);
void SetPickable(int val);
void SetPosition(double, double, double);
void SetScale(double, double, double);
//***************************************************************************
// Forwarded to vtkVolumeProperty.
void SetInterpolationType(int val);
void SetColor(vtkColorTransferFunction* lut);
void SetScalarOpacity(vtkPiecewiseFunction* pwf);
void SetScalarOpacityUnitDistance(double val);
void SetAmbient(double);
void SetDiffuse(double);
void SetSpecular(double);
void SetSpecularPower(double);
void SetShade(bool);
void SetIndependantComponents(bool);
//***************************************************************************
// Forwarded to vtkSmartVolumeMapper.
void SetRequestedRenderMode(int);
// Description:
// Provides access to the actor used by this representation.
vtkPVLODVolume* GetActor() { return this->Actor; }
// Description:
// Helper method to pass input image extent information to the view to use in
// determining the cuts for ordered compositing.
VTK_LEGACY(
static void PassOrderedCompositingInformation(
vtkPVDataRepresentation* self, vtkInformation* inInfo));
//BTX
protected:
vtkImageVolumeRepresentation();
~vtkImageVolumeRepresentation();
// Description:
// Fill input port information.
virtual int FillInputPortInformation(int port, vtkInformation* info);
// Description:
virtual int RequestData(vtkInformation*,
vtkInformationVector**, vtkInformationVector*);
// Description:
// Adds the representation to the view. This is called from
// vtkView::AddRepresentation(). Subclasses should override this method.
// Returns true if the addition succeeds.
virtual bool AddToView(vtkView* view);
// Description:
// Removes the representation to the view. This is called from
// vtkView::RemoveRepresentation(). Subclasses should override this method.
// Returns true if the removal succeeds.
virtual bool RemoveFromView(vtkView* view);
// Description:
// Overridden to check with the vtkPVCacheKeeper to see if the key is cached.
virtual bool IsCached(double cache_key);
// Description:
// Passes on parameters to the active volume mapper
virtual void UpdateMapperParameters();
vtkImageData* Cache;
vtkPVCacheKeeper* CacheKeeper;
vtkSmartVolumeMapper* VolumeMapper;
vtkVolumeProperty* Property;
vtkPVLODVolume* Actor;
vtkOutlineSource* OutlineSource;
vtkPolyDataMapper* OutlineMapper;;
unsigned long DataSize;
double DataBounds[6];
// meta-data about the input image to pass on to render view for hints
// when redistributing data.
vtkNew<vtkPExtentTranslator> PExtentTranslator;
double Origin[3];
double Spacing[3];
int WholeExtent[6];
private:
vtkImageVolumeRepresentation(const vtkImageVolumeRepresentation&); // Not implemented
void operator=(const vtkImageVolumeRepresentation&); // Not implemented
//ETX
};
#endif