mirror of
https://github.com/OpenFOAM/ThirdParty-6.git
synced 2025-12-08 06:57:43 +00:00
155 lines
5.6 KiB
C++
155 lines
5.6 KiB
C++
/*=========================================================================
|
|
|
|
Program: ParaView
|
|
Module: vtkUnstructuredGridVolumeRepresentation.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 vtkUnstructuredGridVolumeRepresentation - representation for showing
|
|
// vtkUnstructuredGrid datasets as volumes.
|
|
// .SECTION Description
|
|
// vtkUnstructuredGridVolumeRepresentation is a representation for volume
|
|
// rendering vtkUnstructuredGrid datasets. It simply renders a translucent
|
|
// surface for LOD i.e. interactive rendering.
|
|
|
|
#ifndef vtkUnstructuredGridVolumeRepresentation_h
|
|
#define vtkUnstructuredGridVolumeRepresentation_h
|
|
|
|
#include "vtkPVClientServerCoreRenderingModule.h" //needed for exports
|
|
#include "vtkPVDataRepresentation.h"
|
|
|
|
class vtkColorTransferFunction;
|
|
class vtkOrderedCompositeDistributor;
|
|
class vtkPiecewiseFunction;
|
|
class vtkPolyDataMapper;
|
|
class vtkProjectedTetrahedraMapper;
|
|
class vtkPVCacheKeeper;
|
|
class vtkPVGeometryFilter;
|
|
class vtkPVLODVolume;
|
|
class vtkPVUpdateSuppressor;
|
|
class vtkUnstructuredDataDeliveryFilter;
|
|
class vtkUnstructuredGridVolumeMapper;
|
|
class vtkVolumeProperty;
|
|
class vtkVolumeRepresentationPreprocessor;
|
|
|
|
class VTKPVCLIENTSERVERCORERENDERING_EXPORT vtkUnstructuredGridVolumeRepresentation : public vtkPVDataRepresentation
|
|
{
|
|
public:
|
|
static vtkUnstructuredGridVolumeRepresentation* New();
|
|
vtkTypeMacro(vtkUnstructuredGridVolumeRepresentation, vtkPVDataRepresentation);
|
|
void PrintSelf(ostream& os, vtkIndent indent);
|
|
|
|
// Description:
|
|
// Register a volume mapper with the representation.
|
|
void AddVolumeMapper(const char* name, vtkUnstructuredGridVolumeMapper*);
|
|
|
|
// Description:
|
|
// Set the active volume mapper to use.
|
|
virtual void SetActiveVolumeMapper(const char*);
|
|
vtkUnstructuredGridVolumeMapper* GetActiveVolumeMapper();
|
|
|
|
// 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.
|
|
// Overridden to propagate to the active representation.
|
|
virtual void SetVisibility(bool val);
|
|
|
|
//***************************************************************************
|
|
// Forwarded to vtkVolumeRepresentationPreprocessor
|
|
void SetExtractedBlockIndex(unsigned int index);
|
|
|
|
//***************************************************************************
|
|
// 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 and vtkProperty (when applicable).
|
|
void SetInterpolationType(int val);
|
|
void SetColor(vtkColorTransferFunction* lut);
|
|
void SetScalarOpacity(vtkPiecewiseFunction* pwf);
|
|
void SetScalarOpacityUnitDistance(double val);
|
|
|
|
// Description:
|
|
// Provides access to the actor used by this representation.
|
|
vtkPVLODVolume* GetActor() { return this->Actor; }
|
|
|
|
//BTX
|
|
protected:
|
|
vtkUnstructuredGridVolumeRepresentation();
|
|
~vtkUnstructuredGridVolumeRepresentation();
|
|
|
|
// 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();
|
|
|
|
vtkVolumeRepresentationPreprocessor* Preprocessor;
|
|
vtkPVCacheKeeper* CacheKeeper;
|
|
vtkProjectedTetrahedraMapper* DefaultMapper;
|
|
vtkVolumeProperty* Property;
|
|
vtkPVLODVolume* Actor;
|
|
|
|
vtkPVGeometryFilter* LODGeometryFilter;
|
|
vtkPolyDataMapper* LODMapper;
|
|
double DataBounds[6];
|
|
|
|
private:
|
|
vtkUnstructuredGridVolumeRepresentation(const vtkUnstructuredGridVolumeRepresentation&); // Not implemented
|
|
void operator=(const vtkUnstructuredGridVolumeRepresentation&); // Not implemented
|
|
|
|
class vtkInternals;
|
|
vtkInternals* Internals;
|
|
//ETX
|
|
};
|
|
|
|
#endif
|