VTK
vtkCompositePolyDataMapper2.h
Go to the documentation of this file.
1 /*=========================================================================
2 
3  Program: Visualization Toolkit
4  Module: vtkCompositePolyDataMapper2.h
5 
6  Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
7  All rights reserved.
8  See Copyright.txt or http://www.kitware.com/Copyright.htm for details.
9 
10  This software is distributed WITHOUT ANY WARRANTY; without even
11  the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
12  PURPOSE. See the above copyright notice for more information.
13 
14 =========================================================================*/
31 #ifndef vtkCompositePolyDataMapper2_h
32 #define vtkCompositePolyDataMapper2_h
33 
34 #include "vtkRenderingOpenGL2Module.h" // For export macro
36 
37 class VTKRENDERINGOPENGL2_EXPORT vtkCompositePolyDataMapper2 : public vtkGenericCompositePolyDataMapper2
38 {
39 public:
42  void PrintSelf(ostream& os, vtkIndent indent);
43 
45  virtual void Render(vtkRenderer *ren, vtkActor *act);
46 
47  virtual void RenderPiece(vtkRenderer *ren, vtkActor *act);
48  virtual void RenderPieceDraw(vtkRenderer *ren, vtkActor *act);
49  virtual void RenderEdges(vtkRenderer *ren, vtkActor *act);
50 
51 protected:
54 
56 
58  virtual void ReplaceShaderColor(
59  std::map<vtkShader::Type, vtkShader *> shaders,
60  vtkRenderer *ren, vtkActor *act);
62 
64 
65  virtual void BuildBufferObjects(vtkRenderer *ren, vtkActor *act);
66  virtual void AppendOneBufferObject(vtkRenderer *ren,
67  vtkActor *act, vtkPolyData *pd, unsigned int flat_index,
68  std::vector<unsigned char> &colors,
69  std::vector<float> &norms);
71 
72  std::vector<unsigned int> VertexOffsets;
73  std::vector<unsigned int> IndexOffsets;
74  std::vector<unsigned int> IndexArray;
75  std::vector<unsigned int> EdgeIndexArray;
76  std::vector<unsigned int> EdgeIndexOffsets;
77  unsigned int MaximumFlatIndex;
78 
80  {
81  public:
82  unsigned int StartVertex;
83  unsigned int StartIndex;
84  unsigned int StartEdgeIndex;
85  unsigned int EndVertex;
86  unsigned int EndIndex;
87  unsigned int EndEdgeIndex;
88  double Opacity;
90  bool Visibility;
92  unsigned int PickId;
93  };
94 
95  std::vector<RenderValue> RenderValues;
97 
98  bool UseGeneric; // use the generic render
100 
101  // free up memory
102  void FreeStructures();
103 
104  void BuildRenderValues(vtkRenderer *renderer,
105  vtkActor *actor,
106  vtkDataObject *dobj,
107  unsigned int &flat_index,
108  unsigned int &lastVertex,
109  unsigned int &lastIndex,
110  unsigned int &lastEdgeIndex);
111 
113 
119  virtual int CanUseTextureMapForColoring(vtkDataObject* input);
123 
124 private:
126  const vtkCompositePolyDataMapper2&); // Not implemented.
127  void operator=(const vtkCompositePolyDataMapper2&); // Not implemented.
128 };
129 
130 #endif
virtual void RenderPieceDraw(vtkRenderer *ren, vtkActor *act)
std::vector< unsigned int > VertexOffsets
represents an object (geometry & properties) in a rendered scene
Definition: vtkActor.h:50
virtual void RenderEdges(vtkRenderer *ren, vtkActor *act)
std::vector< unsigned int > IndexOffsets
mapper for composite dataset consisting of polygonal data.
mapper for composite dataset consisting of polygonal data.
record modification and/or execution time
Definition: vtkTimeStamp.h:34
abstract specification for renderers
Definition: vtkRenderer.h:63
concrete dataset represents vertices, lines, polygons, and triangle strips
Definition: vtkPolyData.h:83
std::vector< RenderValue > RenderValues
std::vector< unsigned int > EdgeIndexArray
virtual int CanUseTextureMapForColoring(vtkDataObject *input)
std::vector< unsigned int > EdgeIndexOffsets
a simple class to control print indentation
Definition: vtkIndent.h:38
std::vector< unsigned int > IndexArray
void PrintSelf(ostream &os, vtkIndent indent)
virtual void ReplaceShaderColor(std::map< vtkShader::Type, vtkShader * > shaders, vtkRenderer *ren, vtkActor *act)
virtual void RenderPiece(vtkRenderer *ren, vtkActor *a)
virtual void BuildBufferObjects(vtkRenderer *ren, vtkActor *act)
virtual void Render(vtkRenderer *ren, vtkActor *act)
general representation of visualization data
Definition: vtkDataObject.h:64
static vtkGenericCompositePolyDataMapper2 * New()