#include <vtkDataArrayTemplate.h>
There is a vtkDataArray subclass for each native type supported by VTK. This template is used to implement all the subclasses in the same way while avoiding code duplication.
Definition at line 32 of file vtkDataArrayTemplate.h.
Public Types | |
enum | DeleteMethod { VTK_DATA_ARRAY_FREE, VTK_DATA_ARRAY_DELETE } |
typedef vtkDataArray | Superclass |
Public Member Functions | |
void | PrintSelf (ostream &os, vtkIndent indent) |
int | Allocate (vtkIdType sz, vtkIdType ext=1000) |
void | Initialize () |
int | GetDataTypeSize () |
void | SetNumberOfTuples (vtkIdType number) |
virtual void | SetTuple (vtkIdType i, vtkIdType j, vtkAbstractArray *source) |
virtual void | InsertTuple (vtkIdType i, vtkIdType j, vtkAbstractArray *source) |
virtual vtkIdType | InsertNextTuple (vtkIdType j, vtkAbstractArray *source) |
double * | GetTuple (vtkIdType i) |
void | Squeeze () |
vtkIdType | Capacity () |
virtual int | Resize (vtkIdType numTuples) |
T | GetValue (vtkIdType id) |
void | SetNumberOfValues (vtkIdType number) |
void | InsertValue (vtkIdType id, T f) |
void | InsertVariantValue (vtkIdType id, vtkVariant value) |
vtkIdType | InsertNextValue (T f) |
double | GetComponent (vtkIdType i, int j) |
void | SetComponent (vtkIdType i, int j, double c) |
virtual void | InsertComponent (vtkIdType i, int j, double c) |
virtual void | ExportToVoidPointer (void *out_ptr) |
virtual vtkArrayIterator * | NewIterator () |
virtual void | DataChanged () |
virtual void | DataElementChanged (vtkIdType id) |
virtual void | ClearLookup () |
void | GetTuple (vtkIdType i, double *tuple) |
void | GetTupleValue (vtkIdType i, T *tuple) |
void | SetTuple (vtkIdType i, const float *tuple) |
void | SetTuple (vtkIdType i, const double *tuple) |
void | SetTupleValue (vtkIdType i, const T *tuple) |
void | InsertTuple (vtkIdType i, const float *tuple) |
void | InsertTuple (vtkIdType i, const double *tuple) |
void | InsertTupleValue (vtkIdType i, const T *tuple) |
vtkIdType | InsertNextTuple (const float *tuple) |
vtkIdType | InsertNextTuple (const double *tuple) |
vtkIdType | InsertNextTupleValue (const T *tuple) |
void | SetValue (vtkIdType id, T value) |
virtual void | RemoveTuple (vtkIdType id) |
virtual void | RemoveFirstTuple () |
virtual void | RemoveLastTuple () |
T * | WritePointer (vtkIdType id, vtkIdType number) |
virtual void * | WriteVoidPointer (vtkIdType id, vtkIdType number) |
T * | GetPointer (vtkIdType id) |
virtual void * | GetVoidPointer (vtkIdType id) |
void | DeepCopy (vtkDataArray *da) |
void | DeepCopy (vtkAbstractArray *aa) |
void | SetArray (T *array, vtkIdType size, int save, int deleteMethod) |
void | SetArray (T *array, vtkIdType size, int save) |
virtual void | SetVoidArray (void *array, vtkIdType size, int save) |
virtual void | SetVoidArray (void *array, vtkIdType size, int save, int deleteMethod) |
virtual vtkIdType | LookupValue (vtkVariant value) |
virtual void | LookupValue (vtkVariant value, vtkIdList *ids) |
vtkIdType | LookupValue (T value) |
void | LookupValue (T value, vtkIdList *ids) |
Protected Member Functions | |
vtkDataArrayTemplate (vtkIdType numComp) | |
~vtkDataArrayTemplate () | |
T * | ResizeAndExtend (vtkIdType sz) |
T * | Realloc (vtkIdType sz) |
virtual void | ComputeScalarRange (int comp) |
virtual void | ComputeVectorRange () |
Protected Attributes | |
T * | Array |
int | TupleSize |
double * | Tuple |
int | SaveUserArray |
int | DeleteMethod |
typedef vtkDataArray vtkDataArrayTemplate< T >::Superclass |
enum vtkDataArrayTemplate::DeleteMethod |
Definition at line 184 of file vtkDataArrayTemplate.h.
vtkDataArrayTemplate< T >::vtkDataArrayTemplate | ( | vtkIdType | numComp | ) | [protected] |
vtkDataArrayTemplate< T >::~vtkDataArrayTemplate | ( | ) | [protected] |
void vtkDataArrayTemplate< T >::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 vtkDataArray.
int vtkDataArrayTemplate< T >::Allocate | ( | vtkIdType | sz, | |
vtkIdType | ext = 1000 | |||
) | [virtual] |
Allocate memory for this array. Delete old storage only if necessary. Note that ext is no longer used.
Implements vtkAbstractArray.
void vtkDataArrayTemplate< T >::Initialize | ( | ) | [virtual] |
Release storage and reset array to initial state.
Implements vtkAbstractArray.
int vtkDataArrayTemplate< T >::GetDataTypeSize | ( | ) | [inline, virtual] |
Return the size of the data type.
Implements vtkAbstractArray.
Definition at line 46 of file vtkDataArrayTemplate.h.
void vtkDataArrayTemplate< T >::SetNumberOfTuples | ( | vtkIdType | number | ) | [virtual] |
Set the number of n-tuples in the array.
Implements vtkAbstractArray.
virtual void vtkDataArrayTemplate< T >::SetTuple | ( | vtkIdType | i, | |
vtkIdType | j, | |||
vtkAbstractArray * | source | |||
) | [virtual] |
Set the tuple at the ith location using the jth tuple in the source array. This method assumes that the two arrays have the same type and structure. Note that range checking and memory allocation is not performed; use in conjunction with SetNumberOfTuples() to allocate space.
Implements vtkDataArray.
virtual void vtkDataArrayTemplate< T >::InsertTuple | ( | vtkIdType | i, | |
vtkIdType | j, | |||
vtkAbstractArray * | source | |||
) | [virtual] |
Insert the jth tuple in the source array, at ith location in this array. Note that memory allocation is performed as necessary to hold the data.
Implements vtkDataArray.
virtual vtkIdType vtkDataArrayTemplate< T >::InsertNextTuple | ( | vtkIdType | j, | |
vtkAbstractArray * | source | |||
) | [virtual] |
Insert the jth tuple in the source array, at the end in this array. Note that memory allocation is performed as necessary to hold the data. Returns the location at which the data was inserted.
Implements vtkDataArray.
double* vtkDataArrayTemplate< T >::GetTuple | ( | vtkIdType | i | ) | [virtual] |
Get a pointer to a tuple at the ith location. This is a dangerous method (it is not thread safe since a pointer is returned).
Implements vtkDataArray.
void vtkDataArrayTemplate< T >::GetTuple | ( | vtkIdType | i, | |
double * | tuple | |||
) | [virtual] |
Copy the tuple value into a user-provided array.
Implements vtkDataArray.
void vtkDataArrayTemplate< T >::GetTupleValue | ( | vtkIdType | i, | |
T * | tuple | |||
) |
Copy the tuple value into a user-provided array.
void vtkDataArrayTemplate< T >::SetTuple | ( | vtkIdType | i, | |
const float * | tuple | |||
) | [virtual] |
Set the tuple value at the ith location in the array.
Implements vtkDataArray.
void vtkDataArrayTemplate< T >::SetTuple | ( | vtkIdType | i, | |
const double * | tuple | |||
) | [virtual] |
Set the tuple value at the ith location in the array.
Implements vtkDataArray.
void vtkDataArrayTemplate< T >::SetTupleValue | ( | vtkIdType | i, | |
const T * | tuple | |||
) |
Set the tuple value at the ith location in the array.
void vtkDataArrayTemplate< T >::InsertTuple | ( | vtkIdType | i, | |
const float * | tuple | |||
) | [virtual] |
Insert (memory allocation performed) the tuple into the ith location in the array.
Implements vtkDataArray.
void vtkDataArrayTemplate< T >::InsertTuple | ( | vtkIdType | i, | |
const double * | tuple | |||
) | [virtual] |
Insert (memory allocation performed) the tuple into the ith location in the array.
Implements vtkDataArray.
void vtkDataArrayTemplate< T >::InsertTupleValue | ( | vtkIdType | i, | |
const T * | tuple | |||
) |
Insert (memory allocation performed) the tuple into the ith location in the array.
vtkIdType vtkDataArrayTemplate< T >::InsertNextTuple | ( | const float * | tuple | ) | [virtual] |
Insert (memory allocation performed) the tuple onto the end of the array.
Implements vtkDataArray.
vtkIdType vtkDataArrayTemplate< T >::InsertNextTuple | ( | const double * | tuple | ) | [virtual] |
Insert (memory allocation performed) the tuple onto the end of the array.
Implements vtkDataArray.
vtkIdType vtkDataArrayTemplate< T >::InsertNextTupleValue | ( | const T * | tuple | ) |
Insert (memory allocation performed) the tuple onto the end of the array.
void vtkDataArrayTemplate< T >::Squeeze | ( | ) | [inline, virtual] |
Resize object to just fit data requirement. Reclaims extra memory.
Implements vtkAbstractArray.
Definition at line 102 of file vtkDataArrayTemplate.h.
vtkIdType vtkDataArrayTemplate< T >::Capacity | ( | ) | [inline] |
Return the capacity in typeof T units of the current array.
Definition at line 105 of file vtkDataArrayTemplate.h.
virtual int vtkDataArrayTemplate< T >::Resize | ( | vtkIdType | numTuples | ) | [virtual] |
Resize the array while conserving the data.
Implements vtkAbstractArray.
T vtkDataArrayTemplate< T >::GetValue | ( | vtkIdType | id | ) | [inline] |
Get the data at a particular index.
Definition at line 111 of file vtkDataArrayTemplate.h.
void vtkDataArrayTemplate< T >::SetValue | ( | vtkIdType | id, | |
T | value | |||
) | [inline] |
Set the data at a particular index. Does not do range checking. Make sure you use the method SetNumberOfValues() before inserting data.
Definition at line 116 of file vtkDataArrayTemplate.h.
void vtkDataArrayTemplate< T >::SetNumberOfValues | ( | vtkIdType | number | ) |
Specify the number of values for this object to hold. Does an allocation as well as setting the MaxId ivar. Used in conjunction with SetValue() method for fast insertion.
void vtkDataArrayTemplate< T >::InsertValue | ( | vtkIdType | id, | |
T | f | |||
) |
Insert data at a specified position in the array.
void vtkDataArrayTemplate< T >::InsertVariantValue | ( | vtkIdType | id, | |
vtkVariant | value | |||
) | [virtual] |
Insert data at a specified position in the array.
Implements vtkAbstractArray.
vtkIdType vtkDataArrayTemplate< T >::InsertNextValue | ( | T | f | ) |
Insert data at the end of the array. Return its location in the array.
virtual void vtkDataArrayTemplate< T >::RemoveTuple | ( | vtkIdType | id | ) | [virtual] |
These methods remove tuples from the data array. They shift data and resize array, so the data array is still valid after this operation. Note, this operation is fairly slow.
Implements vtkDataArray.
virtual void vtkDataArrayTemplate< T >::RemoveFirstTuple | ( | ) | [virtual] |
These methods remove tuples from the data array. They shift data and resize array, so the data array is still valid after this operation. Note, this operation is fairly slow.
Implements vtkDataArray.
virtual void vtkDataArrayTemplate< T >::RemoveLastTuple | ( | ) | [virtual] |
These methods remove tuples from the data array. They shift data and resize array, so the data array is still valid after this operation. Note, this operation is fairly slow.
Implements vtkDataArray.
double vtkDataArrayTemplate< T >::GetComponent | ( | vtkIdType | i, | |
int | j | |||
) | [virtual] |
Return the data component at the ith tuple and jth component location. Note that i is less then NumberOfTuples and j is less then NumberOfComponents.
Reimplemented from vtkDataArray.
void vtkDataArrayTemplate< T >::SetComponent | ( | vtkIdType | i, | |
int | j, | |||
double | c | |||
) | [virtual] |
Set the data component at the ith tuple and jth component location. Note that i is less then NumberOfTuples and j is less then NumberOfComponents. Make sure enough memory has been allocated (use SetNumberOfTuples() and SetNumberOfComponents()).
Reimplemented from vtkDataArray.
virtual void vtkDataArrayTemplate< T >::InsertComponent | ( | vtkIdType | i, | |
int | j, | |||
double | c | |||
) | [virtual] |
Insert the data component at ith tuple and jth component location. Note that memory allocation is performed as necessary to hold the data.
Reimplemented from vtkDataArray.
T* vtkDataArrayTemplate< T >::WritePointer | ( | vtkIdType | id, | |
vtkIdType | number | |||
) |
Get the address of a particular data index. Make sure data is allocated for the number of items requested. Set MaxId according to the number of data values requested.
virtual void* vtkDataArrayTemplate< T >::WriteVoidPointer | ( | vtkIdType | id, | |
vtkIdType | number | |||
) | [inline, virtual] |
Get the address of a particular data index. Make sure data is allocated for the number of items requested. Set MaxId according to the number of data values requested.
Implements vtkDataArray.
Definition at line 165 of file vtkDataArrayTemplate.h.
T* vtkDataArrayTemplate< T >::GetPointer | ( | vtkIdType | id | ) | [inline] |
Get the address of a particular data index. Performs no checks to verify that the memory has been allocated etc.
Definition at line 172 of file vtkDataArrayTemplate.h.
virtual void* vtkDataArrayTemplate< T >::GetVoidPointer | ( | vtkIdType | id | ) | [inline, virtual] |
Get the address of a particular data index. Performs no checks to verify that the memory has been allocated etc.
Implements vtkAbstractArray.
Definition at line 173 of file vtkDataArrayTemplate.h.
void vtkDataArrayTemplate< T >::DeepCopy | ( | vtkDataArray * | da | ) | [virtual] |
Deep copy of another double array.
Reimplemented from vtkDataArray.
void vtkDataArrayTemplate< T >::DeepCopy | ( | vtkAbstractArray * | aa | ) | [inline, virtual] |
Deep copy of another double array.
Reimplemented from vtkDataArray.
Definition at line 179 of file vtkDataArrayTemplate.h.
void vtkDataArrayTemplate< T >::SetArray | ( | T * | array, | |
vtkIdType | size, | |||
int | save, | |||
int | deleteMethod | |||
) |
This method lets the user specify data to be held by the array. The array argument is a pointer to the data. size is the size of the array supplied by the user. Set save to 1 to keep the class from deleting the array when it cleans up or reallocates memory. The class uses the actual array provided; it does not copy the data from the suppled array. If specified, the delete method determines how the data array will be deallocated. If the delete method is VTK_DATA_ARRAY_FREE, free() will be used. If the delete method is DELETE, delete[] will be used. The default is FREE.
void vtkDataArrayTemplate< T >::SetArray | ( | T * | array, | |
vtkIdType | size, | |||
int | save | |||
) | [inline] |
This method lets the user specify data to be held by the array. The array argument is a pointer to the data. size is the size of the array supplied by the user. Set save to 1 to keep the class from deleting the array when it cleans up or reallocates memory. The class uses the actual array provided; it does not copy the data from the suppled array. If specified, the delete method determines how the data array will be deallocated. If the delete method is VTK_DATA_ARRAY_FREE, free() will be used. If the delete method is DELETE, delete[] will be used. The default is FREE.
Definition at line 202 of file vtkDataArrayTemplate.h.
virtual void vtkDataArrayTemplate< T >::SetVoidArray | ( | void * | array, | |
vtkIdType | size, | |||
int | save | |||
) | [inline, virtual] |
This method lets the user specify data to be held by the array. The array argument is a pointer to the data. size is the size of the array supplied by the user. Set save to 1 to keep the class from deleting the array when it cleans up or reallocates memory. The class uses the actual array provided; it does not copy the data from the suppled array. If specified, the delete method determines how the data array will be deallocated. If the delete method is VTK_DATA_ARRAY_FREE, free() will be used. If the delete method is DELETE, delete[] will be used. The default is FREE.
Definition at line 204 of file vtkDataArrayTemplate.h.
virtual void vtkDataArrayTemplate< T >::SetVoidArray | ( | void * | array, | |
vtkIdType | size, | |||
int | save, | |||
int | deleteMethod | |||
) | [inline, virtual] |
This method lets the user specify data to be held by the array. The array argument is a pointer to the data. size is the size of the array supplied by the user. Set save to 1 to keep the class from deleting the array when it cleans up or reallocates memory. The class uses the actual array provided; it does not copy the data from the suppled array. If specified, the delete method determines how the data array will be deallocated. If the delete method is VTK_DATA_ARRAY_FREE, free() will be used. If the delete method is DELETE, delete[] will be used. The default is FREE.
Definition at line 206 of file vtkDataArrayTemplate.h.
virtual void vtkDataArrayTemplate< T >::ExportToVoidPointer | ( | void * | out_ptr | ) | [virtual] |
This method copies the array data to the void pointer specified by the user. It is up to the user to allocate enough memory for the void pointer.
virtual vtkArrayIterator* vtkDataArrayTemplate< T >::NewIterator | ( | ) | [virtual] |
Returns a vtkArrayIteratorTemplate<T>.
Implements vtkAbstractArray.
virtual vtkIdType vtkDataArrayTemplate< T >::LookupValue | ( | vtkVariant | value | ) | [virtual] |
Return the indices where a specific value appears.
Implements vtkAbstractArray.
virtual void vtkDataArrayTemplate< T >::LookupValue | ( | vtkVariant | value, | |
vtkIdList * | ids | |||
) | [virtual] |
Return the indices where a specific value appears.
Implements vtkAbstractArray.
vtkIdType vtkDataArrayTemplate< T >::LookupValue | ( | T | value | ) |
Return the indices where a specific value appears.
void vtkDataArrayTemplate< T >::LookupValue | ( | T | value, | |
vtkIdList * | ids | |||
) |
Return the indices where a specific value appears.
virtual void vtkDataArrayTemplate< T >::DataChanged | ( | ) | [virtual] |
Tell the array explicitly that the data has changed. This is only necessary to call when you modify the array contents without using the array's API (i.e. you retrieve a pointer to the data and modify the array contents). You need to call this so that the fast lookup will know to rebuild itself. Otherwise, the lookup functions will give incorrect results.
Implements vtkAbstractArray.
virtual void vtkDataArrayTemplate< T >::DataElementChanged | ( | vtkIdType | id | ) | [virtual] |
Tell the array explicitly that a single data element has changed. Like DataChanged(), then is only necessary when you modify the array contents without using the array's API.
virtual void vtkDataArrayTemplate< T >::ClearLookup | ( | ) | [virtual] |
Delete the associated fast lookup data structure on this array, if it exists. The lookup will be rebuilt on the next call to a lookup function.
Implements vtkAbstractArray.
T* vtkDataArrayTemplate< T >::ResizeAndExtend | ( | vtkIdType | sz | ) | [protected] |
T* vtkDataArrayTemplate< T >::Realloc | ( | vtkIdType | sz | ) | [protected] |
virtual void vtkDataArrayTemplate< T >::ComputeScalarRange | ( | int | comp | ) | [protected, virtual] |
Compute the range for a specific component. If comp is set -1 then L2 norm is computed on all components. Call ClearRange to force a recomputation if it is needed.
Reimplemented from vtkDataArray.
virtual void vtkDataArrayTemplate< T >::ComputeVectorRange | ( | ) | [protected, virtual] |
Compute the range for a specific component. If comp is set -1 then L2 norm is computed on all components. Call ClearRange to force a recomputation if it is needed.
Reimplemented from vtkDataArray.
T* vtkDataArrayTemplate< T >::Array [protected] |
Definition at line 255 of file vtkDataArrayTemplate.h.
int vtkDataArrayTemplate< T >::TupleSize [protected] |
Definition at line 259 of file vtkDataArrayTemplate.h.
double* vtkDataArrayTemplate< T >::Tuple [protected] |
Definition at line 260 of file vtkDataArrayTemplate.h.
int vtkDataArrayTemplate< T >::SaveUserArray [protected] |
Definition at line 262 of file vtkDataArrayTemplate.h.
int vtkDataArrayTemplate< T >::DeleteMethod [protected] |
Definition at line 263 of file vtkDataArrayTemplate.h.