Converted the template DrawElements primitive class into three seperate
non templated classes - UByteDrawElements, UShortDrawElements, UIntDrawElements.
This commit is contained in:
parent
532a32416f
commit
fb3e705709
@ -15,86 +15,87 @@
|
||||
|
||||
namespace osg {
|
||||
|
||||
enum ArrayType
|
||||
{
|
||||
AttributeArrayType = 0,
|
||||
ByteArrayType = 1,
|
||||
ShortArrayType = 2,
|
||||
IntArrayType = 3,
|
||||
UByteArrayType = 4,
|
||||
UShortArrayType = 5,
|
||||
UIntArrayType = 6,
|
||||
UByte4ArrayType = 7,
|
||||
FloatArrayType = 8,
|
||||
Vec2ArrayType = 9,
|
||||
Vec3ArrayType = 10,
|
||||
Vec4ArrayType = 11
|
||||
};
|
||||
|
||||
class SG_EXPORT AttributeArray : public Object
|
||||
class SG_EXPORT Array : public Object
|
||||
{
|
||||
|
||||
public:
|
||||
|
||||
AttributeArray(ArrayType arrayType=AttributeArrayType,GLint dataSize=0,GLenum dataType=0):
|
||||
enum Type
|
||||
{
|
||||
ArrayType = 0,
|
||||
ByteArrayType = 1,
|
||||
ShortArrayType = 2,
|
||||
IntArrayType = 3,
|
||||
UByteArrayType = 4,
|
||||
UShortArrayType = 5,
|
||||
UIntArrayType = 6,
|
||||
UByte4ArrayType = 7,
|
||||
FloatArrayType = 8,
|
||||
Vec2ArrayType = 9,
|
||||
Vec3ArrayType = 10,
|
||||
Vec4ArrayType = 11
|
||||
};
|
||||
|
||||
Array(Type arrayType=ArrayType,GLint dataSize=0,GLenum dataType=0):
|
||||
_arrayType(arrayType),
|
||||
_dataSize(dataSize),
|
||||
_dataType(dataType) {}
|
||||
|
||||
AttributeArray(const AttributeArray& array,const CopyOp& copyop=CopyOp::SHALLOW_COPY):
|
||||
Array(const Array& array,const CopyOp& copyop=CopyOp::SHALLOW_COPY):
|
||||
Object(array,copyop),
|
||||
_arrayType(array._arrayType),
|
||||
_dataSize(array._dataSize),
|
||||
_dataType(array._dataType) {}
|
||||
|
||||
virtual bool isSameKindAs(const Object* obj) const { return dynamic_cast<const AttributeArray*>(obj)!=NULL; }
|
||||
virtual bool isSameKindAs(const Object* obj) const { return dynamic_cast<const Array*>(obj)!=NULL; }
|
||||
virtual const char* libraryName() const { return "osg"; }
|
||||
virtual const char* className() const;
|
||||
|
||||
|
||||
ArrayType arrayType() const { return _arrayType; }
|
||||
Type getType() const { return _arrayType; }
|
||||
GLint dataSize() const { return _dataSize; }
|
||||
GLenum dataType() const { return _dataType; }
|
||||
virtual const GLvoid* dataPointer() const = 0;
|
||||
|
||||
protected:
|
||||
|
||||
virtual ~AttributeArray() {}
|
||||
virtual ~Array() {}
|
||||
|
||||
ArrayType _arrayType;
|
||||
Type _arrayType;
|
||||
GLint _dataSize;
|
||||
GLenum _dataType;
|
||||
};
|
||||
|
||||
|
||||
|
||||
template<typename T, ArrayType ARRAYTYPE, int DataSize, int DataType>
|
||||
class TemplateArray : public AttributeArray, public std::vector<T>
|
||||
template<typename T, Array::Type ARRAYTYPE, int DataSize, int DataType>
|
||||
class TemplateArray : public Array, public std::vector<T>
|
||||
{
|
||||
public:
|
||||
|
||||
TemplateArray() : AttributeArray(ARRAYTYPE,DataSize,DataType) {}
|
||||
TemplateArray() : Array(ARRAYTYPE,DataSize,DataType) {}
|
||||
|
||||
TemplateArray(const TemplateArray& ta,const CopyOp& copyop=CopyOp::SHALLOW_COPY):
|
||||
AttributeArray(ta,copyop),
|
||||
Array(ta,copyop),
|
||||
std::vector<T>(ta) {}
|
||||
|
||||
TemplateArray(unsigned int no) :
|
||||
AttributeArray(ARRAYTYPE,DataSize,DataType),
|
||||
Array(ARRAYTYPE,DataSize,DataType),
|
||||
std::vector<T>(no) {}
|
||||
|
||||
TemplateArray(unsigned int no,T* ptr) :
|
||||
AttributeArray(ARRAYTYPE,DataSize,DataType),
|
||||
Array(ARRAYTYPE,DataSize,DataType),
|
||||
std::vector<T>(ptr,ptr+no) {}
|
||||
|
||||
|
||||
template <class InputIterator>
|
||||
TemplateArray(InputIterator first,InputIterator last) :
|
||||
AttributeArray(ARRAYTYPE,DataSize,DataType),
|
||||
Array(ARRAYTYPE,DataSize,DataType),
|
||||
std::vector<T>(first,last) {}
|
||||
|
||||
// TemplateArray(T* first,T* last) :
|
||||
// AttributeArray(ARRAYTYPE,DataSize,DataType),
|
||||
// Array(ARRAYTYPE,DataSize,DataType),
|
||||
// std::vector<T>(first,last) {}
|
||||
|
||||
virtual Object* cloneType() const { return osgNew TemplateArray(); }
|
||||
@ -103,17 +104,17 @@ class TemplateArray : public AttributeArray, public std::vector<T>
|
||||
virtual const GLvoid* dataPointer() const { if (!empty()) return &front(); else return 0; }
|
||||
};
|
||||
|
||||
typedef TemplateArray<char,ByteArrayType,1,GL_BYTE> ByteArray;
|
||||
typedef TemplateArray<short,ShortArrayType,1,GL_SHORT> ShortArray;
|
||||
typedef TemplateArray<int,IntArrayType,1,GL_INT> IntArray;
|
||||
typedef TemplateArray<unsigned char,UByteArrayType,1,GL_UNSIGNED_BYTE> UByteArray;
|
||||
typedef TemplateArray<unsigned short,UShortArrayType,1,GL_UNSIGNED_SHORT> UShortArray;
|
||||
typedef TemplateArray<unsigned int,UIntArrayType,1,GL_UNSIGNED_INT> UIntArray;
|
||||
typedef TemplateArray<unsigned int,UByte4ArrayType,4,GL_UNSIGNED_BYTE> UByte4Array;
|
||||
typedef TemplateArray<float,FloatArrayType,1,GL_FLOAT> FloatArray;
|
||||
typedef TemplateArray<Vec2,Vec2ArrayType,2,GL_FLOAT> Vec2Array;
|
||||
typedef TemplateArray<Vec3,Vec3ArrayType,3,GL_FLOAT> Vec3Array;
|
||||
typedef TemplateArray<Vec4,Vec4ArrayType,4,GL_FLOAT> Vec4Array;
|
||||
typedef TemplateArray<char,Array::ByteArrayType,1,GL_BYTE> ByteArray;
|
||||
typedef TemplateArray<short,Array::ShortArrayType,1,GL_SHORT> ShortArray;
|
||||
typedef TemplateArray<int,Array::IntArrayType,1,GL_INT> IntArray;
|
||||
typedef TemplateArray<unsigned char,Array::UByteArrayType,1,GL_UNSIGNED_BYTE> UByteArray;
|
||||
typedef TemplateArray<unsigned short,Array::UShortArrayType,1,GL_UNSIGNED_SHORT> UShortArray;
|
||||
typedef TemplateArray<unsigned int,Array::UIntArrayType,1,GL_UNSIGNED_INT> UIntArray;
|
||||
typedef TemplateArray<unsigned int,Array::UByte4ArrayType,4,GL_UNSIGNED_BYTE> UByte4Array;
|
||||
typedef TemplateArray<float,Array::FloatArrayType,1,GL_FLOAT> FloatArray;
|
||||
typedef TemplateArray<Vec2,Array::Vec2ArrayType,2,GL_FLOAT> Vec2Array;
|
||||
typedef TemplateArray<Vec3,Array::Vec3ArrayType,3,GL_FLOAT> Vec3Array;
|
||||
typedef TemplateArray<Vec4,Array::Vec4ArrayType,4,GL_FLOAT> Vec4Array;
|
||||
|
||||
}
|
||||
|
||||
|
@ -54,17 +54,17 @@ class SG_EXPORT Geometry : public Drawable
|
||||
void setColorBinding(AttributeBinding ab) { _colorBinding = ab; }
|
||||
AttributeBinding getColorBinding() const { return _colorBinding; }
|
||||
|
||||
void setColorArray(AttributeArray* array) { _colorArray = array; if (!_colorArray.valid()) _colorBinding=BIND_OFF; dirtyDisplayList(); }
|
||||
AttributeArray* getColorArray() { return _colorArray.get(); }
|
||||
const AttributeArray* getColorArray() const { return _colorArray.get(); }
|
||||
void setColorArray(Array* array) { _colorArray = array; if (!_colorArray.valid()) _colorBinding=BIND_OFF; dirtyDisplayList(); }
|
||||
Array* getColorArray() { return _colorArray.get(); }
|
||||
const Array* getColorArray() const { return _colorArray.get(); }
|
||||
|
||||
|
||||
typedef std::vector< ref_ptr<AttributeArray> > TexCoordArrayList;
|
||||
typedef std::vector< ref_ptr<Array> > TexCoordArrayList;
|
||||
|
||||
|
||||
void setTexCoordArray(unsigned int unit,AttributeArray*);
|
||||
AttributeArray* getTexCoordArray(unsigned int unit);
|
||||
const AttributeArray* getTexCoordArray(unsigned int unit) const;
|
||||
void setTexCoordArray(unsigned int unit,Array*);
|
||||
Array* getTexCoordArray(unsigned int unit);
|
||||
const Array* getTexCoordArray(unsigned int unit) const;
|
||||
|
||||
unsigned int getNumTexCoordArrays() const { return _texCoordList.size(); }
|
||||
TexCoordArrayList& getTexCoordArrayList() { return _texCoordList; }
|
||||
@ -118,7 +118,7 @@ class SG_EXPORT Geometry : public Drawable
|
||||
ref_ptr<Vec3Array> _normalArray;
|
||||
|
||||
AttributeBinding _colorBinding;
|
||||
ref_ptr<AttributeArray> _colorArray;
|
||||
ref_ptr<Array> _colorArray;
|
||||
|
||||
TexCoordArrayList _texCoordList;
|
||||
|
||||
|
@ -9,19 +9,20 @@
|
||||
|
||||
namespace osg {
|
||||
|
||||
enum PrimitiveType
|
||||
{
|
||||
PrimitivePrimitiveType = 0,
|
||||
DrawArraysPrimitiveType = 1,
|
||||
UByteDrawElementsPrimitiveType = 2,
|
||||
UShortDrawElementsPrimitiveType = 3,
|
||||
UIntDrawElementsPrimitiveType = 4,
|
||||
};
|
||||
|
||||
class SG_EXPORT Primitive : public Object
|
||||
class Primitive : public Object
|
||||
{
|
||||
public:
|
||||
|
||||
enum Type
|
||||
{
|
||||
PrimitiveType = 0,
|
||||
DrawArraysPrimitiveType = 1,
|
||||
UByteDrawElementsPrimitiveType = 2,
|
||||
UShortDrawElementsPrimitiveType = 3,
|
||||
UIntDrawElementsPrimitiveType = 4,
|
||||
};
|
||||
|
||||
enum Mode
|
||||
{
|
||||
POINTS = GL_POINTS,
|
||||
@ -36,7 +37,7 @@ class SG_EXPORT Primitive : public Object
|
||||
POLYGON = GL_POLYGON
|
||||
};
|
||||
|
||||
Primitive(PrimitiveType primType=PrimitivePrimitiveType,GLenum mode=0):
|
||||
Primitive(Type primType=PrimitiveType,GLenum mode=0):
|
||||
_primitiveType(primType),
|
||||
_mode(mode) {}
|
||||
|
||||
@ -47,9 +48,9 @@ class SG_EXPORT Primitive : public Object
|
||||
|
||||
virtual bool isSameKindAs(const Object* obj) const { return dynamic_cast<const Primitive*>(obj)!=NULL; }
|
||||
virtual const char* libraryName() const { return "osg"; }
|
||||
virtual const char* className() const;
|
||||
virtual const char* className() const { return "Primitve"; }
|
||||
|
||||
PrimitiveType primitiveType() const { return _primitiveType; }
|
||||
Type getType() const { return _primitiveType; }
|
||||
|
||||
void setMode(GLenum mode) { _mode = mode; }
|
||||
GLenum getMode() const { return _mode; }
|
||||
@ -60,16 +61,16 @@ class SG_EXPORT Primitive : public Object
|
||||
|
||||
protected:
|
||||
|
||||
PrimitiveType _primitiveType;
|
||||
Type _primitiveType;
|
||||
GLenum _mode;
|
||||
};
|
||||
|
||||
class DrawArrays : public Primitive
|
||||
class SG_EXPORT DrawArrays : public Primitive
|
||||
{
|
||||
public:
|
||||
|
||||
DrawArrays(GLenum mode=0):
|
||||
Primitive(DrawArraysPrimitiveType,0)
|
||||
Primitive(DrawArraysPrimitiveType,mode)
|
||||
{}
|
||||
|
||||
DrawArrays(GLenum mode, GLint first, GLsizei count):
|
||||
@ -102,71 +103,122 @@ class DrawArrays : public Primitive
|
||||
void setCount(GLsizei count) { _count = count; }
|
||||
GLsizei getCount() const { return _count; }
|
||||
|
||||
virtual void draw() const
|
||||
{
|
||||
glDrawArrays(_mode,_first,_count);
|
||||
}
|
||||
virtual void draw() const;
|
||||
|
||||
virtual void applyPrimitiveOperation(Drawable::PrimitiveFunctor& functor)
|
||||
{
|
||||
functor.drawArrays(_mode,_first,_count);
|
||||
}
|
||||
virtual void applyPrimitiveOperation(Drawable::PrimitiveFunctor& functor);
|
||||
|
||||
protected:
|
||||
|
||||
GLint _first;
|
||||
GLsizei _count;
|
||||
};
|
||||
|
||||
template<typename T, PrimitiveType PRIMTYPE, int DataType>
|
||||
class DrawElements : public Primitive, public std::vector<T>
|
||||
class SG_EXPORT UByteDrawElements : public Primitive, public std::vector<unsigned char>
|
||||
{
|
||||
public:
|
||||
|
||||
DrawElements(GLenum mode=0):
|
||||
Primitive(PRIMTYPE,mode),
|
||||
_dataType(DataType) {}
|
||||
UByteDrawElements(GLenum mode=0):
|
||||
Primitive(UByteDrawElementsPrimitiveType,mode) {}
|
||||
|
||||
DrawElements(const DrawElements& array,const CopyOp& copyop=CopyOp::SHALLOW_COPY):
|
||||
UByteDrawElements(const UByteDrawElements& array,const CopyOp& copyop=CopyOp::SHALLOW_COPY):
|
||||
Primitive(array,copyop),
|
||||
std::vector<T>(array),
|
||||
_dataType(array._dataType) {}
|
||||
std::vector<unsigned char>(array) {}
|
||||
|
||||
DrawElements(GLenum mode,unsigned int no,T* ptr) :
|
||||
Primitive(PRIMTYPE,mode),
|
||||
std::vector<T>(ptr,ptr+no),
|
||||
_dataType(DataType) {}
|
||||
UByteDrawElements(GLenum mode,unsigned int no,unsigned char* ptr) :
|
||||
Primitive(UByteDrawElementsPrimitiveType,mode),
|
||||
std::vector<unsigned char>(ptr,ptr+no) {}
|
||||
|
||||
DrawElements(GLenum mode,unsigned int no) :
|
||||
Primitive(PRIMTYPE,mode),
|
||||
std::vector<T>(no),
|
||||
_dataType(DataType) {}
|
||||
UByteDrawElements(GLenum mode,unsigned int no) :
|
||||
Primitive(UByteDrawElementsPrimitiveType,mode),
|
||||
std::vector<unsigned char>(no) {}
|
||||
|
||||
template <class InputIterator>
|
||||
DrawElements(GLenum mode, InputIterator first,InputIterator last) :
|
||||
Primitive(PRIMTYPE,mode),
|
||||
std::vector<T>(first,last),
|
||||
_dataType(DataType) {}
|
||||
UByteDrawElements(GLenum mode, InputIterator first,InputIterator last) :
|
||||
Primitive(UByteDrawElementsPrimitiveType,mode),
|
||||
std::vector<unsigned char>(first,last) {}
|
||||
|
||||
virtual Object* cloneType() const { return osgNew DrawElements(); }
|
||||
virtual Object* clone(const CopyOp& copyop) const { return osgNew DrawElements(*this,copyop); }
|
||||
virtual bool isSameKindAs(const Object* obj) const { return dynamic_cast<const DrawElements*>(obj)!=NULL; }
|
||||
virtual Object* cloneType() const { return osgNew UByteDrawElements(); }
|
||||
virtual Object* clone(const CopyOp& copyop) const { return osgNew UByteDrawElements(*this,copyop); }
|
||||
virtual bool isSameKindAs(const Object* obj) const { return dynamic_cast<const UByteDrawElements*>(obj)!=NULL; }
|
||||
virtual const char* libraryName() const { return "osg"; }
|
||||
virtual const char* className() const { return "UByteDrawElements"; }
|
||||
|
||||
virtual void draw() const
|
||||
{
|
||||
glDrawElements(_mode,size(),_dataType,&front());
|
||||
}
|
||||
virtual void draw() const ;
|
||||
|
||||
virtual void applyPrimitiveOperation(Drawable::PrimitiveFunctor& functor)
|
||||
{
|
||||
if (!empty()) functor.drawElements(_mode,size(),&front());
|
||||
}
|
||||
|
||||
GLenum _dataType;
|
||||
virtual void applyPrimitiveOperation(Drawable::PrimitiveFunctor& functor);
|
||||
};
|
||||
|
||||
class SG_EXPORT UShortDrawElements : public Primitive, public std::vector<unsigned short>
|
||||
{
|
||||
public:
|
||||
|
||||
UShortDrawElements(GLenum mode=0):
|
||||
Primitive(UShortDrawElementsPrimitiveType,mode) {}
|
||||
|
||||
UShortDrawElements(const UShortDrawElements& array,const CopyOp& copyop=CopyOp::SHALLOW_COPY):
|
||||
Primitive(array,copyop),
|
||||
std::vector<unsigned short>(array) {}
|
||||
|
||||
UShortDrawElements(GLenum mode,unsigned int no,unsigned short* ptr) :
|
||||
Primitive(UShortDrawElementsPrimitiveType,mode),
|
||||
std::vector<unsigned short>(ptr,ptr+no) {}
|
||||
|
||||
UShortDrawElements(GLenum mode,unsigned int no) :
|
||||
Primitive(UShortDrawElementsPrimitiveType,mode),
|
||||
std::vector<unsigned short>(no) {}
|
||||
|
||||
template <class InputIterator>
|
||||
UShortDrawElements(GLenum mode, InputIterator first,InputIterator last) :
|
||||
Primitive(UShortDrawElementsPrimitiveType,mode),
|
||||
std::vector<unsigned short>(first,last) {}
|
||||
|
||||
virtual Object* cloneType() const { return osgNew UShortDrawElements(); }
|
||||
virtual Object* clone(const CopyOp& copyop) const { return osgNew UShortDrawElements(*this,copyop); }
|
||||
virtual bool isSameKindAs(const Object* obj) const { return dynamic_cast<const UShortDrawElements*>(obj)!=NULL; }
|
||||
virtual const char* libraryName() const { return "osg"; }
|
||||
virtual const char* className() const { return "UShortDrawElements"; }
|
||||
|
||||
virtual void draw() const;
|
||||
|
||||
virtual void applyPrimitiveOperation(Drawable::PrimitiveFunctor& functor);
|
||||
};
|
||||
|
||||
class UIntDrawElements : public Primitive, public std::vector<unsigned int>
|
||||
{
|
||||
public:
|
||||
|
||||
UIntDrawElements(GLenum mode=0):
|
||||
Primitive(UIntDrawElementsPrimitiveType,mode) {}
|
||||
|
||||
UIntDrawElements(const UIntDrawElements& array,const CopyOp& copyop=CopyOp::SHALLOW_COPY):
|
||||
Primitive(array,copyop),
|
||||
std::vector<unsigned int>(array) {}
|
||||
|
||||
UIntDrawElements(GLenum mode,unsigned int no,unsigned int* ptr) :
|
||||
Primitive(UIntDrawElementsPrimitiveType,mode),
|
||||
std::vector<unsigned int>(ptr,ptr+no) {}
|
||||
|
||||
UIntDrawElements(GLenum mode,unsigned int no) :
|
||||
Primitive(UIntDrawElementsPrimitiveType,mode),
|
||||
std::vector<unsigned int>(no) {}
|
||||
|
||||
template <class InputIterator>
|
||||
UIntDrawElements(GLenum mode, InputIterator first,InputIterator last) :
|
||||
Primitive(UIntDrawElementsPrimitiveType,mode),
|
||||
std::vector<unsigned int>(first,last) {}
|
||||
|
||||
virtual Object* cloneType() const { return osgNew UIntDrawElements(); }
|
||||
virtual Object* clone(const CopyOp& copyop) const { return osgNew UIntDrawElements(*this,copyop); }
|
||||
virtual bool isSameKindAs(const Object* obj) const { return dynamic_cast<const UIntDrawElements*>(obj)!=NULL; }
|
||||
virtual const char* libraryName() const { return "osg"; }
|
||||
virtual const char* className() const { return "UIntDrawElements"; }
|
||||
|
||||
virtual void draw() const;
|
||||
|
||||
virtual void applyPrimitiveOperation(Drawable::PrimitiveFunctor& functor);
|
||||
|
||||
};
|
||||
|
||||
typedef DrawElements<unsigned char,UByteDrawElementsPrimitiveType,GL_UNSIGNED_BYTE> UByteDrawElements;
|
||||
typedef DrawElements<unsigned short,UShortDrawElementsPrimitiveType,GL_UNSIGNED_SHORT> UShortDrawElements;
|
||||
typedef DrawElements<unsigned int,UIntDrawElementsPrimitiveType,GL_UNSIGNED_INT> UIntDrawElements;
|
||||
}
|
||||
|
||||
#endif
|
||||
|
@ -4,7 +4,7 @@ using namespace osg;
|
||||
|
||||
static char* s_ArrayNames[] =
|
||||
{
|
||||
"AttributeArray", // 0
|
||||
"Array", // 0
|
||||
"ByteArray", // 1
|
||||
"ShortArray", // 2
|
||||
"IntArray", // 3
|
||||
@ -20,11 +20,11 @@ static char* s_ArrayNames[] =
|
||||
"Vec4Array", // 11
|
||||
};
|
||||
|
||||
const char* AttributeArray::className() const
|
||||
const char* Array::className() const
|
||||
{
|
||||
if (_arrayType>=AttributeArrayType && _arrayType<=Vec4ArrayType)
|
||||
if (_arrayType>=ArrayType && _arrayType<=Vec4ArrayType)
|
||||
return s_ArrayNames[_arrayType];
|
||||
else
|
||||
return "UnkownAttributeArray";
|
||||
return "UnkownArray";
|
||||
}
|
||||
|
||||
|
@ -24,7 +24,7 @@ Geometry::~Geometry()
|
||||
// no need to delete, all automatically handled by ref_ptr :-)
|
||||
}
|
||||
|
||||
void Geometry::setTexCoordArray(unsigned int unit,AttributeArray* array)
|
||||
void Geometry::setTexCoordArray(unsigned int unit,Array* array)
|
||||
{
|
||||
if (_texCoordList.size()<=unit)
|
||||
_texCoordList.resize(unit+1,0);
|
||||
@ -34,7 +34,7 @@ void Geometry::setTexCoordArray(unsigned int unit,AttributeArray* array)
|
||||
dirtyDisplayList();
|
||||
}
|
||||
|
||||
AttributeArray* Geometry::getTexCoordArray(unsigned int unit)
|
||||
Array* Geometry::getTexCoordArray(unsigned int unit)
|
||||
{
|
||||
if (unit<_texCoordList.size()) return _texCoordList[unit].get();
|
||||
else return 0;
|
||||
@ -52,7 +52,7 @@ void Geometry::drawImmediateMode(State& /*state*/)
|
||||
// set up texture coordinates.
|
||||
for(unsigned int i=0;i<_texCoordList.size();++i)
|
||||
{
|
||||
AttributeArray* array = _texCoordList[i].get();
|
||||
Array* array = _texCoordList[i].get();
|
||||
//glClientActiveTextureARB(GL_TEXTURE0_ARB+i);
|
||||
if (array)
|
||||
{
|
||||
@ -94,25 +94,25 @@ void Geometry::drawImmediateMode(State& /*state*/)
|
||||
// Vec3, Vec4 or UByte4 Arrays.
|
||||
const unsigned char* colorPointer = 0;
|
||||
unsigned int colorStride = 0;
|
||||
ArrayType colorType = AttributeArrayType;
|
||||
Array::Type colorType = Array::ArrayType;
|
||||
if (_colorArray.valid())
|
||||
{
|
||||
colorType = _colorArray->arrayType();
|
||||
colorType = _colorArray->getType();
|
||||
switch(colorType)
|
||||
{
|
||||
case(UByte4ArrayType):
|
||||
case(Array::UByte4ArrayType):
|
||||
{
|
||||
colorPointer = reinterpret_cast<const unsigned char*>(_colorArray->dataPointer());
|
||||
colorStride = 4;
|
||||
break;
|
||||
}
|
||||
case(Vec3ArrayType):
|
||||
case(Array::Vec3ArrayType):
|
||||
{
|
||||
colorPointer = reinterpret_cast<const unsigned char*>(_colorArray->dataPointer());
|
||||
colorStride = 12;
|
||||
break;
|
||||
}
|
||||
case(Vec4ArrayType):
|
||||
case(Array::Vec4ArrayType):
|
||||
{
|
||||
colorPointer = reinterpret_cast<const unsigned char*>(_colorArray->dataPointer());
|
||||
colorStride = 16;
|
||||
@ -132,13 +132,13 @@ void Geometry::drawImmediateMode(State& /*state*/)
|
||||
{
|
||||
switch(colorType)
|
||||
{
|
||||
case(UByte4ArrayType):
|
||||
case(Array::UByte4ArrayType):
|
||||
glColor4ubv(reinterpret_cast<const GLubyte*>(colorPointer));
|
||||
break;
|
||||
case(Vec3ArrayType):
|
||||
case(Array::Vec3ArrayType):
|
||||
glColor3fv(reinterpret_cast<const GLfloat*>(colorPointer));
|
||||
break;
|
||||
case(Vec4ArrayType):
|
||||
case(Array::Vec4ArrayType):
|
||||
glColor4fv(reinterpret_cast<const GLfloat*>(colorPointer));
|
||||
break;
|
||||
}
|
||||
@ -167,13 +167,13 @@ void Geometry::drawImmediateMode(State& /*state*/)
|
||||
{
|
||||
switch(colorType)
|
||||
{
|
||||
case(UByte4ArrayType):
|
||||
case(Array::UByte4ArrayType):
|
||||
glColor4ubv(reinterpret_cast<const GLubyte*>(colorPointer));
|
||||
break;
|
||||
case(Vec3ArrayType):
|
||||
case(Array::Vec3ArrayType):
|
||||
glColor3fv(reinterpret_cast<const GLfloat*>(colorPointer));
|
||||
break;
|
||||
case(Vec4ArrayType):
|
||||
case(Array::Vec4ArrayType):
|
||||
glColor4fv(reinterpret_cast<const GLfloat*>(colorPointer));
|
||||
break;
|
||||
}
|
||||
|
@ -2,20 +2,46 @@
|
||||
|
||||
using namespace osg;
|
||||
|
||||
static char* s_PrimitiveNames[] =
|
||||
void DrawArrays::draw() const
|
||||
{
|
||||
"Primitive", // 0
|
||||
"DrawArrays", // 1
|
||||
"UByteDrawElements", // 2
|
||||
"UShortDrawElements", // 3
|
||||
"UIntDrawElements" // 4
|
||||
};
|
||||
|
||||
const char* Primitive::className() const
|
||||
{
|
||||
if (_primitiveType>=PrimitivePrimitiveType && _primitiveType<=UIntDrawElementsPrimitiveType)
|
||||
return s_PrimitiveNames[_primitiveType];
|
||||
else
|
||||
return "UnkownAttributeArray";
|
||||
glDrawArrays(_mode,_first,_count);
|
||||
}
|
||||
|
||||
void DrawArrays::applyPrimitiveOperation(Drawable::PrimitiveFunctor& functor)
|
||||
{
|
||||
functor.drawArrays(_mode,_first,_count);
|
||||
}
|
||||
|
||||
|
||||
void UByteDrawElements::draw() const
|
||||
{
|
||||
glDrawElements(_mode,size(),GL_UNSIGNED_BYTE,&front());
|
||||
}
|
||||
|
||||
void UByteDrawElements::applyPrimitiveOperation(Drawable::PrimitiveFunctor& functor)
|
||||
{
|
||||
if (!empty()) functor.drawElements(_mode,size(),&front());
|
||||
}
|
||||
|
||||
|
||||
void UShortDrawElements::draw() const
|
||||
{
|
||||
glDrawElements(_mode,size(),GL_UNSIGNED_SHORT,&front());
|
||||
}
|
||||
|
||||
void UShortDrawElements::applyPrimitiveOperation(Drawable::PrimitiveFunctor& functor)
|
||||
{
|
||||
if (!empty()) functor.drawElements(_mode,size(),&front());
|
||||
}
|
||||
|
||||
|
||||
|
||||
void UIntDrawElements::draw() const
|
||||
{
|
||||
glDrawElements(_mode,size(),GL_UNSIGNED_INT,&front());
|
||||
}
|
||||
|
||||
void UIntDrawElements::applyPrimitiveOperation(Drawable::PrimitiveFunctor& functor)
|
||||
{
|
||||
if (!empty()) functor.drawElements(_mode,size(),&front());
|
||||
}
|
||||
|
@ -17,7 +17,7 @@ const char* Geometry_getBindingTypeStr(Geometry::AttributeBinding mode);
|
||||
bool Geometry_matchPrimitiveModeStr(const char* str,GLenum& mode);
|
||||
const char* Geometry_getPrimitiveModeStr(GLenum mode);
|
||||
|
||||
AttributeArray* AttributeArray_readLocalData(Input& fr);
|
||||
Array* Array_readLocalData(Input& fr);
|
||||
|
||||
bool Primitve_readLocalData(Input& fr,osg::Geometry& geom);
|
||||
|
||||
@ -149,7 +149,7 @@ bool Geometry_readLocalData(Object& obj, Input& fr)
|
||||
if (fr.matchSequence("ColorArray %w %i {"))
|
||||
{
|
||||
++fr;
|
||||
AttributeArray* colors = AttributeArray_readLocalData(fr);
|
||||
Array* colors = Array_readLocalData(fr);
|
||||
if (colors)
|
||||
{
|
||||
geom.setColorArray(colors);
|
||||
@ -163,7 +163,7 @@ bool Geometry_readLocalData(Object& obj, Input& fr)
|
||||
fr[1].getInt(unit);
|
||||
|
||||
fr+=2;
|
||||
AttributeArray* texcoords = AttributeArray_readLocalData(fr);
|
||||
Array* texcoords = Array_readLocalData(fr);
|
||||
if (texcoords)
|
||||
{
|
||||
geom.setTexCoordArray(unit,texcoords);
|
||||
@ -176,7 +176,7 @@ bool Geometry_readLocalData(Object& obj, Input& fr)
|
||||
}
|
||||
|
||||
|
||||
AttributeArray* AttributeArray_readLocalData(Input& fr)
|
||||
Array* Array_readLocalData(Input& fr)
|
||||
{
|
||||
int entry = fr[0].getNoNestedBrackets();
|
||||
|
||||
@ -396,11 +396,11 @@ void Array_writeLocalData(Output& fw, Iterator first, Iterator last)
|
||||
|
||||
}
|
||||
|
||||
bool Array_writeLocalData(const AttributeArray& array,Output& fw)
|
||||
bool Array_writeLocalData(const Array& array,Output& fw)
|
||||
{
|
||||
switch(array.arrayType())
|
||||
switch(array.getType())
|
||||
{
|
||||
case(ByteArrayType):
|
||||
case(Array::ByteArrayType):
|
||||
{
|
||||
const ByteArray& carray = static_cast<const ByteArray&>(array);
|
||||
fw<<array.className()<<" "<<carray.size()<<std::endl;
|
||||
@ -408,7 +408,7 @@ bool Array_writeLocalData(const AttributeArray& array,Output& fw)
|
||||
return true;
|
||||
}
|
||||
break;
|
||||
case(ShortArrayType):
|
||||
case(Array::ShortArrayType):
|
||||
{
|
||||
const ShortArray& carray = static_cast<const ShortArray&>(array);
|
||||
fw<<array.className()<<" "<<carray.size()<<std::endl;
|
||||
@ -416,7 +416,7 @@ bool Array_writeLocalData(const AttributeArray& array,Output& fw)
|
||||
return true;
|
||||
}
|
||||
break;
|
||||
case(IntArrayType):
|
||||
case(Array::IntArrayType):
|
||||
{
|
||||
const IntArray& carray = static_cast<const IntArray&>(array);
|
||||
fw<<array.className()<<" "<<carray.size()<<std::endl;
|
||||
@ -424,7 +424,7 @@ bool Array_writeLocalData(const AttributeArray& array,Output& fw)
|
||||
return true;
|
||||
}
|
||||
break;
|
||||
case(UByteArrayType):
|
||||
case(Array::UByteArrayType):
|
||||
{
|
||||
const UByteArray& carray = static_cast<const UByteArray&>(array);
|
||||
fw<<array.className()<<" "<<carray.size()<<std::endl;
|
||||
@ -432,7 +432,7 @@ bool Array_writeLocalData(const AttributeArray& array,Output& fw)
|
||||
return true;
|
||||
}
|
||||
break;
|
||||
case(UShortArrayType):
|
||||
case(Array::UShortArrayType):
|
||||
{
|
||||
const UShortArray& carray = static_cast<const UShortArray&>(array);
|
||||
fw<<array.className()<<" "<<carray.size()<<std::endl;
|
||||
@ -440,7 +440,7 @@ bool Array_writeLocalData(const AttributeArray& array,Output& fw)
|
||||
return true;
|
||||
}
|
||||
break;
|
||||
case(UIntArrayType):
|
||||
case(Array::UIntArrayType):
|
||||
{
|
||||
const UIntArray& carray = static_cast<const UIntArray&>(array);
|
||||
fw<<array.className()<<" "<<carray.size()<<" ";
|
||||
@ -448,7 +448,7 @@ bool Array_writeLocalData(const AttributeArray& array,Output& fw)
|
||||
return true;
|
||||
}
|
||||
break;
|
||||
case(UByte4ArrayType):
|
||||
case(Array::UByte4ArrayType):
|
||||
{
|
||||
const UByte4Array& carray = static_cast<const UByte4Array&>(array);
|
||||
fw<<array.className()<<" "<<carray.size()<<" ";
|
||||
@ -456,7 +456,7 @@ bool Array_writeLocalData(const AttributeArray& array,Output& fw)
|
||||
return true;
|
||||
}
|
||||
break;
|
||||
case(FloatArrayType):
|
||||
case(Array::FloatArrayType):
|
||||
{
|
||||
const FloatArray& carray = static_cast<const FloatArray&>(array);
|
||||
fw<<array.className()<<" "<<carray.size()<<std::endl;
|
||||
@ -464,7 +464,7 @@ bool Array_writeLocalData(const AttributeArray& array,Output& fw)
|
||||
return true;
|
||||
}
|
||||
break;
|
||||
case(Vec2ArrayType):
|
||||
case(Array::Vec2ArrayType):
|
||||
{
|
||||
const Vec2Array& carray = static_cast<const Vec2Array&>(array);
|
||||
fw<<array.className()<<" "<<carray.size()<<std::endl;
|
||||
@ -472,7 +472,7 @@ bool Array_writeLocalData(const AttributeArray& array,Output& fw)
|
||||
return true;
|
||||
}
|
||||
break;
|
||||
case(Vec3ArrayType):
|
||||
case(Array::Vec3ArrayType):
|
||||
{
|
||||
const Vec3Array& carray = static_cast<const Vec3Array&>(array);
|
||||
fw<<array.className()<<" "<<carray.size()<<std::endl;
|
||||
@ -480,7 +480,7 @@ bool Array_writeLocalData(const AttributeArray& array,Output& fw)
|
||||
return true;
|
||||
}
|
||||
break;
|
||||
case(Vec4ArrayType):
|
||||
case(Array::Vec4ArrayType):
|
||||
{
|
||||
const Vec4Array& carray = static_cast<const Vec4Array&>(array);
|
||||
fw<<array.className()<<" "<<carray.size()<<std::endl;
|
||||
@ -488,7 +488,7 @@ bool Array_writeLocalData(const AttributeArray& array,Output& fw)
|
||||
return true;
|
||||
}
|
||||
break;
|
||||
case(AttributeArrayType):
|
||||
case(Array::ArrayType):
|
||||
default:
|
||||
return false;
|
||||
}
|
||||
@ -617,16 +617,16 @@ bool Primitve_readLocalData(Input& fr,osg::Geometry& geom)
|
||||
bool Primitve_writeLocalData(const Primitive& prim,Output& fw)
|
||||
{
|
||||
|
||||
switch(prim.primitiveType())
|
||||
switch(prim.getType())
|
||||
{
|
||||
case(DrawArraysPrimitiveType):
|
||||
case(Primitive::DrawArraysPrimitiveType):
|
||||
{
|
||||
const DrawArrays& cprim = static_cast<const DrawArrays&>(prim);
|
||||
fw<<cprim.className()<<" "<<Geometry_getPrimitiveModeStr(cprim.getMode())<<" "<<cprim.getFirst()<<" "<<cprim.getCount()<<std::endl;
|
||||
return true;
|
||||
}
|
||||
break;
|
||||
case(UByteDrawElementsPrimitiveType):
|
||||
case(Primitive::UByteDrawElementsPrimitiveType):
|
||||
{
|
||||
const UByteDrawElements& cprim = static_cast<const UByteDrawElements&>(prim);
|
||||
fw<<cprim.className()<<" "<<Geometry_getPrimitiveModeStr(cprim.getMode())<<" "<<cprim.size()<<std::endl;
|
||||
@ -634,7 +634,7 @@ bool Primitve_writeLocalData(const Primitive& prim,Output& fw)
|
||||
return true;
|
||||
}
|
||||
break;
|
||||
case(UShortDrawElementsPrimitiveType):
|
||||
case(Primitive::UShortDrawElementsPrimitiveType):
|
||||
{
|
||||
const UShortDrawElements& cprim = static_cast<const UShortDrawElements&>(prim);
|
||||
fw<<cprim.className()<<" "<<Geometry_getPrimitiveModeStr(cprim.getMode())<<" "<<cprim.size()<<std::endl;
|
||||
@ -642,7 +642,7 @@ bool Primitve_writeLocalData(const Primitive& prim,Output& fw)
|
||||
return true;
|
||||
}
|
||||
break;
|
||||
case(UIntDrawElementsPrimitiveType):
|
||||
case(Primitive::UIntDrawElementsPrimitiveType):
|
||||
{
|
||||
const UIntDrawElements& cprim = static_cast<const UIntDrawElements&>(prim);
|
||||
fw<<cprim.className()<<" "<<Geometry_getPrimitiveModeStr(cprim.getMode())<<" "<<cprim.size()<<std::endl;
|
||||
|
Loading…
Reference in New Issue
Block a user