1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132
|
/*=========================================================================
Program: ParaView
Module: vtkPVCompositeDataInformation.h
Copyright (c) Kitware, Inc.
All rights reserved.
See Copyright.txt or http://www.paraview.org/HTML/Copyright.html for details.
This software is distributed WITHOUT ANY WARRANTY; without even
the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
PURPOSE. See the above copyright notice for more information.
=========================================================================*/
/**
* @class vtkPVCompositeDataInformation
* @brief Light object for holding composite data information.
*
* vtkPVCompositeDataInformation is used to copy the meta information of
* a composite dataset from server to client. It holds a vtkPVDataInformation
* for each block of the composite dataset.
* @sa
* vtkHierarchicalBoxDataSet vtkPVDataInformation
*/
#ifndef vtkPVCompositeDataInformation_h
#define vtkPVCompositeDataInformation_h
#include "vtkPVClientServerCoreCoreModule.h" //needed for exports
#include "vtkPVInformation.h"
class vtkPVDataInformation;
class vtkUniformGridAMR;
struct vtkPVCompositeDataInformationInternals;
class VTKPVCLIENTSERVERCORECORE_EXPORT vtkPVCompositeDataInformation : public vtkPVInformation
{
public:
static vtkPVCompositeDataInformation* New();
vtkTypeMacro(vtkPVCompositeDataInformation, vtkPVInformation);
void PrintSelf(ostream& os, vtkIndent indent) VTK_OVERRIDE;
/**
* Transfer information about a single object into this object.
*/
virtual void CopyFromObject(vtkObject*) VTK_OVERRIDE;
/**
* Merge another information object.
*/
virtual void AddInformation(vtkPVInformation*) VTK_OVERRIDE;
//@{
/**
* Manage a serialized version of the information.
*/
virtual void CopyToStream(vtkClientServerStream*) VTK_OVERRIDE;
virtual void CopyFromStream(const vtkClientServerStream*) VTK_OVERRIDE;
//@}
/**
* Clears all internal data structures.
*/
virtual void Initialize();
/**
* Returns the number of children.
*/
unsigned int GetNumberOfChildren();
/**
* Returns the information for the data object at the given index. If the
* child is a composite dataset itself, then the return vtkPVDataInformation
* will have the CompositeDataInformation set appropriately.
*/
vtkPVDataInformation* GetDataInformation(unsigned int idx);
/**
* Return the name of the child node at the given index, if any. This is the
* value for the key vtkCompositeDataSet::NAME() in the meta-data associated
* with the node.
*/
const char* GetName(unsigned int idx);
//@{
/**
* Get/Set if the data is multipiece. If so, then GetDataInformation() will
* always return NULL. For vtkMultiblockDataSet, we don't collect information
* about individual pieces. One can however, query the number of pieces by
* using GetNumberOfChildren().
*/
vtkGetMacro(DataIsMultiPiece, int);
//@}
//@{
/**
* Returns if the dataset is a composite dataset.
*/
vtkGetMacro(DataIsComposite, int);
//@}
// TODO:
// Add API to obtain meta data information for each of the children.
protected:
vtkPVCompositeDataInformation();
~vtkPVCompositeDataInformation();
/**
* Copy information from an amr dataset.
*/
void CopyFromAMR(vtkUniformGridAMR* amr);
int DataIsMultiPiece;
int DataIsComposite;
unsigned int FlatIndexMax;
unsigned int NumberOfPieces;
vtkSetMacro(NumberOfPieces, unsigned int);
friend class vtkPVDataInformation;
vtkPVDataInformation* GetDataInformationForCompositeIndex(int* index);
private:
vtkPVCompositeDataInformationInternals* Internal;
vtkPVCompositeDataInformation(const vtkPVCompositeDataInformation&) VTK_DELETE_FUNCTION;
void operator=(const vtkPVCompositeDataInformation&) VTK_DELETE_FUNCTION;
};
#endif
|