You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
242 lines
5.8 KiB
C++
242 lines
5.8 KiB
C++
/*=========================================================================
|
|
|
|
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<vtkTooltipItem> 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
|