VTK  9.1.0
vtkGraphLayoutView.h
Go to the documentation of this file.
1/*=========================================================================
2
3 Program: Visualization Toolkit
4 Module: vtkGraphLayoutView.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/*-------------------------------------------------------------------------
16 Copyright 2008 Sandia Corporation.
17 Under the terms of Contract DE-AC04-94AL85000 with Sandia Corporation,
18 the U.S. Government retains certain rights in this software.
19-------------------------------------------------------------------------*/
51#ifndef vtkGraphLayoutView_h
52#define vtkGraphLayoutView_h
53
54#include "vtkRenderView.h"
55#include "vtkViewsInfovisModule.h" // For export macro
56
60class vtkViewTheme;
61
62class VTKVIEWSINFOVIS_EXPORT vtkGraphLayoutView : public vtkRenderView
63{
64public:
67 void PrintSelf(ostream& os, vtkIndent indent) override;
68
70
73 void SetVertexLabelArrayName(const char* name);
76
78
81 void SetEdgeLabelArrayName(const char* name);
82 const char* GetEdgeLabelArrayName();
84
86
91 vtkBooleanMacro(VertexLabelVisibility, bool);
93
95
100 vtkBooleanMacro(HideVertexLabelsOnInteraction, bool);
102
104
107 void SetEdgeVisibility(bool vis);
109 vtkBooleanMacro(EdgeVisibility, bool);
111
113
118 vtkBooleanMacro(EdgeLabelVisibility, bool);
120
122
127 vtkBooleanMacro(HideEdgeLabelsOnInteraction, bool);
129
131
135 void SetVertexColorArrayName(const char* name);
138
140
143 void SetColorVertices(bool vis);
145 vtkBooleanMacro(ColorVertices, bool);
147
149
152 void SetEdgeColorArrayName(const char* name);
155
157
160 void SetColorEdges(bool vis);
162 vtkBooleanMacro(ColorEdges, bool);
164
166
169 void SetEdgeSelection(bool vis);
171 vtkBooleanMacro(EdgeSelection, bool);
173
175
181
183
186 void SetEnableEdgesByArray(bool vis);
189
191
197
199
205
207
210 void SetScalingArrayName(const char* name);
211 const char* GetScalingArrayName();
213
215
218 void SetScaledGlyphs(bool arg);
220 vtkBooleanMacro(ScaledGlyphs, bool);
222
224
242 void SetLayoutStrategy(const char* name);
243 void SetLayoutStrategyToRandom() { this->SetLayoutStrategy("Random"); }
244 void SetLayoutStrategyToForceDirected() { this->SetLayoutStrategy("Force Directed"); }
245 void SetLayoutStrategyToSimple2D() { this->SetLayoutStrategy("Simple 2D"); }
246 void SetLayoutStrategyToClustering2D() { this->SetLayoutStrategy("Clustering 2D"); }
247 void SetLayoutStrategyToCommunity2D() { this->SetLayoutStrategy("Community 2D"); }
248 void SetLayoutStrategyToFast2D() { this->SetLayoutStrategy("Fast 2D"); }
249 void SetLayoutStrategyToPassThrough() { this->SetLayoutStrategy("Pass Through"); }
250 void SetLayoutStrategyToCircular() { this->SetLayoutStrategy("Circular"); }
251 void SetLayoutStrategyToTree() { this->SetLayoutStrategy("Tree"); }
252 void SetLayoutStrategyToCosmicTree() { this->SetLayoutStrategy("Cosmic Tree"); }
253 void SetLayoutStrategyToCone() { this->SetLayoutStrategy("Cone"); }
254 void SetLayoutStrategyToSpanTree() { this->SetLayoutStrategy("Span Tree"); }
257
259
267
269
276 void SetEdgeLayoutStrategy(const char* name);
277 void SetEdgeLayoutStrategyToArcParallel() { this->SetEdgeLayoutStrategy("Arc Parallel"); }
278 void SetEdgeLayoutStrategyToPassThrough() { this->SetEdgeLayoutStrategy("Pass Through"); }
281
283
291
297 void AddIconType(const char* type, int index);
298
303
308 void SetIconAlignment(int alignment);
309
311
314 void SetIconVisibility(bool b);
316 vtkBooleanMacro(IconVisibility, bool);
318
320
323 void SetIconArrayName(const char* name);
324 const char* GetIconArrayName();
326
328
334
336
339 virtual void SetVertexLabelFontSize(const int size);
342
344
347 virtual void SetEdgeLabelFontSize(const int size);
348 virtual int GetEdgeLabelFontSize();
350
352
358
360
366
371
378 virtual int IsLayoutComplete();
379
390 virtual void UpdateLayout();
391
392protected:
395
397
403 // Called to process events. Overrides behavior in vtkRenderView.
404 void ProcessEvents(vtkObject* caller, unsigned long eventId, void* callData) override;
406
407private:
408 vtkGraphLayoutView(const vtkGraphLayoutView&) = delete;
409 void operator=(const vtkGraphLayoutView&) = delete;
410 bool VertexLabelsRequested;
411 bool EdgeLabelsRequested;
412};
413
414#endif
Proxy object to connect input/output ports.
The superclass for all representations.
abstract superclass for all edge layout strategies
abstract superclass for all graph layout strategies
Lays out and displays a graph.
bool GetVertexLabelVisibility()
Whether to show vertex labels.
void SetLayoutStrategyToSpanTree()
The layout strategy to use when performing the graph layout.
vtkDataRepresentation * CreateDefaultRepresentation(vtkAlgorithmOutput *conn) override
Overrides behavior in vtkView to create a vtkRenderedGraphRepresentation by default.
void SetEdgeLayoutStrategy(vtkEdgeLayoutStrategy *s)
The layout strategy to use when performing the edge layout.
void SetScaledGlyphs(bool arg)
Whether to use scaled glyphs or not.
void SetScalingArrayName(const char *name)
The array used for scaling (if ScaledGlyphs is ON)
virtual void SetVertexLabelFontSize(const int size)
The size of the font used for vertex labeling.
void SetEdgeLayoutStrategyToPassThrough()
The layout strategy to use when performing the edge layout.
bool GetEdgeLabelVisibility()
Whether to show edge labels.
void SetLayoutStrategyToClustering2D()
The layout strategy to use when performing the graph layout.
void SetEdgeLayoutStrategy(const char *name)
The layout strategy to use when performing the edge layout.
const char * GetEnabledVerticesArrayName()
The array to use for coloring vertices.
bool GetColorEdges()
Whether to color edges.
void SetGlyphType(int type)
The type of glyph to use for the vertices.
void SetEnabledVerticesArrayName(const char *name)
The array to use for coloring vertices.
vtkGraphLayoutStrategy * GetLayoutStrategy()
The layout strategy to use when performing the graph layout.
const char * GetVertexLabelArrayName()
The array to use for vertex labeling.
void SetEdgeLayoutStrategyToArcParallel()
The layout strategy to use when performing the edge layout.
static vtkGraphLayoutView * New()
bool GetEdgeSelection()
Whether edges are selectable.
void SetVertexColorArrayName(const char *name)
The array to use for coloring vertices.
void AddIconType(const char *type, int index)
Associate the icon at index "index" in the vtkTexture to all vertices containing "type" as a value in...
bool GetIconVisibility()
Whether icons are visible (default off).
bool GetScaledGlyphs()
Whether to use scaled glyphs or not.
int GetEnableEdgesByArray()
Whether to color edges.
void ProcessEvents(vtkObject *caller, unsigned long eventId, void *callData) override
Overrides behavior in vtkView to create a vtkRenderedGraphRepresentation by default.
void SetColorEdges(bool vis)
Whether to color edges.
bool GetColorVertices()
Whether to color vertices.
const char * GetScalingArrayName()
The array used for scaling (if ScaledGlyphs is ON)
void PrintSelf(ostream &os, vtkIndent indent) override
Methods invoked by print to print information about the object including superclasses.
virtual int IsLayoutComplete()
Is the graph layout complete? This method is useful for when the strategy is iterative and the applic...
void SetLayoutStrategyToRandom()
The layout strategy to use when performing the graph layout.
int GetGlyphType()
The type of glyph to use for the vertices.
void SetLayoutStrategyToCone()
The layout strategy to use when performing the graph layout.
void SetEdgeColorArrayName(const char *name)
The array to use for coloring edges.
void SetLayoutStrategyToCosmicTree()
The layout strategy to use when performing the graph layout.
void SetLayoutStrategyToTree()
The layout strategy to use when performing the graph layout.
virtual vtkRenderedGraphRepresentation * GetGraphRepresentation()
Overrides behavior in vtkView to create a vtkRenderedGraphRepresentation by default.
void SetLayoutStrategy(const char *name)
The layout strategy to use when performing the graph layout.
const char * GetEnabledEdgesArrayName()
The array to use for coloring edges.
void SetLayoutStrategyToPassThrough()
The layout strategy to use when performing the graph layout.
int GetEnableVerticesByArray()
Whether to color vertices.
void SetVertexLabelArrayName(const char *name)
The array to use for vertex labeling.
bool GetHideVertexLabelsOnInteraction()
Whether to hide vertex labels during mouse interactions.
void SetIconArrayName(const char *name)
The array used for assigning icons.
~vtkGraphLayoutView() override
void SetEdgeLabelVisibility(bool vis)
Whether to show edge labels.
void SetHideEdgeLabelsOnInteraction(bool vis)
Whether to hide edge labels during mouse interactions.
bool GetEdgeVisibility()
Whether to show the edges at all.
const char * GetEdgeColorArrayName()
The array to use for coloring edges.
bool GetVertexScalarBarVisibility()
Whether the scalar bar for vertices is visible.
void SetLayoutStrategyToSimple2D()
The layout strategy to use when performing the graph layout.
bool GetHideEdgeLabelsOnInteraction()
Whether to hide edge labels during mouse interactions.
virtual int GetVertexLabelFontSize()
The size of the font used for vertex labeling.
void SetEdgeSelection(bool vis)
Whether edges are selectable.
void SetEnableEdgesByArray(bool vis)
Whether to color edges.
const char * GetVertexColorArrayName()
The array to use for coloring vertices.
void SetEdgeVisibility(bool vis)
Whether to show the edges at all.
void SetEnableVerticesByArray(bool vis)
Whether to color vertices.
void SetLayoutStrategyToCircular()
The layout strategy to use when performing the graph layout.
virtual int GetEdgeLabelFontSize()
The size of the font used for edge labeling.
const char * GetIconArrayName()
The array used for assigning icons.
void SetEdgeScalarBarVisibility(bool vis)
Whether the scalar bar for edges is visible.
void SetEdgeLabelArrayName(const char *name)
The array to use for edge labeling.
const char * GetLayoutStrategyName()
The layout strategy to use when performing the graph layout.
void SetLayoutStrategyToForceDirected()
The layout strategy to use when performing the graph layout.
void ZoomToSelection()
Reset the camera based on the bounds of the selected region.
virtual void UpdateLayout()
This method is useful for when the strategy is iterative and the application wants to show the iterat...
void SetIconVisibility(bool b)
Whether icons are visible (default off).
void SetVertexScalarBarVisibility(bool vis)
Whether the scalar bar for vertices is visible.
virtual void SetEdgeLabelFontSize(const int size)
The size of the font used for edge labeling.
void SetLayoutStrategyToCommunity2D()
The layout strategy to use when performing the graph layout.
const char * GetEdgeLayoutStrategyName()
The layout strategy to use when performing the edge layout.
void SetColorVertices(bool vis)
Whether to color vertices.
bool GetEdgeScalarBarVisibility()
Whether the scalar bar for edges is visible.
void SetLayoutStrategyToFast2D()
The layout strategy to use when performing the graph layout.
void SetIconAlignment(int alignment)
Specify where the icons should be placed in relation to the vertex.
void ClearIconTypes()
Clear all icon mappings.
vtkEdgeLayoutStrategy * GetEdgeLayoutStrategy()
The layout strategy to use when performing the edge layout.
const char * GetEdgeLabelArrayName()
The array to use for edge labeling.
void SetLayoutStrategy(vtkGraphLayoutStrategy *s)
The layout strategy to use when performing the graph layout.
void SetVertexLabelVisibility(bool vis)
Whether to show vertex labels.
void SetEnabledEdgesArrayName(const char *name)
The array to use for coloring edges.
void SetHideVertexLabelsOnInteraction(bool vis)
Whether to hide vertex labels during mouse interactions.
a simple class to control print indentation
Definition: vtkIndent.h:43
abstract base class for most VTK objects
Definition: vtkObject.h:63
A view containing a renderer.
Definition: vtkRenderView.h:68
Sets theme colors for a graphical view.
Definition: vtkViewTheme.h:52
@ type
Definition: vtkX3D.h:522
@ name
Definition: vtkX3D.h:225
@ size
Definition: vtkX3D.h:259
@ index
Definition: vtkX3D.h:252