VTK
vtkTanglegramItem.h
Go to the documentation of this file.
1 /*=========================================================================
2 
3  Program: Visualization Toolkit
4  Module: TestDiagram.cxx
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 =========================================================================*/
32 #ifndef vtkTanglegramItem_h
33 #define vtkTanglegramItem_h
34 
35 #include "vtkViewsInfovisModule.h" // For export macro
36 
37 #include "vtkContextItem.h"
38 #include "vtkSmartPointer.h" // For SmartPointer ivars
39 #include "vtkTable.h" // For get/set
40 
41 class vtkDendrogramItem;
42 class vtkLookupTable;
43 class vtkStringArray;
44 class vtkTree;
45 
46 class VTKVIEWSINFOVIS_EXPORT vtkTanglegramItem : public vtkContextItem
47 {
48 public:
49  static vtkTanglegramItem *New();
51  void PrintSelf(ostream &os, vtkIndent indent) override;
52 
56  virtual void SetTree1(vtkTree *tree);
57 
61  virtual void SetTree2(vtkTree *tree);
62 
64 
73  vtkTable * GetTable();
74  void SetTable(vtkTable *table);
76 
78 
81  vtkGetStringMacro(Tree1Label);
82  vtkSetStringMacro(Tree1Label);
84 
86 
89  vtkGetStringMacro(Tree2Label);
90  vtkSetStringMacro(Tree2Label);
92 
97  void SetOrientation(int orientation);
98 
102  int GetOrientation();
103 
105 
111  vtkGetMacro(MinimumVisibleFontSize, int);
112  vtkSetMacro(MinimumVisibleFontSize, int);
114 
116 
122  vtkGetMacro(LabelSizeDifference, int);
123  vtkSetMacro(LabelSizeDifference, int);
125 
127 
130  vtkGetMacro(CorrespondenceLineWidth, float);
131  vtkSetMacro(CorrespondenceLineWidth, float);
133 
135 
138  float GetTreeLineWidth();
139  void SetTreeLineWidth(float width);
141 
145  bool Hit(const vtkContextMouseEvent &mouse) override;
146 
151  bool MouseDoubleClickEvent(const vtkContextMouseEvent &event) override;
152 
153 protected:
155  ~vtkTanglegramItem() override;
156 
160  void RefreshBuffers(vtkContext2D *painter);
161 
165  void PositionTree2();
166 
170  void PaintCorrespondenceLines(vtkContext2D *painter);
171 
175  void PaintTreeLabels(vtkContext2D *painter);
176 
181  void ReorderTree();
182 
188  void ReorderTreeAtVertex(vtkIdType parent, vtkTree *tree);
189 
196  double GetPositionScoreForVertex(vtkIdType vertex, vtkTree *tree);
197 
202  void GenerateLookupTable();
203 
207  bool Paint(vtkContext2D *painter) override;
208 
209 private:
214  vtkStringArray *Tree1Names;
215  vtkStringArray *Tree2Names;
216  vtkStringArray *SourceNames;
217  double Tree1Bounds[4];
218  double Tree2Bounds[4];
219  double Spacing;
220  double LabelWidth1;
221  double LabelWidth2;
222  bool PositionSet;
223  bool TreeReordered;
224  char* Tree1Label;
225  char* Tree2Label;
226  int Orientation;
227  int MinimumVisibleFontSize;
228  int LabelSizeDifference;
229  float CorrespondenceLineWidth;
230 
231  vtkTanglegramItem(const vtkTanglegramItem&) = delete;
232  void operator=(const vtkTanglegramItem&) = delete;
233 
234 };
235 
236 #endif
Display two related trees.
A 2D graphics item for rendering a tree as a dendrogram.
base class for items that are part of a vtkContextScene.
virtual bool Paint(vtkContext2D *painter)
Paint event for the item, called whenever the item needs to be drawn.
map scalar values into colors via a lookup table
a vtkAbstractArray subclass for strings
int vtkIdType
Definition: vtkType.h:347
Class for drawing 2D primitives to a graphical context.
Definition: vtkContext2D.h:58
data structure to represent mouse events.
a simple class to control print indentation
Definition: vtkIndent.h:39
void PrintSelf(ostream &os, vtkIndent indent) override
Methods invoked by print to print information about the object including superclasses.
A table, which contains similar-typed columns of data.
Definition: vtkTable.h:68
virtual bool Hit(const vtkContextMouseEvent &mouse)
Return true if the supplied x, y coordinate is inside the item.
static vtkObject * New()
Create an object with Debug turned off, modified time initialized to zero, and reference counting on...
A rooted tree data structure.
Definition: vtkTree.h:60
virtual bool MouseDoubleClickEvent(const vtkContextMouseEvent &mouse)
Mouse button double click event.