vtkTreeAlgorithm Class Reference

#include <vtkTreeAlgorithm.h>

Inheritance diagram for vtkTreeAlgorithm:

Inheritance graph
[legend]
Collaboration diagram for vtkTreeAlgorithm:

Collaboration graph
[legend]

List of all members.


Detailed Description

Superclass for algorithms that produce only Tree as output.

vtkTreeAlgorithm is a convenience class to make writing algorithms easier. It is also designed to help transition old algorithms to the new pipeline edgehitecture. There are some assumptions and defaults made by this class you should be aware of. This class defaults such that your filter will have one input port and one output port. If that is not the case simply change it with SetNumberOfInputPorts etc. See this class constructor for the default. This class also provides a FillInputPortInfo method that by default says that all inputs will be Tree. If that isn't the case then please override this method in your subclass. This class breaks out the downstream requests into separate functions such as ExecuteData and ExecuteInformation. For new algorithms you should implement RequestData( request, inputVec, outputVec) but for older filters there is a default implementation that calls the old ExecuteData(output) signature. For even older filters that don't implement ExecuteData the default implementation calls the even older Execute() signature.

Tests:
vtkTreeAlgorithm (Tests)

Definition at line 52 of file vtkTreeAlgorithm.h.


Public Types

typedef vtkAlgorithm Superclass

Public Member Functions

virtual const char * GetClassName ()
virtual int IsA (const char *type)
void PrintSelf (ostream &os, vtkIndent indent)
virtual int ProcessRequest (vtkInformation *, vtkInformationVector **, vtkInformationVector *)
vtkTreeGetOutput ()
vtkTreeGetOutput (int index)
void SetInput (vtkDataObject *obj)
void SetInput (int index, vtkDataObject *obj)

Static Public Member Functions

static vtkTreeAlgorithmNew ()
static int IsTypeOf (const char *type)
static vtkTreeAlgorithmSafeDownCast (vtkObject *o)

Protected Member Functions

 vtkTreeAlgorithm ()
 ~vtkTreeAlgorithm ()
virtual int RequestInformation (vtkInformation *request, vtkInformationVector **inputVector, vtkInformationVector *outputVector)
virtual int FillOutputPortInformation (int port, vtkInformation *info)
virtual int FillInputPortInformation (int port, vtkInformation *info)
virtual int RequestData (vtkInformation *request, vtkInformationVector **inputVector, vtkInformationVector *outputVector)
virtual int RequestUpdateExtent (vtkInformation *, vtkInformationVector **, vtkInformationVector *)

Member Typedef Documentation


Constructor & Destructor Documentation

vtkTreeAlgorithm::vtkTreeAlgorithm (  )  [protected]

vtkTreeAlgorithm::~vtkTreeAlgorithm (  )  [protected]


Member Function Documentation

static vtkTreeAlgorithm* vtkTreeAlgorithm::New (  )  [static]

Create an object with Debug turned off, modified time initialized to zero, and reference counting on.

Reimplemented from vtkAlgorithm.

Reimplemented in vtkAreaLayout, vtkBoostBreadthFirstSearchTree, vtkBoostPrimMinimumSpanningTree, vtkGroupLeafVertices, vtkNetworkHierarchy, vtkPruneTreeFilter, vtkTableToTreeFilter, vtkTreeFieldAggregator, vtkTreeLevelsFilter, vtkTreeMapLayout, and vtkXMLTreeReader.

virtual const char* vtkTreeAlgorithm::GetClassName (  )  [virtual]

static int vtkTreeAlgorithm::IsTypeOf ( const char *  name  )  [static]

Return 1 if this class type is the same type of (or a subclass of) the named class. Returns 0 otherwise. This method works in combination with vtkTypeRevisionMacro found in vtkSetGet.h.

Reimplemented from vtkAlgorithm.

Reimplemented in vtkAreaLayout, vtkBoostBreadthFirstSearchTree, vtkBoostPrimMinimumSpanningTree, vtkGroupLeafVertices, vtkNetworkHierarchy, vtkPruneTreeFilter, vtkTableToTreeFilter, vtkTreeFieldAggregator, vtkTreeLevelsFilter, vtkTreeMapLayout, and vtkXMLTreeReader.

virtual int vtkTreeAlgorithm::IsA ( const char *  name  )  [virtual]

Return 1 if this class is the same type of (or a subclass of) the named class. Returns 0 otherwise. This method works in combination with vtkTypeRevisionMacro found in vtkSetGet.h.

Reimplemented from vtkAlgorithm.

Reimplemented in vtkAreaLayout, vtkBoostBreadthFirstSearchTree, vtkBoostPrimMinimumSpanningTree, vtkGroupLeafVertices, vtkNetworkHierarchy, vtkPruneTreeFilter, vtkTableToTreeFilter, vtkTreeFieldAggregator, vtkTreeLevelsFilter, vtkTreeMapLayout, and vtkXMLTreeReader.

static vtkTreeAlgorithm* vtkTreeAlgorithm::SafeDownCast ( vtkObject o  )  [static]

void vtkTreeAlgorithm::PrintSelf ( ostream &  os,
vtkIndent  indent 
) [virtual]

Methods invoked by print to print information about the object including superclasses. Typically not called by the user (use Print() instead) but used in the hierarchical print process to combine the output of several classes.

Reimplemented from vtkAlgorithm.

Reimplemented in vtkAreaLayout, vtkBoostBreadthFirstSearchTree, vtkBoostPrimMinimumSpanningTree, vtkGroupLeafVertices, vtkNetworkHierarchy, vtkPruneTreeFilter, vtkTableToTreeFilter, vtkTreeFieldAggregator, vtkTreeLevelsFilter, vtkTreeMapLayout, and vtkXMLTreeReader.

virtual int vtkTreeAlgorithm::ProcessRequest ( vtkInformation ,
vtkInformationVector **  ,
vtkInformationVector  
) [virtual]

see vtkAlgorithm for details

Reimplemented from vtkAlgorithm.

vtkTree* vtkTreeAlgorithm::GetOutput (  )  [inline]

Get the output data object for a port on this algorithm.

Definition at line 68 of file vtkTreeAlgorithm.h.

vtkTree* vtkTreeAlgorithm::GetOutput ( int  index  ) 

Get the output data object for a port on this algorithm.

void vtkTreeAlgorithm::SetInput ( vtkDataObject obj  )  [inline]

Set an input of this algorithm. You should not override these methods because they are not the only way to connect a pipeline. Note that these methods support old-style pipeline connections. When writing new code you should use the more general vtkAlgorithm::SetInputConnection(). These methods transform the input index to the input port index, not an index of a connection within a single port.

Definition at line 80 of file vtkTreeAlgorithm.h.

void vtkTreeAlgorithm::SetInput ( int  index,
vtkDataObject obj 
)

Set an input of this algorithm. You should not override these methods because they are not the only way to connect a pipeline. Note that these methods support old-style pipeline connections. When writing new code you should use the more general vtkAlgorithm::SetInputConnection(). These methods transform the input index to the input port index, not an index of a connection within a single port.

virtual int vtkTreeAlgorithm::RequestInformation ( vtkInformation request,
vtkInformationVector **  inputVector,
vtkInformationVector outputVector 
) [protected, virtual]

virtual int vtkTreeAlgorithm::RequestData ( vtkInformation request,
vtkInformationVector **  inputVector,
vtkInformationVector outputVector 
) [protected, virtual]

virtual int vtkTreeAlgorithm::RequestUpdateExtent ( vtkInformation ,
vtkInformationVector **  ,
vtkInformationVector  
) [protected, virtual]

This is called by the superclass. This is the method you should override.

virtual int vtkTreeAlgorithm::FillOutputPortInformation ( int  port,
vtkInformation info 
) [protected, virtual]

Fill the output port information objects for this algorithm. This is invoked by the first call to GetOutputPortInformation for each port so subclasses can specify what they can handle.

Reimplemented from vtkAlgorithm.

virtual int vtkTreeAlgorithm::FillInputPortInformation ( int  port,
vtkInformation info 
) [protected, virtual]

Fill the input port information objects for this algorithm. This is invoked by the first call to GetInputPortInformation for each port so subclasses can specify what they can handle.

Reimplemented from vtkAlgorithm.

Reimplemented in vtkBoostBreadthFirstSearchTree, and vtkBoostPrimMinimumSpanningTree.


The documentation for this class was generated from the following file:

Generated on Wed Jun 3 19:40:59 2009 for VTK by  doxygen 1.5.6