VTK  9.1.0
vtkOpenGLPointGaussianMapper.h
Go to the documentation of this file.
1/*=========================================================================
2
3 Program: Visualization Toolkit
4
5 Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
6 All rights reserved.
7 See Copyright.txt or http://www.kitware.com/Copyright.htm for details.
8
9 This software is distributed WITHOUT ANY WARRANTY; without even
10 the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
11 PURPOSE. See the above copyright notice for more information.
12
13=========================================================================*/
22#ifndef vtkOpenGLPointGaussianMapper_h
23#define vtkOpenGLPointGaussianMapper_h
24
26#include "vtkRenderingOpenGL2Module.h" // For export macro
27#include <vector> // for ivar
28
29class vtkOpenGLPointGaussianMapperHelper;
30
31class VTKRENDERINGOPENGL2_EXPORT vtkOpenGLPointGaussianMapper : public vtkPointGaussianMapper
32{
33public:
36 void PrintSelf(ostream& os, vtkIndent indent) override;
37
44
49
53 void Render(vtkRenderer* ren, vtkActor* act) override;
54
60 vtkHardwareSelector* sel, std::vector<unsigned int>& pixeloffsets, vtkProp* prop) override;
61
62protected:
65
66 void ReportReferences(vtkGarbageCollector* collector) override;
67
68 std::vector<vtkOpenGLPointGaussianMapperHelper*> Helpers;
69 vtkOpenGLPointGaussianMapperHelper* CreateHelper();
70 void CopyMapperValuesToHelper(vtkOpenGLPointGaussianMapperHelper* helper);
71
75
76 // unused
77 void RenderPiece(vtkRenderer*, vtkActor*) override {}
78
80
81 // create the table for opacity values
83
84 // create the table for scale values
86
87 float* OpacityTable; // the table
88 double OpacityScale; // used for quick lookups
89 double OpacityOffset; // used for quick lookups
90 float* ScaleTable; // the table
91 double ScaleScale; // used for quick lookups
92 double ScaleOffset; // used for quick lookups
93
100
105
109 void ComputeBounds() override;
110
111 // used by the hardware selector
112 std::vector<std::vector<unsigned int>> PickPixels;
113
114private:
116 void operator=(const vtkOpenGLPointGaussianMapper&) = delete;
117};
118
119#endif
represents an object (geometry & properties) in a rendered scene
Definition: vtkActor.h:155
Superclass for all pipeline executives in VTK.
Definition: vtkExecutive.h:76
Detect and break reference loops.
a simple class to control print indentation
Definition: vtkIndent.h:113
Store vtkAlgorithm input/output information.
draw PointGaussians using imposters
void ProcessSelectorPixelBuffers(vtkHardwareSelector *sel, std::vector< unsigned int > &pixeloffsets, vtkProp *prop) override
allows a mapper to update a selections color buffers Called from a prop which in turn is called from ...
static vtkOpenGLPointGaussianMapper * New()
std::vector< std::vector< unsigned int > > PickPixels
bool HasTranslucentPolygonalGeometry() override
Based on emissive setting.
void Render(vtkRenderer *ren, vtkActor *act) override
This calls RenderPiece (in a for loop if streaming is necessary).
std::vector< vtkOpenGLPointGaussianMapperHelper * > Helpers
vtkOpenGLPointGaussianMapperHelper * CreateHelper()
void ReleaseGraphicsResources(vtkWindow *) override
Release any graphics resources that are being consumed by this mapper.
void RenderPiece(vtkRenderer *, vtkActor *) override
Implemented by sub classes.
void CopyMapperValuesToHelper(vtkOpenGLPointGaussianMapperHelper *helper)
void ComputeBounds() override
Need to loop over the hierarchy to compute bounds.
vtkExecutive * CreateDefaultExecutive() override
We need to override this method because the standard streaming demand driven pipeline may not be what...
~vtkOpenGLPointGaussianMapper() override
void ReportReferences(vtkGarbageCollector *collector) override
void RenderInternal(vtkRenderer *, vtkActor *)
void PrintSelf(ostream &os, vtkIndent indent) override
Methods invoked by print to print information about the object including superclasses.
int FillInputPortInformation(int port, vtkInformation *info) override
Need to define the type of data handled by this mapper.
draw PointGaussians using imposters
abstract superclass for all actors, volumes and annotations
Definition: vtkProp.h:67
abstract specification for renderers
Definition: vtkRenderer.h:173
record modification and/or execution time
Definition: vtkTimeStamp.h:52
window superclass for vtkRenderWindow
Definition: vtkWindow.h:36
@ info
Definition: vtkX3D.h:382
@ port
Definition: vtkX3D.h:453