VTK
vtkMutableDirectedGraph.h
Go to the documentation of this file.
1/*=========================================================================
2
3 Program: Visualization Toolkit
4 Module: vtkMutableDirectedGraph.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-------------------------------------------------------------------------*/
41#ifndef vtkMutableDirectedGraph_h
42#define vtkMutableDirectedGraph_h
43
44#include "vtkCommonDataModelModule.h" // For export macro
45#include "vtkDirectedGraph.h"
46
48class vtkGraphEdge;
49class vtkVariant;
50
51class VTKCOMMONDATAMODEL_EXPORT vtkMutableDirectedGraph : public vtkDirectedGraph
52{
53public:
56 void PrintSelf(ostream& os, vtkIndent indent) VTK_OVERRIDE;
57
71
83
103
119 vtkIdType AddVertex(const vtkVariant& pedigreeId);
120
130
144 vtkVariantArray *propertyArr);
145
159 vtkVariantArray *propertyArr = 0);
160
174 vtkVariantArray *propertyArr = 0);
175
189 const vtkVariant& v,
190 vtkVariantArray *propertyArr = 0);
191
200
214 void LazyAddVertex(vtkVariantArray *propertyArr);
215
226 void LazyAddVertex(const vtkVariant& pedigreeId);
227
240 void LazyAddEdge(vtkIdType u, vtkIdType v, vtkVariantArray *propertyArr = 0);
241
255 vtkVariantArray *propertyArr = 0);
256
270 vtkVariantArray *propertyArr = 0);
271
284 void LazyAddEdge(const vtkVariant& u,
285 const vtkVariant& v,
286 vtkVariantArray *propertyArr = 0);
287
297
311 vtkVariantArray *propertyArr);
313 { return this->AddChild(parent, 0); }
314
320
326
331
336
337protected:
340
344 vtkGraphEdge *GraphEdge;
345
346private:
347 vtkMutableDirectedGraph(const vtkMutableDirectedGraph&) VTK_DELETE_FUNCTION;
348 void operator=(const vtkMutableDirectedGraph&) VTK_DELETE_FUNCTION;
349};
350
351#endif
A directed graph.
Iterates through all edges in a graph.
Representation of a single graph edge.
Definition: vtkGraphEdge.h:40
dynamic, self-adjusting array of vtkIdType
a simple class to control print indentation
Definition: vtkIndent.h:40
An editable directed graph.
void RemoveEdges(vtkIdTypeArray *arr)
Removes a collection of edges from the graph.
void RemoveEdge(vtkIdType e)
Removes the edge from the graph.
static vtkMutableDirectedGraph * New()
vtkIdType AddVertex(vtkVariantArray *propertyArr)
Adds a vertex to the graph with associated properties defined in propertyArr and returns the index of...
vtkIdType AddChild(vtkIdType parent, vtkVariantArray *propertyArr)
Convenience method for creating trees.
void LazyAddEdge(const vtkVariant &u, const vtkVariant &v, vtkVariantArray *propertyArr=0)
Adds a directed edge from u to v, where u and v are vertex pedigree IDs.
vtkIdType AddChild(vtkIdType parent)
vtkEdgeType AddEdge(const vtkVariant &u, const vtkVariant &v, vtkVariantArray *propertyArr=0)
Adds a directed edge from u to v, where u and v are vertex pedigree IDs, and returns a vtkEdgeType st...
void PrintSelf(ostream &os, vtkIndent indent) override
Methods invoked by print to print information about the object including superclasses.
vtkIdType AddVertex(const vtkVariant &pedigreeId)
Adds a vertex with the given pedigreeID to the graph and returns the index of the new vertex.
vtkGraphEdge * AddGraphEdge(vtkIdType u, vtkIdType v)
Variant of AddEdge() that returns a heavyweight vtkGraphEdge object.
~vtkMutableDirectedGraph() override
void LazyAddVertex(vtkVariantArray *propertyArr)
Adds a vertex to the graph with associated properties defined in propertyArr.
vtkEdgeType AddEdge(vtkIdType u, vtkIdType v, vtkVariantArray *propertyArr)
Adds a directed edge from u to v, where u and v are vertex indices, with associated properties define...
vtkEdgeType AddEdge(vtkIdType u, const vtkVariant &v, vtkVariantArray *propertyArr=0)
Adds a directed edge from u to v, where u is a vertex index and v is a vertex pedigree ID,...
vtkIdType AddVertex()
Adds a vertex to the graph and returns the index of the new vertex.
void LazyAddEdge(vtkIdType u, vtkIdType v, vtkVariantArray *propertyArr=0)
Adds a directed edge from u to v, where u and v are vertex indices.
void LazyAddVertex(const vtkVariant &pedigreeId)
Adds a vertex with the given pedigreeID to the graph.
void RemoveVertices(vtkIdTypeArray *arr)
Removes a collection of vertices from the graph along with any connected edges.
void RemoveVertex(vtkIdType v)
Removes the vertex from the graph along with any connected edges.
vtkEdgeType AddEdge(const vtkVariant &u, vtkIdType v, vtkVariantArray *propertyArr=0)
Adds a directed edge from u to v, where u is a vertex pedigree ID and v is a vertex index,...
void LazyAddEdge(const vtkVariant &u, vtkIdType v, vtkVariantArray *propertyArr=0)
Adds a directed edge from u to v, where u is a vertex pedigree ID and v is a vertex index.
vtkEdgeType AddEdge(vtkIdType u, vtkIdType v)
Adds a directed edge from u to v, where u and v are vertex indices, and returns a vtkEdgeType structu...
virtual vtkIdType SetNumberOfVertices(vtkIdType numVerts)
Allocates space for the specified number of vertices in the graph's internal data structures.
void LazyAddEdge(vtkIdType u, const vtkVariant &v, vtkVariantArray *propertyArr=0)
Adds a directed edge from u to v, where u is a vertex index and v is a vertex pedigree ID.
void LazyAddVertex()
Adds a vertex to the graph.
An array holding vtkVariants.
A atomic type representing the union of many types.
Definition: vtkVariant.h:76
int vtkIdType
Definition: vtkType.h:287