/*========================================================================= 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. =========================================================================*/ /** * @class vtkChartBox * @brief Factory class for drawing box plot charts * * * This defines the interface for a box plot chart. */ #ifndef vtkChartBox_h #define vtkChartBox_h #include "vtkChart.h" #include "vtkChartsCoreModule.h" // For export macro class vtkIdTypeArray; class vtkPlotBox; class vtkStdString; class vtkStringArray; class vtkTooltipItem; class VTKCHARTSCORE_EXPORT vtkChartBox : public vtkChart { public: vtkTypeMacro(vtkChartBox, vtkChart); void PrintSelf(ostream& os, vtkIndent indent) override; /** * Creates a box chart */ static vtkChartBox* 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); void SetColumnVisibility(vtkIdType column, 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); bool GetColumnVisibility(vtkIdType column); //@} /** * Get the input table column id of a column by its name. */ vtkIdType GetColumnId(const vtkStdString& name); //@{ /** * 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); /** * 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 chart Y axis */ virtual vtkAxis* GetYAxis(); /** * Get the column X position by index in the visible set. */ virtual float GetXPosition(int index); /** * Get the number of visible box plots in the current chart. */ virtual vtkIdType GetNumberOfVisibleColumns(); /** * 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); /** * Return true if the supplied x, y coordinate is inside the item. */ bool Hit(const vtkContextMouseEvent& mouse) override; /** * Mouse move event. */ bool MouseMoveEvent(const vtkContextMouseEvent& mouse) override; /** * Mouse button down event */ bool MouseButtonPressEvent(const vtkContextMouseEvent& mouse) override; /** * Mouse button release event. */ bool MouseButtonReleaseEvent(const vtkContextMouseEvent& mouse) override; /** * Set the vtkTooltipItem object that will be displayed by the chart. */ virtual void SetTooltip(vtkTooltipItem* tooltip); /** * Get the vtkTooltipItem object that will be displayed by the chart. */ virtual vtkTooltipItem* GetTooltip(); /** * Set the information passed to the tooltip. */ virtual void SetTooltipInfo(const vtkContextMouseEvent&, const vtkVector2d&, vtkIdType, vtkPlot*, vtkIdType segmentIndex = -1); protected: vtkChartBox(); ~vtkChartBox() 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; /** * A list of the visible columns in the chart. */ vtkStringArray* VisibleColumns; //@{ /** * Index of the selected column in the visible columns list. */ int SelectedColumn; float SelectedColumnDelta; //@} /** * The point cache is marked dirty until it has been initialized. */ vtkTimeStamp BuildTime; /** * 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); /** * 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&) = delete; void operator=(const vtkChartBox&) = delete; }; //@{ /** * 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