VTK
vtkChartBox.h
Go to the documentation of this file.
1 /*=========================================================================
2 
3  Program: Visualization Toolkit
4  Module: vtkChartBox.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 =========================================================================*/
15 
26 #ifndef vtkChartBox_h
27 #define vtkChartBox_h
28 
29 #include "vtkChartsCoreModule.h" // For export macro
30 #include "vtkChart.h"
31 
32 class vtkIdTypeArray;
33 class vtkPlotBox;
34 class vtkStdString;
35 class vtkStringArray;
36 class vtkTooltipItem;
37 
39 {
40 public:
41  vtkTypeMacro(vtkChartBox, vtkChart);
42  virtual void PrintSelf(ostream &os, vtkIndent indent);
43 
45  static vtkChartBox* New();
46 
50  virtual void Update();
51 
54  virtual bool Paint(vtkContext2D *painter);
55 
57 
58  void SetColumnVisibility(const vtkStdString& name, bool visible);
59  void SetColumnVisibility(vtkIdType column, bool visible);
61 
64  void SetColumnVisibilityAll(bool visible);
65 
67 
68  bool GetColumnVisibility(const vtkStdString& name);
69  bool GetColumnVisibility(vtkIdType column);
71 
73  vtkIdType GetColumnId(const vtkStdString& name);
74 
76 
77  vtkGetObjectMacro(VisibleColumns, vtkStringArray);
79 
80  // Index of the selected column in the visible columns list.
81  vtkGetMacro(SelectedColumn, int);
82  vtkSetMacro(SelectedColumn, int);
83 
86  virtual vtkPlot* GetPlot(vtkIdType index);
87 
89  virtual vtkIdType GetNumberOfPlots();
90 
92  virtual vtkAxis* GetYAxis();
93 
95  virtual float GetXPosition(int index);
96 
98  virtual vtkIdType GetNumberOfVisibleColumns();
99 
102  virtual void SetPlot(vtkPlotBox *plot);
103 
104 //BTX
106  virtual bool Hit(const vtkContextMouseEvent &mouse);
107 
109  virtual bool MouseMoveEvent(const vtkContextMouseEvent &mouse);
110 
112  virtual bool MouseButtonPressEvent(const vtkContextMouseEvent &mouse);
113 
115  virtual bool MouseButtonReleaseEvent(const vtkContextMouseEvent &mouse);
116 
117 //ETX
118 
120  virtual void SetTooltip(vtkTooltipItem *tooltip);
121 
123  virtual vtkTooltipItem* GetTooltip();
124 
126 
127  virtual void SetTooltipInfo(const vtkContextMouseEvent &,
128  const vtkVector2d &,
129  vtkIdType, vtkPlot*,
130  vtkIdType segmentIndex = -1);
131 //BTX
132 protected:
133  vtkChartBox();
134  ~vtkChartBox();
136 
138 
139  class Private;
140  Private *Storage;
142 
144 
147 
150 
152 
156 
159 
163 
164  void ResetSelection();
165  void UpdateGeometry(vtkContext2D*);
166  void CalculatePlotTransform();
167  void SwapAxes(int a1, int a2);
168 
170 
173  bool LocatePointInPlots(const vtkContextMouseEvent &mouse,
174  int invokeEvent = -1);
176 
177  int LocatePointInPlot(const vtkVector2f &position,
178  const vtkVector2f &tolerance, vtkVector2f &plotPos,
179  vtkPlot *plot, vtkIdType &segmentIndex);
180 
181 private:
182  vtkChartBox(const vtkChartBox &); // Not implemented.
183  void operator=(const vtkChartBox &); // Not implemented.
184 //ETX
185 };
186 
188 
192 {
196  int Index;
197 };
199 
200 #endif //vtkChartBox_h
Wrapper around std::string to keep symbols short.
Definition: vtkStdString.h:46
vtkIdTypeArray * Selection
Definition: vtkChartBox.h:146
vtkStringArray * VisibleColumns
Definition: vtkChartBox.h:149
virtual bool MouseButtonPressEvent(const vtkContextMouseEvent &mouse)
vtkStdString SeriesName
Definition: vtkChartBox.h:193
vtkVector2f Position
Definition: vtkChartBox.h:194
record modification and/or execution time
Definition: vtkTimeStamp.h:34
a vtkAbstractArray subclass for strings
bool CalculatePlotTransform(vtkAxis *x, vtkAxis *y, vtkTransform2D *transform)
dynamic, self-adjusting array of vtkIdType
virtual void PrintSelf(ostream &os, vtkIndent indent)
int vtkIdType
Definition: vtkType.h:275
bool GeometryValid
Definition: vtkChartBox.h:143
Class for drawing 2D primitives to a graphical context.
Definition: vtkContext2D.h:56
Factory class for drawing 2D charts.
Definition: vtkChart.h:49
takes care of drawing 2D axes
Definition: vtkAxis.h:70
int SelectedColumn
Definition: vtkChartBox.h:153
data structure to represent mouse events.
a simple class to control print indentation
Definition: vtkIndent.h:38
virtual bool MouseButtonReleaseEvent(const vtkContextMouseEvent &mouse)
virtual vtkIdType GetNumberOfPlots()
float SelectedColumnDelta
Definition: vtkChartBox.h:154
Abstract class for 2D plots.
Definition: vtkPlot.h:51
Class for drawing box plots.
Definition: vtkPlotBox.h:40
vtkTimeStamp BuildTime
Definition: vtkChartBox.h:158
virtual bool Paint(vtkContext2D *painter)=0
virtual bool MouseMoveEvent(const vtkContextMouseEvent &mouse)
virtual bool Hit(const vtkContextMouseEvent &mouse)
virtual vtkPlot * GetPlot(vtkIdType index)
takes care of drawing 2D axes
static vtkObject * New()
vtkVector2i ScreenPosition
Definition: vtkChartBox.h:195
vtkSmartPointer< vtkTooltipItem > Tooltip
Definition: vtkChartBox.h:162
virtual void Update()
Factory class for drawing box plot charts.
Definition: vtkChartBox.h:38
#define VTKCHARTSCORE_EXPORT
Private * Storage
Definition: vtkChartBox.h:139