vtkPointGaussianRepresentation.h
Go to the documentation of this file.
1 // SPDX-FileCopyrightText: Copyright (c) Kitware Inc.
2 // SPDX-License-Identifier: BSD-3-Clause
10 #ifndef vtkPointGaussianRepresentation_h
11 #define vtkPointGaussianRepresentation_h
12 
14 #include "vtkRemotingViewsModule.h" // needed for exports
15 #include "vtkSmartPointer.h" // needed for smart pointer
16 #include <string> // for std::string
17 #include <vector> // for std::vector
18 
19 class vtkActor;
20 class vtkDataObject;
23 class vtkScalarsToColors;
24 
26 {
27 public:
30  void PrintSelf(ostream& os, vtkIndent indent) override;
31 
33  vtkInformation* outInfo) override;
34 
38  void SetLookupTable(vtkScalarsToColors* lut);
39 
43  void SetVisibility(bool val) override;
44 
48  virtual void SetEmissive(bool val);
49 
54  virtual void SetMapScalars(int val);
55 
56  //***************************************************************************
57  // Forwarded to Actor.
58  virtual void SetOrientation(double, double, double);
59  virtual void SetOrigin(double, double, double);
60  virtual void SetPickable(int val);
61  virtual void SetPosition(double, double, double);
62  virtual void SetScale(double, double, double);
63  virtual void SetCoordinateSystem(int);
64 
65  //***************************************************************************
66  // Forwarded to Actor->GetProperty()
67  virtual void SetAmbientColor(double r, double g, double b);
68  virtual void SetDiffuseColor(double r, double g, double b);
69  virtual void SetEdgeColor(double r, double g, double b);
70  virtual void SetInterpolation(int val);
71  virtual void SetLineWidth(double val);
72  virtual void SetOpacity(double val);
73  virtual void SetPointSize(double val);
74  virtual void SetSpecularColor(double r, double g, double b);
75  virtual void SetSpecularPower(double val);
76 
81  virtual void SetSplatSize(double radius);
82 
87  {
88  GAUSSIAN_BLUR, // This is the default
89  SPHERE, // Points shaded to look (something) like a sphere lit from the view direction
90  BLACK_EDGED_CIRCLE, // Camera facing, flat circle, rimmed in black
91  PLAIN_CIRCLE, // Same as above, but without the black edge
92  TRIANGLE, // Camera facing, flat triangle
93  SQUARE_OUTLINE, // Camera facing, flat square, with empty center
94  CUSTOM, // Custom shader
95  NUMBER_OF_PRESETS // !!! THIS MUST ALWAYS BE THE LAST PRESET ENUM !!!
96  };
97 
101  void SelectShaderPreset(int preset);
102 
106  void SetCustomShader(const char* shaderString);
107 
111  void SetCustomTriangleScale(double scale);
112 
118  void SelectScaleArray(int, int, int, int, const char* name);
119 
123  void SelectScaleArrayComponent(int component);
124 
128  void SetUseScaleFunction(bool enable);
129 
136  void SetScaleTransferFunction(vtkPiecewiseFunction* pwf);
137 
142  void SetOpacityTransferFunction(vtkPiecewiseFunction* pwf);
143 
150  void SelectOpacityArray(int, int, int, int, const char* name);
151 
155  void SelectOpacityArrayComponent(int component);
156 
158 
163  void SetOpacityByArray(bool newVal);
164  vtkGetMacro(OpacityByArray, bool);
165  vtkBooleanMacro(OpacityByArray, bool);
167 
169 
173  void SetScaleByArray(bool newVal);
174  vtkGetMacro(ScaleByArray, bool);
175  vtkBooleanMacro(ScaleByArray, bool);
177 
178 protected:
180  ~vtkPointGaussianRepresentation() override;
181 
182  bool AddToView(vtkView* view) override;
183  bool RemoveFromView(vtkView* view) override;
184 
185  int FillInputPortInformation(int port, vtkInformation* info) override;
187 
188  void UpdateColoringParameters();
189  vtkSetStringMacro(LastScaleArray);
190  vtkSetStringMacro(LastOpacityArray);
191  void InitializeShaderPresets();
192  void UpdateMapperScaleFunction();
193 
198 
200 
204 
208 
210 
211  std::vector<std::string> PresetShaderStrings;
212  std::vector<float> PresetShaderScales;
213 
214 private:
216  void operator=(const vtkPointGaussianRepresentation&) = delete;
217 };
218 
219 #endif // vtkPointGaussianRepresentation_h
vtkSmartPointer< vtkDataObject > ProcessedData
#define VTKREMOTINGVIEWS_EXPORT
vtkPVDataRepresentation adds some ParaView specific API to data representations.
bool AddToView(vtkView *view) override
Making these methods public.
Representation for showing point data as sprites, including gaussian splats, spheres, or some custom shaded representation.
virtual void SetVisibility(bool val)
Get/Set the visibility for this representation.
virtual int ProcessViewRequest(vtkInformationRequestKey *request_type, vtkInformation *inInfo, vtkInformation *outInfo)
vtkAlgorithm::ProcessRequest() equivalent for rendering passes.
virtual int FillInputPortInformation(int port, vtkInformation *info)
ShaderPresets
An enum specifying some preset fragment shaders.
int RequestData(vtkInformation *, vtkInformationVector **, vtkInformationVector *) override
Overridden to invoke vtkCommand::UpdateDataEvent.
vtkSmartPointer< vtkPointGaussianMapper > Mapper
bool RemoveFromView(vtkView *view) override
Making these methods public.
static vtkDataRepresentation * New()
vtkSmartPointer< vtkPiecewiseFunction > ScaleFunction
void PrintSelf(ostream &os, vtkIndent indent) override
std::vector< std::string > PresetShaderStrings