/*========================================================================= Program: Visualization Toolkit Module: vtkChartParallelCoordinates.h Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen All rights reserved. See Copyright.txt or http://www.kitware.com/Copyright.htm for details. This software is distributed WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the above copyright notice for more information. =========================================================================*/ /** * @class vtkChartParallelCoordinates * @brief Factory class for drawing 2D charts * * * This defines the interface for a parallel coordinates chart. */ #ifndef vtkChartParallelCoordinates_h #define vtkChartParallelCoordinates_h #include "vtkChartsCoreModule.h" // For export macro #include "vtkNew.h" // For vtkNew #include "vtkChart.h" class vtkIdTypeArray; class vtkStdString; class vtkStringArray; class vtkPlotParallelCoordinates; class VTKCHARTSCORE_EXPORT vtkChartParallelCoordinates : public vtkChart { public: vtkTypeMacro(vtkChartParallelCoordinates, vtkChart); void PrintSelf(ostream &os, vtkIndent indent) override; /** * Creates a parallel coordinates chart */ static vtkChartParallelCoordinates* New(); /** * Perform any updates to the item that may be necessary before rendering. * The scene should take care of calling this on all items before their * Paint function is invoked. */ void Update() override; /** * Paint event for the chart, called whenever the chart needs to be drawn */ bool Paint(vtkContext2D *painter) override; /** * Set the visibility of the specified column. */ void SetColumnVisibility(const vtkStdString& name, bool visible); /** * Set the visibility of all columns (true will make them all visible, false * will remove all visible columns). */ void SetColumnVisibilityAll(bool visible); /** * Get the visibility of the specified column. */ bool GetColumnVisibility(const vtkStdString& name); /** * Get a list of the columns, and the order in which they are displayed. */ virtual vtkStringArray* GetVisibleColumns(); /** * Set the list of visible columns, and the order in which they will be displayed. */ virtual void SetVisibleColumns(vtkStringArray* visColumns); /** * Get the plot at the specified index, returns null if the index is invalid. */ vtkPlot* GetPlot(vtkIdType index) override; /** * Get the number of plots the chart contains. */ vtkIdType GetNumberOfPlots() override; /** * Get the axis specified by axisIndex. */ vtkAxis* GetAxis(int axisIndex) override; /** * Get the number of axes in the current chart. */ vtkIdType GetNumberOfAxes() override; /** * Request that the chart recalculates the range of its axes. Especially * useful in applications after the parameters of plots have been modified. */ void RecalculateBounds() override; /** * Set plot to use for the chart. Since this type of chart can * only contain one plot, this will replace the previous plot. */ virtual void SetPlot(vtkPlotParallelCoordinates *plot); /** * Return true if the supplied x, y coordinate is inside the item. */ bool Hit(const vtkContextMouseEvent &mouse) override; /** * Mouse enter event. */ bool MouseEnterEvent(const vtkContextMouseEvent &mouse) override; /** * Mouse move event. */ bool MouseMoveEvent(const vtkContextMouseEvent &mouse) override; /** * Mouse leave event. */ bool MouseLeaveEvent(const vtkContextMouseEvent &mouse) override; /** * Mouse button down event */ bool MouseButtonPressEvent(const vtkContextMouseEvent &mouse) override; /** * Mouse button release event. */ bool MouseButtonReleaseEvent(const vtkContextMouseEvent &mouse) override; /** * Mouse wheel event, positive delta indicates forward movement of the wheel. */ bool MouseWheelEvent(const vtkContextMouseEvent &mouse, int delta) override; protected: vtkChartParallelCoordinates(); ~vtkChartParallelCoordinates() override; //@{ /** * Private storage object - where we hide all of our STL objects... */ class Private; Private *Storage; //@} bool GeometryValid; /** * Selected indices for the table the plot is rendering */ vtkIdTypeArray *Selection; /** * Strongly owned internal data for the column visibility. */ vtkNew VisibleColumns; /** * The point cache is marked dirty until it has been initialized. */ vtkTimeStamp BuildTime; void ResetSelection(); bool ResetAxeSelection(int axe); void ResetAxesSelection(); void UpdateGeometry(); void CalculatePlotTransform(); void SwapAxes(int a1, int a2); private: vtkChartParallelCoordinates(const vtkChartParallelCoordinates &) = delete; void operator=(const vtkChartParallelCoordinates &) = delete; }; #endif //vtkChartParallelCoordinates_h