VTK  9.2.5
vtkChartParallelCoordinates.h
Go to the documentation of this file.
1 /*=========================================================================
2 
3  Program: Visualization Toolkit
4  Module: vtkChartParallelCoordinates.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 
46 #ifndef vtkChartParallelCoordinates_h
47 #define vtkChartParallelCoordinates_h
48 
49 #include "vtkChart.h"
50 #include "vtkChartsCoreModule.h" // For export macro
51 #include "vtkNew.h" // For vtkNew
52 
53 class vtkIdTypeArray;
54 class vtkStdString;
55 class vtkStringArray;
57 
58 class VTKCHARTSCORE_EXPORT vtkChartParallelCoordinates : public vtkChart
59 {
60 public:
62  void PrintSelf(ostream& os, vtkIndent indent) override;
63 
68 
74  void Update() override;
75 
79  bool Paint(vtkContext2D* painter) override;
80 
84  bool PaintRect(vtkContext2D* painter, int axis, float min, float max);
85 
89  void SetColumnVisibility(const vtkStdString& name, bool visible);
90 
95  void SetColumnVisibilityAll(bool visible);
96 
101 
106 
110  virtual void SetVisibleColumns(vtkStringArray* visColumns);
111 
116 
121 
125  vtkAxis* GetAxis(int axisIndex) override;
126 
131 
136  void RecalculateBounds() override;
137 
142  virtual void SetPlot(vtkPlotParallelCoordinates* plot);
143 
147  bool Hit(const vtkContextMouseEvent& mouse) override;
148 
152  bool MouseEnterEvent(const vtkContextMouseEvent& mouse) override;
153 
157  bool MouseMoveEvent(const vtkContextMouseEvent& mouse) override;
158 
162  bool MouseLeaveEvent(const vtkContextMouseEvent& mouse) override;
163 
167  bool MouseButtonPressEvent(const vtkContextMouseEvent& mouse) override;
168 
172  bool MouseButtonReleaseEvent(const vtkContextMouseEvent& mouse) override;
173 
177  bool MouseWheelEvent(const vtkContextMouseEvent& mouse, int delta) override;
178 
183  void UpdateCurrentAxisSelection(int axisId);
184 
185 protected:
188 
190 
193  struct Private;
194  Private* Storage;
196 
198 
203 
208 
213 
215  void ResetAxeSelection(int axe);
219  void SwapAxes(int a1, int a2);
220 
221 private:
223  void operator=(const vtkChartParallelCoordinates&) = delete;
224 };
225 
226 #endif // vtkChartParallelCoordinates_h
takes care of drawing 2D axes
Definition: vtkAxis.h:181
Factory class for drawing 2D charts.
vtkAxis * GetAxis(int axisIndex) override
Get the axis specified by axisIndex.
bool MouseMoveEvent(const vtkContextMouseEvent &mouse) override
Mouse move event.
vtkNew< vtkStringArray > VisibleColumns
Strongly owned internal data for the column visibility.
virtual void SetVisibleColumns(vtkStringArray *visColumns)
Set the list of visible columns, and the order in which they will be displayed.
vtkPlot * GetPlot(vtkIdType index) override
Get the plot at the specified index, returns null if the index is invalid.
void UpdateCurrentAxisSelection(int axisId)
Update the selection of an axis based on the current selectionMode we have previously set.
vtkTimeStamp BuildTime
The point cache is marked dirty until it has been initialized.
vtkIdType GetNumberOfAxes() override
Get the number of axes in the current chart.
bool GetColumnVisibility(const vtkStdString &name)
Get the visibility of the specified column.
bool Hit(const vtkContextMouseEvent &mouse) override
Return true if the supplied x, y coordinate is inside the item.
void ResetAxeSelection(int axe)
void RecalculateBounds() override
Request that the chart recalculates the range of its axes.
void SetColumnVisibility(const vtkStdString &name, bool visible)
Set the visibility of the specified column.
virtual vtkStringArray * GetVisibleColumns()
Get a list of the columns, and the order in which they are displayed.
bool MouseWheelEvent(const vtkContextMouseEvent &mouse, int delta) override
Mouse wheel event, positive delta indicates forward movement of the wheel.
void SetColumnVisibilityAll(bool visible)
Set the visibility of all columns (true will make them all visible, false will remove all visible col...
bool MouseEnterEvent(const vtkContextMouseEvent &mouse) override
Mouse enter event.
vtkIdTypeArray * Selection
Selected indices for the table the plot is rendering.
vtkIdType GetNumberOfPlots() override
Get the number of plots the chart contains.
bool Paint(vtkContext2D *painter) override
Paint event for the chart, called whenever the chart needs to be drawn.
bool MouseLeaveEvent(const vtkContextMouseEvent &mouse) override
Mouse leave event.
bool MouseButtonReleaseEvent(const vtkContextMouseEvent &mouse) override
Mouse button release event.
bool MouseButtonPressEvent(const vtkContextMouseEvent &mouse) override
Mouse button down event.
virtual void SetPlot(vtkPlotParallelCoordinates *plot)
Set plot to use for the chart.
bool PaintRect(vtkContext2D *painter, int axis, float min, float max)
Draw a rect on a specific axis.
static vtkChartParallelCoordinates * New()
Creates a parallel coordinates chart.
void Update() override
Perform any updates to the item that may be necessary before rendering.
void PrintSelf(ostream &os, vtkIndent indent) override
Methods invoked by print to print information about the object including superclasses.
~vtkChartParallelCoordinates() override
void SwapAxes(int a1, int a2)
Factory class for drawing 2D charts.
Definition: vtkChart.h:52
Class for drawing 2D primitives to a graphical context.
Definition: vtkContext2D.h:77
data structure to represent mouse events.
dynamic, self-adjusting array of vtkIdType
a simple class to control print indentation
Definition: vtkIndent.h:119
Class for drawing a parallel coordinate plot given columns from a vtkTable.
Abstract class for 2D plots.
Definition: vtkPlot.h:163
Wrapper around std::string to keep symbols short.
Definition: vtkStdString.h:108
a vtkAbstractArray subclass for strings
record modification and/or execution time
Definition: vtkTimeStamp.h:55
@ name
Definition: vtkX3D.h:225
@ index
Definition: vtkX3D.h:252
int vtkIdType
Definition: vtkType.h:332
#define max(a, b)