VTK
vtkPlot.h
Go to the documentation of this file.
1 /*=========================================================================
2 
3  Program: Visualization Toolkit
4  Module: vtkPlot.h
5 
6  Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
7  All rights reserved.
8  See Copyright.txt or http://www.kitware.com/Copyright.htm for details.
9 
10  This software is distributed WITHOUT ANY WARRANTY; without even
11  the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
12  PURPOSE. See the above copyright notice for more information.
13 
14 =========================================================================*/
15 
33 #ifndef vtkPlot_h
34 #define vtkPlot_h
35 
36 #include "vtkChartsCoreModule.h" // For export macro
37 #include "vtkContextItem.h"
38 #include "vtkStdString.h" // Needed to hold TooltipLabelFormat ivar
39 #include "vtkSmartPointer.h" // Needed to hold SP ivars
40 #include "vtkContextPolygon.h" // For vtkContextPolygon
41 #include "vtkRect.h" // For vtkRectd ivar
42 
43 class vtkVariant;
44 class vtkTable;
45 class vtkIdTypeArray;
46 class vtkContextMapper2D;
47 class vtkPen;
48 class vtkBrush;
49 class vtkAxis;
50 class vtkStringArray;
51 
52 class VTKCHARTSCORE_EXPORT vtkPlot : public vtkContextItem
53 {
54 public:
55  vtkTypeMacro(vtkPlot, vtkContextItem);
56  void PrintSelf(ostream &os, vtkIndent indent) override;
57 
59 
64  vtkSetMacro(LegendVisibility, bool);
65  vtkGetMacro(LegendVisibility, bool);
66  vtkBooleanMacro(LegendVisibility, bool);
68 
76  virtual bool PaintLegend(vtkContext2D *painter, const vtkRectf& rect,
77  int legendIndex);
78 
80 
92  virtual void SetTooltipLabelFormat(const vtkStdString &label);
93  virtual vtkStdString GetTooltipLabelFormat();
95 
97 
100  virtual void SetTooltipNotation(int notation);
101  virtual int GetTooltipNotation();
103 
105 
108  virtual void SetTooltipPrecision(int precision);
109  virtual int GetTooltipPrecision();
111 
116  virtual vtkStdString GetTooltipLabel(const vtkVector2d &plotPos,
117  vtkIdType seriesIndex,
118  vtkIdType segmentIndex);
119 
125  virtual vtkIdType GetNearestPoint(const vtkVector2f& point,
126  const vtkVector2f& tolerance,
128 
132  virtual bool SelectPoints(const vtkVector2f& min, const vtkVector2f& max);
133 
137  virtual bool SelectPointsInPolygon(const vtkContextPolygon &polygon);
138 
140 
143  virtual void SetColor(unsigned char r, unsigned char g, unsigned char b,
144  unsigned char a);
145  virtual void SetColor(double r, double g, double b);
146  virtual void GetColor(double rgb[3]);
147  void GetColor(unsigned char rgb[3]);
149 
153  virtual void SetWidth(float width);
154 
158  virtual float GetWidth();
159 
161 
164  void SetPen(vtkPen *pen);
165  vtkPen* GetPen();
167 
169 
172  void SetBrush(vtkBrush *brush);
173  vtkBrush* GetBrush();
175 
177 
181  void SetSelectionPen(vtkPen *pen);
182  vtkPen* GetSelectionPen();
184 
186 
190  void SetSelectionBrush(vtkBrush *brush);
191  vtkBrush* GetSelectionBrush();
193 
197  virtual void SetLabel(const vtkStdString &label);
198 
202  virtual vtkStdString GetLabel();
203 
208  virtual void SetLabels(vtkStringArray *labels);
209 
214  virtual vtkStringArray *GetLabels();
215 
219  virtual int GetNumberOfLabels();
220 
224  vtkStdString GetLabel(vtkIdType index);
225 
231  void SetIndexedLabels(vtkStringArray *labels);
232 
236  virtual vtkStringArray *GetIndexedLabels();
237 
241  vtkContextMapper2D* GetData();
242 
244 
248  vtkGetMacro(UseIndexForXSeries, bool);
250 
252 
256  vtkSetMacro(UseIndexForXSeries, bool);
258 
260 
264  virtual void SetInputData(vtkTable *table);
265  virtual void SetInputData(vtkTable *table, const vtkStdString &xColumn,
266  const vtkStdString &yColumn);
267  void SetInputData(vtkTable *table, vtkIdType xColumn, vtkIdType yColumn);
269 
273  virtual vtkTable* GetInput();
274 
280  virtual void SetInputArray(int index, const vtkStdString &name);
281 
283 
289  vtkSetMacro(Selectable,bool);
290  vtkGetMacro(Selectable,bool);
291  vtkBooleanMacro(Selectable,bool);
293 
295 
300  virtual void SetSelection(vtkIdTypeArray *id);
301  vtkGetObjectMacro(Selection, vtkIdTypeArray);
303 
305 
308  vtkGetObjectMacro(XAxis, vtkAxis);
309  virtual void SetXAxis(vtkAxis* axis);
311 
313 
316  vtkGetObjectMacro(YAxis, vtkAxis);
317  virtual void SetYAxis(vtkAxis* axis);
319 
321 
327  void SetShiftScale(const vtkRectd &scaling);
328  vtkRectd GetShiftScale();
330 
336  virtual void GetBounds(double bounds[4])
337  { bounds[0] = bounds[1] = bounds[2] = bounds[3] = 0.0; }
338 
363  virtual void GetUnscaledInputBounds(double bounds[4])
364  {
365  // Implemented here by calling GetBounds() to support plot
366  // subclasses that do no log-scaling or plot orientation.
367  return this->GetBounds(bounds);
368  }
369 
376  virtual void UpdateCache() {}
377 
379 
383  virtual void SetProperty(const vtkStdString &property, const vtkVariant &var);
384  virtual vtkVariant GetProperty(const vtkStdString &property);
386 
387 protected:
388  vtkPlot();
389  ~vtkPlot() override;
390 
394  vtkStdString GetNumber(double position, vtkAxis *axis);
395 
400 
405 
411 
417 
422 
427 
432 
438 
444 
449 
454 
459 
464 
470 
476 
479 
484 
486 
487 private:
488  vtkPlot(const vtkPlot &) = delete;
489  void operator=(const vtkPlot &) = delete;
490 
491 };
492 
493 #endif //vtkPlot_h
vtkAxis * XAxis
The X axis associated with this plot.
Definition: vtkPlot.h:458
Wrapper around std::string to keep symbols short.
Definition: vtkStdString.h:40
virtual void UpdateCache()
Subclasses that build data caches to speed up painting should override this method to update such cac...
Definition: vtkPlot.h:376
vtkRectd ShiftScale
The current shift in origin and scaling factor applied to the plot.
Definition: vtkPlot.h:483
base class for items that are part of a vtkContextScene.
vtkSmartPointer< vtkStringArray > IndexedLabels
Holds Labels when they&#39;re auto-created.
Definition: vtkPlot.h:431
vtkSmartPointer< vtkBrush > Brush
This object stores the vtkBrush that controls how the plot is drawn.
Definition: vtkPlot.h:404
int TooltipNotation
Definition: vtkPlot.h:477
virtual void GetBounds(double bounds[4])
Get the bounds for this plot as (Xmin, Xmax, Ymin, Ymax).
Definition: vtkPlot.h:336
a vtkAbstractArray subclass for strings
dynamic, self-adjusting array of vtkIdType
int vtkIdType
Definition: vtkType.h:347
bool Selectable
Whether plot points can be selected or not.
Definition: vtkPlot.h:448
int TooltipPrecision
Definition: vtkPlot.h:478
Abstract class for 2D context mappers.
vtkSmartPointer< vtkPen > SelectionPen
This object stores the vtkPen that controls how the selected elements of the plot are drawn...
Definition: vtkPlot.h:410
A atomic type representing the union of many types.
Definition: vtkVariant.h:71
vtkStdString TooltipDefaultLabelFormat
The default printf-style string to build custom tooltip labels from.
Definition: vtkPlot.h:475
vtkIdTypeArray * Selection
Selected indices for the table the plot is rendering.
Definition: vtkPlot.h:453
Class for drawing 2D primitives to a graphical context.
Definition: vtkContext2D.h:58
provides a brush that fills shapes drawn by vtkContext2D.
Definition: vtkBrush.h:40
takes care of drawing 2D axes
Definition: vtkAxis.h:71
a simple class to control print indentation
Definition: vtkIndent.h:39
vtkSmartPointer< vtkBrush > SelectionBrush
This object stores the vtkBrush that controls how the selected elements of the plot are drawn...
Definition: vtkPlot.h:416
vtkSmartPointer< vtkContextMapper2D > Data
This data member contains the data that will be plotted, it inherits from vtkAlgorithm.
Definition: vtkPlot.h:443
void PrintSelf(ostream &os, vtkIndent indent) override
Methods invoked by print to print information about the object including superclasses.
provides a pen that draws the outlines of shapes drawn by vtkContext2D.
Definition: vtkPen.h:39
Abstract class for 2D plots.
Definition: vtkPlot.h:52
vtkSmartPointer< vtkStringArray > Labels
Plot labels, used by legend.
Definition: vtkPlot.h:421
vtkSmartPointer< vtkStringArray > AutoLabels
Holds Labels when they&#39;re auto-created.
Definition: vtkPlot.h:426
A table, which contains similar-typed columns of data.
Definition: vtkTable.h:68
virtual void GetUnscaledInputBounds(double bounds[4])
Provide un-log-scaled bounds for the plot inputs.
Definition: vtkPlot.h:363
vtkAxis * YAxis
The X axis associated with this plot.
Definition: vtkPlot.h:463
bool LegendVisibility
Definition: vtkPlot.h:485
vtkStdString TooltipLabelFormat
A printf-style string to build custom tooltip labels from.
Definition: vtkPlot.h:469
vtkSmartPointer< vtkPen > Pen
This object stores the vtkPen that controls how the plot is drawn.
Definition: vtkPlot.h:399
#define max(a, b)
bool UseIndexForXSeries
Use the Y array index for the X value.
Definition: vtkPlot.h:437