29 #ifndef vtkRenderedGraphRepresentation_h
30 #define vtkRenderedGraphRepresentation_h
34 #include "vtkViewsInfovisModule.h"
77 virtual void SetVertexLabelArrayName(
const char*
name);
78 virtual const char* GetVertexLabelArrayName();
79 virtual void SetVertexLabelPriorityArrayName(
const char*
name);
80 virtual const char* GetVertexLabelPriorityArrayName();
81 virtual void SetVertexLabelVisibility(
bool b);
82 virtual bool GetVertexLabelVisibility();
83 vtkBooleanMacro(VertexLabelVisibility,
bool);
86 vtkSetStringMacro(VertexHoverArrayName);
87 vtkGetStringMacro(VertexHoverArrayName);
92 vtkSetMacro(HideVertexLabelsOnInteraction,
bool);
93 vtkGetMacro(HideVertexLabelsOnInteraction,
bool);
94 vtkBooleanMacro(HideVertexLabelsOnInteraction,
bool);
100 virtual void SetEdgeLabelArrayName(
const char*
name);
101 virtual const char* GetEdgeLabelArrayName();
102 virtual void SetEdgeLabelPriorityArrayName(
const char*
name);
103 virtual const char* GetEdgeLabelPriorityArrayName();
104 virtual void SetEdgeLabelVisibility(
bool b);
105 virtual bool GetEdgeLabelVisibility();
106 vtkBooleanMacro(EdgeLabelVisibility,
bool);
109 vtkSetStringMacro(EdgeHoverArrayName);
110 vtkGetStringMacro(EdgeHoverArrayName);
115 vtkSetMacro(HideEdgeLabelsOnInteraction,
bool);
116 vtkGetMacro(HideEdgeLabelsOnInteraction,
bool);
117 vtkBooleanMacro(HideEdgeLabelsOnInteraction,
bool);
123 virtual void SetVertexIconArrayName(
const char*
name);
124 virtual const char* GetVertexIconArrayName();
125 virtual void SetVertexIconPriorityArrayName(
const char*
name);
126 virtual const char* GetVertexIconPriorityArrayName();
127 virtual void SetVertexIconVisibility(
bool b);
128 virtual bool GetVertexIconVisibility();
129 vtkBooleanMacro(VertexIconVisibility,
bool);
130 virtual void AddVertexIconType(
const char*
name,
int type);
131 virtual void ClearVertexIconTypes();
132 virtual void SetUseVertexIconTypeMap(
bool b);
133 virtual bool GetUseVertexIconTypeMap();
134 vtkBooleanMacro(UseVertexIconTypeMap,
bool);
135 virtual void SetVertexIconAlignment(
int align);
136 virtual int GetVertexIconAlignment();
137 virtual void SetVertexSelectedIcon(
int icon);
138 virtual int GetVertexSelectedIcon();
139 virtual void SetVertexDefaultIcon(
int icon);
140 virtual int GetVertexDefaultIcon();
153 virtual void SetVertexIconSelectionMode(
int mode);
154 virtual int GetVertexIconSelectionMode();
160 this->SetVertexIconSelectionMode(3);
167 virtual void SetEdgeIconArrayName(
const char*
name);
168 virtual const char* GetEdgeIconArrayName();
169 virtual void SetEdgeIconPriorityArrayName(
const char*
name);
170 virtual const char* GetEdgeIconPriorityArrayName();
171 virtual void SetEdgeIconVisibility(
bool b);
172 virtual bool GetEdgeIconVisibility();
173 vtkBooleanMacro(EdgeIconVisibility,
bool);
174 virtual void AddEdgeIconType(
const char*
name,
int type);
175 virtual void ClearEdgeIconTypes();
176 virtual void SetUseEdgeIconTypeMap(
bool b);
177 virtual bool GetUseEdgeIconTypeMap();
178 vtkBooleanMacro(UseEdgeIconTypeMap,
bool);
179 virtual void SetEdgeIconAlignment(
int align);
180 virtual int GetEdgeIconAlignment();
185 virtual void SetColorVerticesByArray(
bool b);
186 virtual bool GetColorVerticesByArray();
187 vtkBooleanMacro(ColorVerticesByArray,
bool);
188 virtual void SetVertexColorArrayName(
const char*
name);
189 virtual const char* GetVertexColorArrayName();
194 virtual void SetColorEdgesByArray(
bool b);
195 virtual bool GetColorEdgesByArray();
196 vtkBooleanMacro(ColorEdgesByArray,
bool);
197 virtual void SetEdgeColorArrayName(
const char*
name);
198 virtual const char* GetEdgeColorArrayName();
203 virtual void SetEnableVerticesByArray(
bool b);
204 virtual bool GetEnableVerticesByArray();
205 vtkBooleanMacro(EnableVerticesByArray,
bool);
206 virtual void SetEnabledVerticesArrayName(
const char*
name);
207 virtual const char* GetEnabledVerticesArrayName();
212 virtual void SetEnableEdgesByArray(
bool b);
213 virtual bool GetEnableEdgesByArray();
214 vtkBooleanMacro(EnableEdgesByArray,
bool);
215 virtual void SetEnabledEdgesArrayName(
const char*
name);
216 virtual const char* GetEnabledEdgesArrayName();
218 virtual void SetEdgeVisibility(
bool b);
219 virtual bool GetEdgeVisibility();
220 vtkBooleanMacro(EdgeVisibility,
bool);
222 void SetEdgeSelection(
bool b);
223 bool GetEdgeSelection();
240 virtual void SetLayoutStrategy(
const char*
name);
241 vtkGetStringMacro(LayoutStrategyName);
264 virtual void SetLayoutStrategyToAssignCoordinates(
265 const char* xarr,
const char* yarr =
nullptr,
const char* zarr =
nullptr);
277 virtual void SetLayoutStrategyToTree(
278 bool radial,
double angle = 90,
double leafSpacing = 0.9,
double logSpacing = 1.0);
290 virtual void SetLayoutStrategyToCosmicTree(
const char* nodeSizeArrayName,
291 bool sizeLeafNodesOnly =
true,
int layoutDepth = 0,
vtkIdType layoutRoot = -1);
310 virtual void SetEdgeLayoutStrategyToGeo(
double explodeFactor = 0.2);
316 virtual void SetEdgeLayoutStrategy(
const char*
name);
317 vtkGetStringMacro(EdgeLayoutStrategyName);
332 virtual void SetGlyphType(
int type);
333 virtual int GetGlyphType();
340 virtual void SetScaling(
bool b);
341 virtual bool GetScaling();
342 vtkBooleanMacro(Scaling,
bool);
349 virtual void SetScalingArrayName(
const char*
name);
350 virtual const char* GetScalingArrayName();
357 virtual void SetVertexScalarBarVisibility(
bool b);
358 virtual bool GetVertexScalarBarVisibility();
359 virtual void SetEdgeScalarBarVisibility(
bool b);
360 virtual bool GetEdgeScalarBarVisibility();
374 virtual bool IsLayoutComplete();
379 virtual void UpdateLayout();
384 void ComputeSelectedGraphBounds(
double bounds[6]);
447 vtkSetStringMacro(VertexColorArrayNameInternal);
448 vtkGetStringMacro(VertexColorArrayNameInternal);
451 vtkSetStringMacro(EdgeColorArrayNameInternal);
452 vtkGetStringMacro(EdgeColorArrayNameInternal);
455 vtkSetStringMacro(ScalingArrayNameInternal);
456 vtkGetStringMacro(ScalingArrayNameInternal);
459 vtkSetStringMacro(LayoutStrategyName);
461 vtkSetStringMacro(EdgeLayoutStrategyName);
void SetLayoutStrategyToClustering2D()
virtual void ApplyViewTheme(vtkViewTheme *vtkNotUsed(theme))
Apply a theme to this representation.
vtkSmartPointer< vtkPolyDataMapper > OutlineMapper
Internal filter classes.
vtkSmartPointer< vtkGraphToPoints > VertexIconPoints
Internal filter classes.
virtual void SetVertexIconSelectionModeToIgnoreSelection()
Set the mode to one of.
virtual vtkSelection * ConvertSelection(vtkView *view, vtkSelection *selection)
Convert the selection to a type appropriate for sharing with other representations through vtkAnnotat...
virtual void SetVertexIconSelectionModeToSelectedIcon()
Set the mode to one of.
vtkSmartPointer< vtkGraphToPolyData > GraphToPoly
Internal filter classes.
vtkSmartPointer< vtkScalarBarWidget > VertexScalarBar
Internal filter classes.
bool HideEdgeLabelsOnInteraction
void SetEdgeLayoutStrategyToPassThrough()
Set/get the graph layout strategy.
represents an object (geometry & properties) in a rendered scene
actor that draws 2D data with texture support
vtkSmartPointer< vtkApplyIcons > ApplyVertexIcons
Internal filter classes.
vtkSmartPointer< vtkPointSetToLabelHierarchy > VertexLabelHierarchy
Internal filter classes.
Filter that generates a polydata consisting of quads with texture coordinates referring to a set of i...
char * EdgeLayoutStrategyName
char * VertexHoverArrayName
vtkSmartPointer< vtkGraphToGlyphs > VertexGlyph
Internal filter classes.
vtkSmartPointer< vtkActor > VertexActor
Internal filter classes.
map scalar values into colors via a lookup table
int RequestData(vtkInformation *, vtkInformationVector **, vtkInformationVector *) override
Subclasses should override this to connect inputs to the internal pipeline as necessary.
void SetLayoutStrategyToPassThrough()
vtkSmartPointer< vtkIconGlyphFilter > VertexIconGlyph
Internal filter classes.
void SetLayoutStrategyToCosmicTree()
data object that represents a "selection" in VTK.
Adds an attribute array with the degree of each vertex.
vtkSmartPointer< vtkScalarBarWidget > EdgeScalarBar
Internal filter classes.
virtual bool AddToView(vtkView *vtkNotUsed(view))
Adds the representation to the view.
concrete dataset represents vertices, lines, polygons, and triangle strips
vtkSmartPointer< vtkApplyColors > ApplyColors
Internal filter classes.
char * VertexColorArrayNameInternal
void SetLayoutStrategyToCircular()
static vtkRenderedRepresentation * New()
abstract superclass for all graph layout strategies
vtkSmartPointer< vtkPolyDataMapper > EdgeMapper
Internal filter classes.
vtkSmartPointer< vtkVertexDegree > VertexDegree
Internal filter classes.
convert a vtkGraph to vtkPolyData
Superclass for mapping scalar values to colors.
vtkSmartPointer< vtkEdgeLayout > EdgeLayout
Internal filter classes.
generate points at center of edges
Sets theme colors for a graphical view.
vtkSmartPointer< vtkTexturedActor2D > VertexIconActor
Internal filter classes.
vtkSmartPointer< vtkTransformCoordinateSystems > VertexIconTransform
Internal filter classes.
void SetLayoutStrategyToSpanTree()
The superclass for all views.
void SetLayoutStrategyToCommunity2D()
a simple class to control print indentation
vtkSmartPointer< vtkPointSetToLabelHierarchy > EdgeLabelHierarchy
Internal filter classes.
vtkSmartPointer< vtkGraphLayout > Layout
Internal filter classes.
virtual bool RemoveFromView(vtkView *vtkNotUsed(view))
Removes the representation to the view.
layout a graph in 2 or 3 dimensions
virtual void PrepareForRendering(vtkRenderView *view)
The view will call this method before every render.
vtkSmartPointer< vtkPolyData > EmptyPolyData
Internal filter classes.
void SetLayoutStrategyToRandom()
Set predefined layout strategies.
void SetLayoutStrategyToTree()
void SetLayoutStrategyToSimple2D()
Perturbs vertices that are coincident.
char * EdgeHoverArrayName
represent text properties.
build a label hierarchy for a graph or point set.
vtkSmartPointer< vtkRemoveHiddenData > RemoveHiddenGraph
Internal filter classes.
void SetLayoutStrategyToCone()
virtual std::string GetHoverStringInternal(vtkSelection *)
Subclasses may override this method to generate the hover text.
map vtkPolyData to graphics primitives
vtkSmartPointer< vtkActor > OutlineActor
Internal filter classes.
char * EdgeColorArrayNameInternal
vtkSmartPointer< vtkActor > EdgeActor
Internal filter classes.
char * LayoutStrategyName
void SetLayoutStrategyToForceDirected()
bool HideVertexLabelsOnInteraction
vtkSmartPointer< vtkGraphToPoints > GraphToPoints
Internal filter classes.
A view containing a renderer.
abstract superclass for all edge layout strategies
vtkSmartPointer< vtkEdgeCenters > EdgeCenters
Internal filter classes.
convert a vtkGraph a set of points.
apply colors to a data set.
void PrintSelf(ostream &os, vtkIndent indent) override
Methods invoked by print to print information about the object including superclasses.
void SetLayoutStrategyToFast2D()
char * ScalingArrayNameInternal
vtkSmartPointer< vtkPolyDataMapper > VertexMapper
Internal filter classes.
vtkSmartPointer< vtkGraphToGlyphs > OutlineGlyph
Internal filter classes.
vtkSmartPointer< vtkPolyDataMapper2D > VertexIconMapper
Internal filter classes.
virtual void SetVertexIconSelectionModeToSelectedOffset()
Set the mode to one of.
create glyphs for graph vertices
virtual void SetVertexIconSelectionModeToAnnotationIcon()
Set the mode to one of.
apply icons to a data set.
vtkSmartPointer< vtkPerturbCoincidentVertices > Coincident
Internal filter classes.
draw vtkPolyData onto the image plane
Removes the rows/edges/vertices of input data flagged by ann.
void SetEdgeLayoutStrategyToArcParallel()
Set/get the graph layout strategy.