00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035
00036
00037
00038
00039
00054 #ifndef __vtkUnsignedShortArray_h
00055 #define __vtkUnsignedShortArray_h
00056
00057 #include "vtkDataArray.h"
00058
00059 class VTK_EXPORT vtkUnsignedShortArray : public vtkDataArray
00060 {
00061 public:
00062 static vtkUnsignedShortArray *New();
00063
00064 vtkTypeMacro(vtkUnsignedShortArray,vtkDataArray);
00065 void PrintSelf(ostream& os, vtkIndent indent);
00066
00068 int Allocate(const int sz, const int ext=1000);
00069
00071 void Initialize();
00072
00074 vtkDataArray *MakeObject();
00075
00077 int GetDataType() {return VTK_UNSIGNED_SHORT;};
00078
00080 void SetNumberOfTuples(const int number);
00081
00084 float *GetTuple(const int i);
00085
00087 void GetTuple(const int i, float * tuple);
00088 void GetTuple(const int i, double * tuple);
00089
00091 void SetTuple(const int i, const float * tuple);
00092 void SetTuple(const int i, const double * tuple);
00093
00096 void InsertTuple(const int i, const float * tuple);
00097 void InsertTuple(const int i, const double * tuple);
00098
00101 int InsertNextTuple(const float * tuple);
00102 int InsertNextTuple(const double * tuple);
00103
00107 float GetComponent(const int i, const int j);
00108
00113 void SetComponent(const int i, const int j, const float c);
00114
00118 void InsertComponent(const int i, const int j, const float c);
00119
00121 unsigned short GetValue(const int id) {return this->Array[id];};
00122
00125 void SetValue(const int id, const unsigned short value) {
00126 this->Array[id] = value;};
00127
00131 void SetNumberOfValues(const int number);
00132
00134 void InsertValue(const int id, const unsigned short i);
00135
00138 int InsertNextValue(const unsigned short);
00139
00142 unsigned short *GetPointer(const int id) {return this->Array + id;}
00143 void *GetVoidPointer(const int id) {return (void *)this->GetPointer(id);};
00144
00148 unsigned short *WritePointer(const int id, const int number);
00149
00151 void DeepCopy(vtkDataArray *ia);
00152
00159 void SetArray(unsigned short* array, int size, int save);
00160 void SetVoidArray(void *array,int size, int save)
00161 {this->SetArray((unsigned short*)array, size, save);};
00162
00164 void Squeeze() {this->Resize (this->MaxId+1);};
00165
00166 #ifndef VTK_REMOVE_LEGACY_CODE
00167
00168 void DeepCopy(vtkDataArray &ia)
00169 {VTK_LEGACY_METHOD(DeepCopy,"3.2"); this->DeepCopy(&ia);}
00170 #endif
00171
00172
00173 protected:
00174 vtkUnsignedShortArray(int numComp=1);
00175 ~vtkUnsignedShortArray();
00176 vtkUnsignedShortArray(const vtkUnsignedShortArray&) {};
00177 void operator=(const vtkUnsignedShortArray&) {};
00178
00179 unsigned short *Array;
00180 unsigned short *Resize(const int sz);
00181
00182 int TupleSize;
00183 float *Tuple;
00184
00185 int SaveUserArray;
00186 };
00187
00188 inline void vtkUnsignedShortArray::SetNumberOfValues(const int number)
00189 {
00190 this->Allocate(number);
00191 this->MaxId = number - 1;
00192 }
00193
00194 inline unsigned short *vtkUnsignedShortArray::WritePointer(const int id, const int number)
00195 {
00196 int newSize=id+number;
00197 if ( newSize > this->Size )
00198 {
00199 this->Resize(newSize);
00200 }
00201 if ( (--newSize) > this->MaxId )
00202 {
00203 this->MaxId = newSize;
00204 }
00205 return this->Array + id;
00206 }
00207
00208 inline void vtkUnsignedShortArray::InsertValue(const int id, const unsigned short i)
00209 {
00210 if ( id >= this->Size )
00211 {
00212 this->Resize(id+1);
00213 }
00214 this->Array[id] = i;
00215 if ( id > this->MaxId )
00216 {
00217 this->MaxId = id;
00218 }
00219 }
00220
00221 inline int vtkUnsignedShortArray::InsertNextValue(const unsigned short i)
00222 {
00223 this->InsertValue (++this->MaxId,i);
00224 return this->MaxId;
00225 }
00226
00227 #endif
00228
00229
00230
00231