/*========================================================================= Program: Visualization Toolkit Module: vtkChartBox.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. =========================================================================*/ // .NAME vtkChartBox - Factory class for drawing box plot charts // // .SECTION Description // This defines the interface for a box plot chart. #ifndef vtkChartBox_h #define vtkChartBox_h #include "vtkChartsCoreModule.h" // For export macro #include "vtkChart.h" class vtkIdTypeArray; class vtkPlotBox; class vtkStdString; class vtkStringArray; class vtkTooltipItem; class VTKCHARTSCORE_EXPORT vtkChartBox : public vtkChart { public: vtkTypeMacro(vtkChartBox, vtkChart); virtual void PrintSelf(ostream &os, vtkIndent indent); // Description: // Creates a parallel coordinates chart static vtkChartBox* New(); // Description: // 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. virtual void Update(); // Description: // Paint event for the chart, called whenever the chart needs to be drawn virtual bool Paint(vtkContext2D *painter); // Description: // Set the visibility of the specified column. void SetColumnVisibility(const vtkStdString& name, bool visible); void SetColumnVisibility(vtkIdType column, bool visible); // Description: // Set the visibility of all columns (true will make them all visible, false // will remove all visible columns). void SetColumnVisibilityAll(bool visible); // Description: // Get the visibility of the specified column. bool GetColumnVisibility(const vtkStdString& name); bool GetColumnVisibility(vtkIdType column); // Description: // Get the input table column id of a column by its name. vtkIdType GetColumnId(const vtkStdString& name); // Description: // Get a list of the columns, and the order in which they are displayed. vtkGetObjectMacro(VisibleColumns, vtkStringArray); // Index of the selected column in the visible columns list. vtkGetMacro(SelectedColumn, int); vtkSetMacro(SelectedColumn, int); // Description: // Get the plot at the specified index, returns null if the index is invalid. virtual vtkPlot* GetPlot(vtkIdType index); // Description: // Get the number of plots the chart contains. virtual vtkIdType GetNumberOfPlots(); // Description: // Get the chart Y axis virtual vtkAxis* GetYAxis(); // Description: // Get the column X position by index in the visible set. virtual float GetXPosition(int index); // Description: // Get the number of visible box plots in the current chart. virtual vtkIdType GetNumberOfVisibleColumns(); // Description // 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(vtkPlotBox *plot); //BTX // Description: // Return true if the supplied x, y coordinate is inside the item. virtual bool Hit(const vtkContextMouseEvent &mouse); // Description: // Mouse move event. virtual bool MouseMoveEvent(const vtkContextMouseEvent &mouse); // Description: // Mouse button down event virtual bool MouseButtonPressEvent(const vtkContextMouseEvent &mouse); // Description: // Mouse button release event. virtual bool MouseButtonReleaseEvent(const vtkContextMouseEvent &mouse); //ETX // Description: // Set the vtkTooltipItem object that will be displayed by the chart. virtual void SetTooltip(vtkTooltipItem *tooltip); // Description: // Get the vtkTooltipItem object that will be displayed by the chart. virtual vtkTooltipItem* GetTooltip(); // Description: // Set the information passed to the tooltip. virtual void SetTooltipInfo(const vtkContextMouseEvent &, const vtkVector2d &, vtkIdType, vtkPlot*, vtkIdType segmentIndex = -1); //BTX protected: vtkChartBox(); ~vtkChartBox(); // Description: // Private storage object - where we hide all of our STL objects... class Private; Private *Storage; bool GeometryValid; // Description: // Selected indices for the table the plot is rendering vtkIdTypeArray *Selection; // Description: // A list of the visible columns in the chart. vtkStringArray *VisibleColumns; // Description: // Index of the selected column in the visible columns list. int SelectedColumn; float SelectedColumnDelta; // Description: // The point cache is marked dirty until it has been initialized. vtkTimeStamp BuildTime; // Description: // The tooltip item for the chart - can be used to display extra information. vtkSmartPointer Tooltip; void ResetSelection(); void UpdateGeometry(vtkContext2D*); void CalculatePlotTransform(); void SwapAxes(int a1, int a2); // Description: // Try to locate a point within the plots to display in a tooltip. // If invokeEvent is greater than 0, then an event will be invoked if a point // is at that mouse position. bool LocatePointInPlots(const vtkContextMouseEvent &mouse, int invokeEvent = -1); int LocatePointInPlot(const vtkVector2f &position, const vtkVector2f &tolerance, vtkVector2f &plotPos, vtkPlot *plot, vtkIdType &segmentIndex); private: vtkChartBox(const vtkChartBox &); // Not implemented. void operator=(const vtkChartBox &); // Not implemented. //ETX }; // Description: // Small struct used by InvokeEvent to send some information about the point // that was clicked on. This is an experimental part of the API, subject to // change. struct vtkChartBoxData { vtkStdString SeriesName; vtkVector2f Position; vtkVector2i ScreenPosition; int Index; }; #endif //vtkChartBox_h