VTK
vtkScalarBarActorInternal.h
Go to the documentation of this file.
1 #ifndef vtkScalarBarActorInternal_h
2 #define vtkScalarBarActorInternal_h
3 // VTK-HeaderTest-Exclude: vtkScalarBarActorInternal.h
4 
5 #include "vtkColor.h" // for AnnotationColors, LabelColorMap, and tuples
6 #include "vtkSmartPointer.h" // for "smart vectors"
7 #include "vtkStdString.h" // for LabelMap
8 
9 #include <map>
10 #include <vector>
11 
12 class vtkActor2D;
13 class vtkCellArray;
14 class vtkTextActor;
15 class vtkPoints;
16 class vtkPolyData;
19 
21 template<class T>
22 class vtkSmartVector : public std::vector<vtkSmartPointer<T> >
23 {
24 public:
29  {
30  // NB: This is relatively evil. But much cheaper than copying the array.
31  // It assumes the compiler won't pad the class.
32  return reinterpret_cast<T**>(&((*this)[0]));
33  }
34 };
35 
38 {
41 
50 };
51 
54 {
55 public:
57  {
58  this->Viewport = 0;
59  this->SwatchColors = 0;
60  this->SwatchPts = 0;
61  this->Polys = 0;
62  this->AnnotationBoxes = 0;
63  this->AnnotationBoxesMapper = 0;
64  this->AnnotationBoxesActor = 0;
65  this->AnnotationLeaders = 0;
66  this->AnnotationLeadersMapper = 0;
67  this->AnnotationLeadersActor = 0;
68  this->NanSwatch = 0;
69  this->NanSwatchMapper = 0;
70  this->NanSwatchActor = 0;
71  }
72 
73  // Define types for smart vectors containing various base classes.
75 
76  // Other vector container types.
77  typedef std::vector<double> DoubleVector;
78  typedef std::vector<vtkColor3ub> ColorVector;
79 
86 
88  double NanSwatchSize;
89 
91  double SwatchPad;
92 
95  int NumNotes;
96 
99  int NumColors;
100 
104 
107  int TL[2]; // VERTICAL => TL={0,1}, HORIZONTAL => TL={1,0}, Size[TL[0]] == width, Size[TL[1]] == height
108 
111 
114 
117 
120 
123 
126 
130 
133 
135  std::map<double,vtkStdString> Labels;
136 
139  std::map<double,vtkColor3ub> LabelColors;
141 
143 
144  ActorVector TextActors;
151  ActorVector AnnotationLabels;
152  DoubleVector AnnotationAnchors;
153  ColorVector AnnotationColors;
158 };
159 
160 #endif // vtkScalarBarActorInternal_h
vtkTuple< int, 2 > Size
Size of the box, stored as (thickness, length) not (width, height).
std::vector< vtkColor3ub > ColorVector
vtkTuple< int, 2 > Posn
The position of the box in viewport (pixel) coordinates.
vtkScalarBarBox TitleBox
The bounding box of the scalar bar title text.
vtkScalarBarBox Frame
The bounding box of the entire scalar bar frame.
ActorVector AnnotationLabels
Cache of classes holding geometry assembled and ready for rendering.
std::vector< double > DoubleVector
DoubleVector AnnotationAnchors
Cache of classes holding geometry assembled and ready for rendering.
abstract specification for Viewports
Definition: vtkViewport.h:46
vtkViewport * Viewport
Cache of dimensions fixed during geometry assembly.
vtkPolyData * AnnotationBoxes
Cache of classes holding geometry assembled and ready for rendering.
vtkActor2D * AnnotationBoxesActor
Cache of classes holding geometry assembled and ready for rendering.
vtkScalarBarBox ScalarBarBox
The bounding box of the scalar bar (excluding NaN swatch)
a actor that draws 2D data
Definition: vtkActor2D.h:44
Internal state for the scalar bar actor shared with subclasses.
vtkPolyDataMapper2D * NanSwatchMapper
Cache of classes holding geometry assembled and ready for rendering.
ColorVector AnnotationColors
Cache of classes holding geometry assembled and ready for rendering.
vtkScalarBarBox NanBox
The bounding box of the NaN swatch.
concrete dataset represents vertices, lines, polygons, and triangle strips
Definition: vtkPolyData.h:84
vtkPolyData * NanSwatch
Cache of classes holding geometry assembled and ready for rendering.
T ** PointerArray()
Convert to an array of "dumb" pointers for functions that need a contiguous array pointer as input...
int NumColors
Number of color swatches to draw for either the continuous or categorical scalar bar, not including a NaN swatch.
An actor that displays text. Scaled or unscaled.
Definition: vtkTextActor.h:54
int NumNotes
Number of annotated values (at least lut->GetNumberOfAnnotatedValues(), but maybe more) ...
A vector of smart pointers.
std::map< double, vtkColor3ub > LabelColors
Map from viewport coordinates to the leader line color of each annotation.
vtkPolyData * AnnotationLeaders
Cache of classes holding geometry assembled and ready for rendering.
dynamic, self-adjusting array of unsigned char
int TL[2]
Permutation of (0, 1) that transforms thickness,length into width,height.
object to represent cell connectivity
Definition: vtkCellArray.h:49
vtkPolyDataMapper2D * AnnotationBoxesMapper
Cache of classes holding geometry assembled and ready for rendering.
double SwatchPad
Space in pixels between swatches when in indexed lookup mode.
vtkUnsignedCharArray * SwatchColors
Colors of swatches in Polys.
double NanSwatchSize
The thickness and length of the (square) NaN swatch.
ActorVector TextActors
Cache of classes holding geometry assembled and ready for rendering.
vtkPolyDataMapper2D * AnnotationLeadersMapper
Cache of classes holding geometry assembled and ready for rendering.
vtkActor2D * NanSwatchActor
Cache of classes holding geometry assembled and ready for rendering.
vtkPoints * SwatchPts
Point coordinates for the scalar bar actor.
A structure to represent pixel coordinates for text or swatch bounds.
std::map< double, vtkStdString > Labels
Map from viewport coordinates to label text of each annotation.
vtkCellArray * Polys
Cells representing color swatches (for the scalar bar actor)
int NumSwatches
Either NumColors or NumColors + 1, depending on whether the NaN swatch is to be drawn.
vtkActor2D * AnnotationLeadersActor
Cache of classes holding geometry assembled and ready for rendering.
draw vtkPolyData onto the image plane
represent and manipulate 3D points
Definition: vtkPoints.h:38
vtkSmartVector< vtkTextActor > ActorVector
vtkScalarBarBox TickBox
The bounding box of tick mark anchor points (tick labels are not fully contained) ...