27 #ifndef __vtkBitArray_h
28 #define __vtkBitArray_h
32 class vtkBitArrayLookup;
128 void SetNumberOfValues(
vtkIdType number);
156 {
return this->WritePointer(
id, number); }
159 return static_cast<void *
>(this->GetPointer(
id));
178 void SetArray(
unsigned char* array,
vtkIdType size,
int save);
181 this->SetArray(static_cast<unsigned char *>(array), size, save);
214 unsigned char *ResizeAndExtend(
vtkIdType sz);
231 vtkBitArrayLookup* Lookup;
239 this->
MaxId = number - 1;
247 this->
Array[
id/8] =
static_cast<unsigned char>(
248 this->
Array[
id/8] | (0x80 >>
id%8));
252 this->
Array[
id/8] =
static_cast<unsigned char>(
253 this->
Array[
id/8] & (~(0x80 >>
id%8)));
260 if (
id >= this->
Size )
266 this->
Array[
id/8] =
static_cast<unsigned char>(
267 this->
Array[
id/8] | (0x80 >>
id%8));
271 this->
Array[
id/8] =
static_cast<unsigned char>(
272 this->
Array[
id/8] & (~(0x80 >>
id%8)));
274 if (
id > this->
MaxId )
virtual void DataChanged()
virtual double * GetTuple(vtkIdType i)=0
void SetVoidArray(void *array, vtkIdType size, int save)
virtual void DeepCopy(vtkAbstractArray *aa)
virtual void DataChanged()=0
virtual void DeepCopy(vtkAbstractArray *da)
Abstract superclass for all arrays.
virtual vtkIdType LookupValue(vtkVariant value)=0
virtual void RemoveFirstTuple()=0
virtual void SetNumberOfTuples(vtkIdType number)=0
virtual void InsertComponent(vtkIdType i, int j, double c)
void InsertValue(vtkIdType id, int i)
virtual void Initialize()=0
A atomic type representing the union of many types.
void SetValue(vtkIdType id, int value)
int ToInt(bool *valid) const
virtual int Allocate(vtkIdType sz, vtkIdType ext=1000)=0
virtual void InsertTuple(vtkIdType i, vtkIdType j, vtkAbstractArray *source)=0
unsigned char * GetPointer(vtkIdType id)
void SetNumberOfValues(vtkIdType number)
virtual void ClearLookup()=0
a simple class to control print indentation
virtual void RemoveLastTuple()=0
void SetVariantValue(vtkIdType idx, vtkVariant value)
void DeepCopy(vtkAbstractArray *aa)
list of point or cell ids
virtual int Resize(vtkIdType numTuples)=0
abstract superclass for arrays of numeric data
virtual vtkArrayIterator * NewIterator()=0
Abstract superclass to iterate over elements in an vtkAbstractArray.
virtual void SetTuple(vtkIdType i, vtkIdType j, vtkAbstractArray *source)=0
unsigned char * ResizeAndExtend(vtkIdType sz)
dynamic, self-adjusting array of bits
void * GetVoidPointer(vtkIdType id)
void save(Archiver &ar, const vtkVariant &variant, const unsigned int vtkNotUsed(version))
int Allocate(vtkIdType sz, vtkIdType ext=1000)
virtual void SetComponent(vtkIdType i, int j, double c)
vtkIdType InsertNextValue(int i)
void PrintSelf(ostream &os, vtkIndent indent)
virtual void RemoveTuple(vtkIdType id)=0
virtual void SetVariantValue(vtkIdType idx, vtkVariant value)=0
void * WriteVoidPointer(vtkIdType id, vtkIdType number)
virtual vtkIdType InsertNextTuple(vtkIdType j, vtkAbstractArray *source)=0