219 #include "vtkCommonDataModelModule.h"
228 class vtkGraphEdgePoints;
244 class vtk_edge_iterator;
245 class vtk_out_edge_pointer_iterator;
246 class vtk_in_edge_pointer_iterator;
338 void ComputeBounds();
347 void GetBounds(
double bounds[6]);
492 virtual
void CopyStructure(
vtkGraph *g);
499 virtual
bool CheckedShallowCopy(
vtkGraph *g);
506 virtual
bool CheckedDeepCopy(
vtkGraph *g);
511 virtual
void Squeeze();
534 bool IsSameStructure(
vtkGraph *other);
582 {
double p[3] = {x, y, z}; this->SetEdgePoint(e, i, p); }
587 void AddEdgePoint(
vtkIdType e,
double x[3]);
589 {
double p[3] = {x, y, z}; this->AddEdgePoint(e, p); }
596 void ShallowCopyEdgePoints(
vtkGraph* g);
597 void DeepCopyEdgePoints(
vtkGraph* g);
696 void RemoveVertexInternal(
vtkIdType v,
bool directed);
702 void RemoveEdgeInternal(
vtkIdType e,
bool directed);
718 virtual
bool IsStructureValid(
vtkGraph *g) = 0;
723 virtual
void CopyInternal(
vtkGraph *g,
bool deep);
743 vtkGraphEdgePoints *EdgePoints;
748 void SetEdgePoints(vtkGraphEdgePoints* edgePoints);
754 void ForceOwnership();
767 void BuildEdgeList();
777 friend class
boost::vtk_edge_iterator;
778 friend class
boost::vtk_in_edge_pointer_iterator;
779 friend class
boost::vtk_out_edge_pointer_iterator;
805 static
double DefaultPoint[3];
813 virtual
void SetEdgeList(vtkIdTypeArray* list);
814 vtkIdTypeArray *EdgeList;
819 void operator=(const
vtkGraph&) VTK_DELETE_FUNCTION;
824 VTKCOMMONDATAMODEL_EXPORT ostream& operator<<(ostream& out,
vtkEdgeBase e);
helper for the vtkGraph class that allows the graph to be distributed across multiple memory spaces...
void PrintSelf(ostream &os, vtkIndent indent) override
Methods invoked by print to print information about the object including superclasses.
virtual vtkFieldData * GetAttributesAsFieldData(int type)
Returns the attributes of the data object as a vtkFieldData.
Forward declaration required for Boost serialization.
An array holding vtkVariants.
Iterates through adjacent vertices in a graph.
record modification and/or execution time
Iterates through all edges in a graph.
void DeepCopy(vtkPistonReference *self, vtkPistonReference *other)
Representation of a single graph edge.
vtkEdgeBase(vtkIdType id)
virtual void Initialize()
Restore data object to initial state,.
dynamic, self-adjusting array of vtkIdType
vtkTypeUInt64 vtkMTimeType
void GetPoint(const int i, const int j, const int k, double pnt[3])
A atomic type representing the union of many types.
Base class for graph data types.
a simple class to control print indentation
std::pair< boost::graph_traits< vtkGraph * >::vertex_iterator, boost::graph_traits< vtkGraph * >::vertex_iterator > vertices(vtkGraph *g)
Iterates through all incoming edges to a vertex.
Internal representation of vtkGraph.
represent and manipulate attribute data in a dataset
virtual vtkIdType GetNumberOfElements(int type)
Get the number of elements for a specific attribute type (POINT, CELL, etc.).
object to represent cell connectivity
Iterates all vertices in a graph.
vtkOutEdgeType(vtkIdType t, vtkIdType id)
int GetDataObjectType() override
Return what type of dataset this is.
Iterates through all outgoing edges from a vertex.
general representation of visualization data
vtkInEdgeType(vtkIdType s, vtkIdType id)
vtkEdgeType(vtkIdType s, vtkIdType t, vtkIdType id)
represent and manipulate 3D points
void AddEdgePoint(vtkIdType e, double x, double y, double z)
std::pair< boost::graph_traits< vtkGraph * >::edge_iterator, boost::graph_traits< vtkGraph * >::edge_iterator > edges(vtkGraph *g)
represent and manipulate fields of data