VTK
Classes | Public Types | Public Member Functions | Static Public Member Functions | Protected Member Functions | Protected Attributes
vtkChart Class Reference

Factory class for drawing 2D charts. More...

#include <vtkChart.h>

Inheritance diagram for vtkChart:
Inheritance graph
[legend]
Collaboration diagram for vtkChart:
Collaboration graph
[legend]

List of all members.

Classes

class  MouseActions
class  MouseClickActions

Public Types

typedef vtkContextItem Superclass
enum  {
  LINE, POINTS, BAR, STACKED,
  BAG, FUNCTIONALBAG
}
enum  {
  PAN = 0, ZOOM, ZOOM_AXIS, SELECT,
  SELECT_RECTANGLE = SELECT, SELECT_POLYGON, NOTIFY
}
enum  EventIds { UpdateRange = 1002 }
enum  { SELECTION_ROWS, SELECTION_PLOTS }
enum  { FILL_SCENE, FILL_RECT, AXES_TO_RECT }

Public Member Functions

virtual int IsA (const char *type)
vtkChartNewInstance () const
virtual void PrintSelf (ostream &os, vtkIndent indent)
virtual bool Paint (vtkContext2D *painter)=0
virtual vtkPlotAddPlot (int type)
virtual vtkIdType AddPlot (vtkPlot *plot)
virtual bool RemovePlot (vtkIdType index)
virtual bool RemovePlotInstance (vtkPlot *plot)
virtual void ClearPlots ()
virtual vtkPlotGetPlot (vtkIdType index)
virtual vtkIdType GetNumberOfPlots ()
virtual vtkAxisGetAxis (int axisIndex)
virtual vtkIdType GetNumberOfAxes ()
virtual void RecalculateBounds ()
virtual void SetAnnotationLink (vtkAnnotationLink *link)
virtual vtkChartLegendGetLegend ()
void SetBorders (int left, int bottom, int right, int top)
void SetSize (const vtkRectf &rect)
vtkRectf GetSize ()
virtual void SetActionToButton (int action, int button)
virtual int GetActionToButton (int action)
virtual void SetClickActionToButton (int action, int button)
virtual int GetClickActionToButton (int action)
virtual void SetSelectionMethod (int method)
virtual int GetSelectionMethod ()
virtual vtkAnnotationLinkGetAnnotationLink ()
virtual void SetGeometry (int, int)
void SetGeometry (int[2])
virtual intGetGeometry ()
virtual void GetGeometry (int &, int &)
virtual void GetGeometry (int[2])
virtual void SetPoint1 (int, int)
void SetPoint1 (int[2])
virtual intGetPoint1 ()
virtual void GetPoint1 (int &, int &)
virtual void GetPoint1 (int[2])
virtual void SetPoint2 (int, int)
void SetPoint2 (int[2])
virtual intGetPoint2 ()
virtual void GetPoint2 (int &, int &)
virtual void GetPoint2 (int[2])
virtual void SetShowLegend (bool visible)
virtual bool GetShowLegend ()
virtual void SetTitle (const vtkStdString &title)
virtual vtkStdString GetTitle ()
virtual vtkTextPropertyGetTitleProperties ()
void SetBottomBorder (int border)
void SetTopBorder (int border)
void SetLeftBorder (int border)
void SetRightBorder (int border)
virtual void SetLayoutStrategy (int)
virtual int GetLayoutStrategy ()
virtual void SetAutoSize (bool isAutoSized)
virtual bool GetAutoSize ()
virtual void SetRenderEmpty (bool)
virtual bool GetRenderEmpty ()
void SetBackgroundBrush (vtkBrush *brush)
vtkBrushGetBackgroundBrush ()
virtual void SetSelectionMode (int)
virtual int GetSelectionMode ()

Static Public Member Functions

static int IsTypeOf (const char *type)
static vtkChartSafeDownCast (vtkObjectBase *o)

Protected Member Functions

virtual vtkObjectBaseNewInstanceInternal () const
 vtkChart ()
 ~vtkChart ()
void AttachAxisRangeListener (vtkAxis *)
void AxisRangeForwarderCallback (vtkObject *, unsigned long, void *)
bool CalculatePlotTransform (vtkAxis *x, vtkAxis *y, vtkTransform2D *transform)
bool CalculateUnscaledPlotTransform (vtkAxis *x, vtkAxis *y, vtkTransform2D *transform)

Protected Attributes

vtkAnnotationLinkAnnotationLink
int Geometry [2]
int Point1 [2]
int Point2 [2]
bool ShowLegend
vtkStdString Title
vtkTextPropertyTitleProperties
vtkRectf Size
int LayoutStrategy
bool RenderEmpty
vtkSmartPointer< vtkBrushBackgroundBrush
int SelectionMode
int SelectionMethod
MouseActions Actions
MouseClickActions ActionsClick

Detailed Description

Factory class for drawing 2D charts.

This defines the interface for a chart.

Examples:
vtkChart (Examples)
Tests:
vtkChart (Tests)

Definition at line 49 of file vtkChart.h.


Member Typedef Documentation

Reimplemented from vtkContextItem.

Reimplemented in vtkChartXY, vtkChartParallelCoordinates, vtkChartPie, and vtkChartHistogram2D.

Definition at line 52 of file vtkChart.h.


Member Enumeration Documentation

anonymous enum

Enum of the available chart types

Enumerator:
LINE 
POINTS 
BAR 
STACKED 
BAG 
FUNCTIONALBAG 

Definition at line 58 of file vtkChart.h.

anonymous enum

Enum of valid chart action types. PAN - moves the axis range ZOOM - zooms to a selected rectangle ZOOM_AXIS - zooms the x and y axis range SELECT_RECTANGLE - selects points within a rectangle SELECT_POLYGON - selects points within a polygon SELECT - alias for SELECT_RECTANGLE NOTIFY - Post vtkCommand::InteractionEvent on selection of a point

Enumerator:
PAN 
ZOOM 
ZOOM_AXIS 
SELECT 
SELECT_RECTANGLE 
SELECT_POLYGON 
NOTIFY 

Definition at line 74 of file vtkChart.h.

Enum of event type that are triggered by the charts

Enumerator:
UpdateRange 

Definition at line 87 of file vtkChart.h.

anonymous enum

Enumeration of the possible selection methods in a chart. SELECTION_ROWS is the default and simply selects the row in a table in all plots showing that table. SELECTION_PLOTS will make a selection in each plot, and that selection remains specific to the plot object.

Enumerator:
SELECTION_ROWS 
SELECTION_PLOTS 

Definition at line 142 of file vtkChart.h.

anonymous enum

Enum of the available layout strategies for the charts.

Enumerator:
FILL_SCENE 
FILL_RECT 
AXES_TO_RECT 

Definition at line 227 of file vtkChart.h.


Constructor & Destructor Documentation

vtkChart::vtkChart ( ) [protected]
vtkChart::~vtkChart ( ) [protected]

Member Function Documentation

static int vtkChart::IsTypeOf ( const char *  name) [static]

Return 1 if this class type is the same type of (or a subclass of) the named class. Returns 0 otherwise. This method works in combination with vtkTypeMacro found in vtkSetGet.h.

Reimplemented from vtkContextItem.

Reimplemented in vtkChartXY, vtkChartParallelCoordinates, vtkChartPie, and vtkChartHistogram2D.

virtual int vtkChart::IsA ( const char *  name) [virtual]

Return 1 if this class is the same type of (or a subclass of) the named class. Returns 0 otherwise. This method works in combination with vtkTypeMacro found in vtkSetGet.h.

Reimplemented from vtkContextItem.

Reimplemented in vtkChartXY, vtkChartParallelCoordinates, vtkChartPie, and vtkChartHistogram2D.

static vtkChart* vtkChart::SafeDownCast ( vtkObjectBase o) [static]
virtual vtkObjectBase* vtkChart::NewInstanceInternal ( ) const [protected, virtual]
virtual void vtkChart::PrintSelf ( ostream &  os,
vtkIndent  indent 
) [virtual]

Methods invoked by print to print information about the object including superclasses. Typically not called by the user (use Print() instead) but used in the hierarchical print process to combine the output of several classes.

Reimplemented from vtkContextItem.

Reimplemented in vtkChartXY, vtkChartParallelCoordinates, vtkChartPie, and vtkChartHistogram2D.

virtual bool vtkChart::Paint ( vtkContext2D painter) [pure virtual]

Paint event for the chart, called whenever the chart needs to be drawn

Reimplemented from vtkAbstractContextItem.

Implemented in vtkChartXY, vtkChartParallelCoordinates, and vtkChartPie.

virtual vtkPlot* vtkChart::AddPlot ( int  type) [virtual]

Add a plot to the chart, defaults to using the name of the y column

Reimplemented in vtkChartXY, and vtkChartPie.

virtual vtkIdType vtkChart::AddPlot ( vtkPlot plot) [virtual]

Add a plot to the chart. Return the index of the plot, -1 if it failed.

Reimplemented in vtkChartXY, and vtkChartPie.

virtual bool vtkChart::RemovePlot ( vtkIdType  index) [virtual]

Remove the plot at the specified index, returns true if successful, false if the index was invalid.

Reimplemented in vtkChartXY.

virtual bool vtkChart::RemovePlotInstance ( vtkPlot plot) [virtual]

Remove the given plot. Returns true if successful, false if the plot was not contained in this chart. Note, the base implementation of this method performs a linear search to locate the plot.

virtual void vtkChart::ClearPlots ( ) [virtual]

Remove all plots from the chart.

Reimplemented in vtkChartXY.

virtual vtkPlot* vtkChart::GetPlot ( vtkIdType  index) [virtual]

Get the plot at the specified index, returns null if the index is invalid.

Reimplemented in vtkChartXY, vtkChartParallelCoordinates, vtkChartPie, and vtkChartHistogram2D.

virtual vtkIdType vtkChart::GetNumberOfPlots ( ) [virtual]

Get the number of plots the chart contains.

Reimplemented in vtkChartXY, vtkChartParallelCoordinates, and vtkChartPie.

virtual vtkAxis* vtkChart::GetAxis ( int  axisIndex) [virtual]

Get the axis specified by axisIndex. 0 is x, 1 is y. This should probably be improved either using a string or enum to select the axis.

Reimplemented in vtkChartXY, and vtkChartParallelCoordinates.

virtual vtkIdType vtkChart::GetNumberOfAxes ( ) [virtual]

Get the number of axes in the current chart.

Reimplemented in vtkChartXY, and vtkChartParallelCoordinates.

virtual void vtkChart::RecalculateBounds ( ) [virtual]

Request that the chart recalculates the range of its axes. Especially useful in applications after the parameters of plots have been modified.

Reimplemented in vtkChartXY, and vtkChartParallelCoordinates.

virtual void vtkChart::SetSelectionMethod ( int  method) [virtual]

Set the selection method, which controls how selections are handled by the chart. The default is SELECTION_ROWS which selects all points in all plots in a chart that have values in the rows selected. SELECTION_PLOTS allows for finer-grained selections specific to each plot, and so to each XY column pair.

Reimplemented in vtkChartXY.

virtual int vtkChart::GetSelectionMethod ( ) [virtual]

Set the selection method, which controls how selections are handled by the chart. The default is SELECTION_ROWS which selects all points in all plots in a chart that have values in the rows selected. SELECTION_PLOTS allows for finer-grained selections specific to each plot, and so to each XY column pair.

virtual void vtkChart::SetAnnotationLink ( vtkAnnotationLink link) [virtual]

Set the vtkAnnotationLink for the chart.

Get the vtkAnnotationLink for the chart.

virtual void vtkChart::SetGeometry ( int  ,
int   
) [virtual]

Set/get the width and the height of the chart.

void vtkChart::SetGeometry ( int  [2])

Set/get the width and the height of the chart.

virtual int* vtkChart::GetGeometry ( ) [virtual]

Set/get the width and the height of the chart.

virtual void vtkChart::GetGeometry ( int ,
int  
) [virtual]

Set/get the width and the height of the chart.

virtual void vtkChart::GetGeometry ( int  [2]) [virtual]

Set/get the width and the height of the chart.

virtual void vtkChart::SetPoint1 ( int  ,
int   
) [virtual]

Set/get the first point in the chart (the bottom left).

void vtkChart::SetPoint1 ( int  [2])

Set/get the first point in the chart (the bottom left).

virtual int* vtkChart::GetPoint1 ( ) [virtual]

Set/get the first point in the chart (the bottom left).

virtual void vtkChart::GetPoint1 ( int ,
int  
) [virtual]

Set/get the first point in the chart (the bottom left).

virtual void vtkChart::GetPoint1 ( int  [2]) [virtual]

Set/get the first point in the chart (the bottom left).

virtual void vtkChart::SetPoint2 ( int  ,
int   
) [virtual]

Set/get the second point in the chart (the top right).

void vtkChart::SetPoint2 ( int  [2])

Set/get the second point in the chart (the top right).

virtual int* vtkChart::GetPoint2 ( ) [virtual]

Set/get the second point in the chart (the top right).

virtual void vtkChart::GetPoint2 ( int ,
int  
) [virtual]

Set/get the second point in the chart (the top right).

virtual void vtkChart::GetPoint2 ( int  [2]) [virtual]

Set/get the second point in the chart (the top right).

virtual void vtkChart::SetShowLegend ( bool  visible) [virtual]

Set/get whether the chart should draw a legend.

Reimplemented in vtkChartXY, and vtkChartPie.

virtual bool vtkChart::GetShowLegend ( ) [virtual]

Set/get whether the chart should draw a legend.

virtual vtkChartLegend* vtkChart::GetLegend ( ) [virtual]

Get the legend for the chart, if available. Can return NULL if there is no legend.

Reimplemented in vtkChartXY, and vtkChartPie.

virtual void vtkChart::SetTitle ( const vtkStdString title) [virtual]

Get/set the title text of the chart.

virtual vtkStdString vtkChart::GetTitle ( ) [virtual]

Get/set the title text of the chart.

Get the vtkTextProperty that governs how the chart title is displayed.

void vtkChart::SetBottomBorder ( int  border)

Set/get the borders of the chart (space in pixels around the chart).

void vtkChart::SetTopBorder ( int  border)

Set/get the borders of the chart (space in pixels around the chart).

void vtkChart::SetLeftBorder ( int  border)

Set/get the borders of the chart (space in pixels around the chart).

void vtkChart::SetRightBorder ( int  border)

Set/get the borders of the chart (space in pixels around the chart).

void vtkChart::SetBorders ( int  left,
int  bottom,
int  right,
int  top 
)

Set/get the borders of the chart (space in pixels around the chart).

void vtkChart::SetSize ( const vtkRectf rect)

Set the size of the chart. The rect argument specifies the bottom corner, width and height of the chart. The borders will be laid out within the specified rectangle.

Get the current size of the chart.

virtual void vtkChart::SetLayoutStrategy ( int  ) [virtual]

Set/get the layout strategy that should be used by the chart. As we don't support enums this can take any value in the integer range, but the only valid enums are FILL_SCENE, FILL_RECT and AXES_TO_RECT.

virtual int vtkChart::GetLayoutStrategy ( ) [virtual]

Set/get the layout strategy that should be used by the chart. As we don't support enums this can take any value in the integer range, but the only valid enums are FILL_SCENE, FILL_RECT and AXES_TO_RECT.

virtual void vtkChart::SetAutoSize ( bool  isAutoSized) [inline, virtual]

Set/get whether the chart should automatically resize to fill the current render window. Default is true.

Definition at line 245 of file vtkChart.h.

virtual bool vtkChart::GetAutoSize ( ) [inline, virtual]

Set/get whether the chart should automatically resize to fill the current render window. Default is true.

Definition at line 250 of file vtkChart.h.

virtual void vtkChart::SetRenderEmpty ( bool  ) [virtual]

Set/get whether the chart should still render its axes and decorations even if the chart has no visible plots. Default is false (do not render an empty plot). Note that if you wish to render axes for an empty plot you should also set AutoSize to false, as that will hide all axes for an empty plot.

virtual bool vtkChart::GetRenderEmpty ( ) [virtual]

Set/get whether the chart should still render its axes and decorations even if the chart has no visible plots. Default is false (do not render an empty plot). Note that if you wish to render axes for an empty plot you should also set AutoSize to false, as that will hide all axes for an empty plot.

virtual void vtkChart::SetActionToButton ( int  action,
int  button 
) [virtual]

Assign action types to mouse buttons. Available action types are PAN, ZOOM and SELECT in the chart enum, the default assigns the LEFT_BUTTON to PAN, MIDDLE_BUTTON to ZOOM and RIGHT_BUTTON to SELECT. Valid mouse enums are in the vtkContextMouseEvent class. Note that only one mouse button can be assigned to each action, an action will have -1 (invalid button) assigned if it had the same button as the one assigned to a different action.

virtual int vtkChart::GetActionToButton ( int  action) [virtual]

Get the mouse button associated with the supplied action. The mouse button enum is from vtkContextMouseEvent, and the action enum is from vtkChart.

virtual void vtkChart::SetClickActionToButton ( int  action,
int  button 
) [virtual]

Assign action types to single mouse clicks. Available action types are SELECT and NOTIFY in the chart enum. The default assigns the LEFT_BUTTON to NOTIFY, and the RIGHT_BUTTON to SELECT.

virtual int vtkChart::GetClickActionToButton ( int  action) [virtual]

Get the mouse button associated with the supplied click action. The mouse button enum is from vtkContextMouseEvent, and the action enum is from vtkChart.

Set/Get the brush to use for the background color.

Set/Get the brush to use for the background color.

virtual void vtkChart::SetSelectionMode ( int  ) [virtual]

Set/get the Selection Mode that will be used by the chart while doing selection. The only valid enums are vtkContextScene::SELECTION_NONE, SELECTION_DEFAULT, SELECTION_ADDITION, SELECTION_SUBTRACTION, SELECTION_TOGGLE

virtual int vtkChart::GetSelectionMode ( ) [virtual]

Set/get the Selection Mode that will be used by the chart while doing selection. The only valid enums are vtkContextScene::SELECTION_NONE, SELECTION_DEFAULT, SELECTION_ADDITION, SELECTION_SUBTRACTION, SELECTION_TOGGLE

bool vtkChart::CalculatePlotTransform ( vtkAxis x,
vtkAxis y,
vtkTransform2D transform 
) [protected]

Given the x and y vtkAxis, and a transform, calculate the transform that the points in a chart would need to be drawn within the axes. This assumes that the axes have the correct start and end positions, and that they are perpendicular.

bool vtkChart::CalculateUnscaledPlotTransform ( vtkAxis x,
vtkAxis y,
vtkTransform2D transform 
) [protected]

Calculate the unshifted, and unscaled plot transform for the x and y axis.

void vtkChart::AttachAxisRangeListener ( vtkAxis ) [protected]

Attach axis range listener so we can forward those events at the chart level

void vtkChart::AxisRangeForwarderCallback ( vtkObject ,
unsigned  long,
void *   
) [protected]

Member Data Documentation

Our annotation link, used for sharing selections etc.

Definition at line 332 of file vtkChart.h.

int vtkChart::Geometry[2] [protected]

The width and the height of the chart.

Definition at line 335 of file vtkChart.h.

int vtkChart::Point1[2] [protected]

The position of the lower left corner of the chart.

Definition at line 338 of file vtkChart.h.

int vtkChart::Point2[2] [protected]

The position of the upper right corner of the chart.

Definition at line 341 of file vtkChart.h.

bool vtkChart::ShowLegend [protected]

Display the legend?

Definition at line 344 of file vtkChart.h.

The title of the chart

Definition at line 347 of file vtkChart.h.

The text properties associated with the chart

Definition at line 350 of file vtkChart.h.

vtkRectf vtkChart::Size [protected]

Definition at line 352 of file vtkChart.h.

Definition at line 354 of file vtkChart.h.

bool vtkChart::RenderEmpty [protected]

Definition at line 355 of file vtkChart.h.

Brush to use for drawing the background.

Definition at line 358 of file vtkChart.h.

Definition at line 361 of file vtkChart.h.

Definition at line 365 of file vtkChart.h.

Definition at line 393 of file vtkChart.h.

Definition at line 394 of file vtkChart.h.


The documentation for this class was generated from the following file: