From Mike Weiblen, support for new Uniform arrays.
From Robert Osfield, refactor of above with original code to ensure backwards compatibility.
This commit is contained in:
parent
a18e697a47
commit
90fc234cf1
@ -24,9 +24,9 @@
|
||||
#define VERSION_0013 13
|
||||
#define VERSION_0014 14
|
||||
#define VERSION_0015 15
|
||||
#define VERSION_0016 16
|
||||
|
||||
//#define VERSION VERSION_0014
|
||||
#define VERSION VERSION_0015
|
||||
#define VERSION VERSION_0016
|
||||
|
||||
/* The BYTE_SEX tag is used to check the endian
|
||||
of the IVE file being read in. The IVE format
|
||||
|
@ -38,95 +38,105 @@ void Uniform::write(DataOutputStream* out){
|
||||
out->writeString(getName());
|
||||
}
|
||||
|
||||
switch( Uniform::getGlApiType(getType()) )
|
||||
if ( out->getVersion() >= VERSION_0016 )
|
||||
{
|
||||
case(osg::Uniform::FLOAT):
|
||||
out->writeInt(getNumElements());
|
||||
|
||||
if( getFloatArray() ) out->writeArray( getFloatArray() );
|
||||
if( getIntArray() ) out->writeArray( getIntArray() );
|
||||
}
|
||||
else
|
||||
{
|
||||
switch( Uniform::getGlApiType(getType()) )
|
||||
{
|
||||
float value;
|
||||
get(value);
|
||||
out->writeFloat(value);
|
||||
break;
|
||||
}
|
||||
case(osg::Uniform::FLOAT_VEC2):
|
||||
{
|
||||
osg::Vec2 value;
|
||||
get(value);
|
||||
out->writeVec2(value);
|
||||
break;
|
||||
}
|
||||
case(osg::Uniform::FLOAT_VEC3):
|
||||
{
|
||||
osg::Vec3 value;
|
||||
get(value);
|
||||
out->writeVec3(value);
|
||||
break;
|
||||
}
|
||||
case(osg::Uniform::FLOAT_VEC4):
|
||||
{
|
||||
osg::Vec4 value;
|
||||
get(value);
|
||||
out->writeVec4(value);
|
||||
break;
|
||||
}
|
||||
case(osg::Uniform::INT):
|
||||
{
|
||||
int i0;
|
||||
get(i0);
|
||||
out->writeInt(i0);
|
||||
break;
|
||||
}
|
||||
case(osg::Uniform::INT_VEC2):
|
||||
{
|
||||
int i0, i1;
|
||||
get(i0, i1);
|
||||
out->writeInt(i0);
|
||||
out->writeInt(i1);
|
||||
break;
|
||||
}
|
||||
case(osg::Uniform::INT_VEC3):
|
||||
{
|
||||
int i0, i1, i2;
|
||||
get(i0, i1, i2);
|
||||
out->writeInt(i0);
|
||||
out->writeInt(i1);
|
||||
out->writeInt(i2);
|
||||
break;
|
||||
}
|
||||
case(osg::Uniform::INT_VEC4):
|
||||
{
|
||||
int i0, i1, i2, i3;
|
||||
get(i0, i1, i2, i3);
|
||||
out->writeInt(i0);
|
||||
out->writeInt(i1);
|
||||
out->writeInt(i2);
|
||||
out->writeInt(i3);
|
||||
break;
|
||||
}
|
||||
case(osg::Uniform::FLOAT_MAT2):
|
||||
{
|
||||
osg::Matrix2 m2;
|
||||
get(m2);
|
||||
for(int i=0; i<4; ++i) out->writeFloat(m2[i]);
|
||||
break;
|
||||
}
|
||||
case(osg::Uniform::FLOAT_MAT3):
|
||||
{
|
||||
osg::Matrix3 m3;
|
||||
get(m3);
|
||||
for(int i=0; i<9; ++i) out->writeFloat(m3[i]);
|
||||
break;
|
||||
}
|
||||
case(osg::Uniform::FLOAT_MAT4):
|
||||
{
|
||||
osg::Matrixf matrix;
|
||||
get(matrix);
|
||||
out->writeMatrixf(matrix);
|
||||
break;
|
||||
}
|
||||
default:
|
||||
{
|
||||
osg::notify(osg::WARN)<<"Warning : uniform "<<getType()<<"type not supported for writing."<<std::endl;
|
||||
break;
|
||||
case(osg::Uniform::FLOAT):
|
||||
{
|
||||
float value;
|
||||
get(value);
|
||||
out->writeFloat(value);
|
||||
break;
|
||||
}
|
||||
case(osg::Uniform::FLOAT_VEC2):
|
||||
{
|
||||
osg::Vec2 value;
|
||||
get(value);
|
||||
out->writeVec2(value);
|
||||
break;
|
||||
}
|
||||
case(osg::Uniform::FLOAT_VEC3):
|
||||
{
|
||||
osg::Vec3 value;
|
||||
get(value);
|
||||
out->writeVec3(value);
|
||||
break;
|
||||
}
|
||||
case(osg::Uniform::FLOAT_VEC4):
|
||||
{
|
||||
osg::Vec4 value;
|
||||
get(value);
|
||||
out->writeVec4(value);
|
||||
break;
|
||||
}
|
||||
case(osg::Uniform::INT):
|
||||
{
|
||||
int i0;
|
||||
get(i0);
|
||||
out->writeInt(i0);
|
||||
break;
|
||||
}
|
||||
case(osg::Uniform::INT_VEC2):
|
||||
{
|
||||
int i0, i1;
|
||||
get(i0, i1);
|
||||
out->writeInt(i0);
|
||||
out->writeInt(i1);
|
||||
break;
|
||||
}
|
||||
case(osg::Uniform::INT_VEC3):
|
||||
{
|
||||
int i0, i1, i2;
|
||||
get(i0, i1, i2);
|
||||
out->writeInt(i0);
|
||||
out->writeInt(i1);
|
||||
out->writeInt(i2);
|
||||
break;
|
||||
}
|
||||
case(osg::Uniform::INT_VEC4):
|
||||
{
|
||||
int i0, i1, i2, i3;
|
||||
get(i0, i1, i2, i3);
|
||||
out->writeInt(i0);
|
||||
out->writeInt(i1);
|
||||
out->writeInt(i2);
|
||||
out->writeInt(i3);
|
||||
break;
|
||||
}
|
||||
case(osg::Uniform::FLOAT_MAT2):
|
||||
{
|
||||
osg::Matrix2 m2;
|
||||
get(m2);
|
||||
for(int i=0; i<4; ++i) out->writeFloat(m2[i]);
|
||||
break;
|
||||
}
|
||||
case(osg::Uniform::FLOAT_MAT3):
|
||||
{
|
||||
osg::Matrix3 m3;
|
||||
get(m3);
|
||||
for(int i=0; i<9; ++i) out->writeFloat(m3[i]);
|
||||
break;
|
||||
}
|
||||
case(osg::Uniform::FLOAT_MAT4):
|
||||
{
|
||||
osg::Matrixf matrix;
|
||||
get(matrix);
|
||||
out->writeMatrixf(matrix);
|
||||
break;
|
||||
}
|
||||
default:
|
||||
{
|
||||
osg::notify(osg::WARN)<<"Warning : uniform "<<getType()<<"type not supported for writing."<<std::endl;
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -161,81 +171,91 @@ void Uniform::read(DataInputStream* in)
|
||||
setName(in->readString());
|
||||
}
|
||||
|
||||
switch( Uniform::getGlApiType(getType()) )
|
||||
if ( in->getVersion() >= VERSION_0016 )
|
||||
{
|
||||
case(osg::Uniform::FLOAT):
|
||||
setNumElements( in->readInt() );
|
||||
|
||||
osg::Array* data = in->readArray();
|
||||
setArray( dynamic_cast<osg::FloatArray*>(data) );
|
||||
setArray( dynamic_cast<osg::IntArray*>(data) );
|
||||
}
|
||||
else
|
||||
{
|
||||
switch( Uniform::getGlApiType(getType()) )
|
||||
{
|
||||
set(in->readFloat());
|
||||
break;
|
||||
}
|
||||
case(osg::Uniform::FLOAT_VEC2):
|
||||
{
|
||||
set(in->readVec2());
|
||||
break;
|
||||
}
|
||||
case(osg::Uniform::FLOAT_VEC3):
|
||||
{
|
||||
set(in->readVec3());
|
||||
break;
|
||||
}
|
||||
case(osg::Uniform::FLOAT_VEC4):
|
||||
{
|
||||
set(in->readVec4());
|
||||
break;
|
||||
}
|
||||
case(osg::Uniform::INT):
|
||||
{
|
||||
set(in->readInt());
|
||||
break;
|
||||
}
|
||||
case(osg::Uniform::INT_VEC2):
|
||||
{
|
||||
int i0 = in->readInt();
|
||||
int i1 = in->readInt();
|
||||
set(i0,i1);
|
||||
break;
|
||||
}
|
||||
case(osg::Uniform::INT_VEC3):
|
||||
{
|
||||
int i0 = in->readInt();
|
||||
int i1 = in->readInt();
|
||||
int i2 = in->readInt();
|
||||
set(i0,i1,i2);
|
||||
break;
|
||||
}
|
||||
case(osg::Uniform::INT_VEC4):
|
||||
{
|
||||
int i0 = in->readInt();
|
||||
int i1 = in->readInt();
|
||||
int i2 = in->readInt();
|
||||
int i3 = in->readInt();
|
||||
set(i0,i1,i2,i3);
|
||||
break;
|
||||
}
|
||||
case(osg::Uniform::FLOAT_MAT2):
|
||||
{
|
||||
osg::Matrix2 m2;
|
||||
for(int i=0; i<9; ++i) m2[i]=in->readFloat();
|
||||
set(m2);
|
||||
break;
|
||||
}
|
||||
case(osg::Uniform::FLOAT_MAT3):
|
||||
{
|
||||
osg::Matrix3 m3;
|
||||
for(int i=0; i<9; ++i) m3[i]=in->readFloat();
|
||||
set(m3);
|
||||
break;
|
||||
}
|
||||
case(osg::Uniform::FLOAT_MAT4):
|
||||
{
|
||||
set( in->readMatrixf() );
|
||||
break;
|
||||
}
|
||||
default:
|
||||
{
|
||||
osg::notify(osg::WARN)<<"Warning : uniform "<<getType()<<"type not supported for reading."<<std::endl;
|
||||
break;
|
||||
case(osg::Uniform::FLOAT):
|
||||
{
|
||||
set(in->readFloat());
|
||||
break;
|
||||
}
|
||||
case(osg::Uniform::FLOAT_VEC2):
|
||||
{
|
||||
set(in->readVec2());
|
||||
break;
|
||||
}
|
||||
case(osg::Uniform::FLOAT_VEC3):
|
||||
{
|
||||
set(in->readVec3());
|
||||
break;
|
||||
}
|
||||
case(osg::Uniform::FLOAT_VEC4):
|
||||
{
|
||||
set(in->readVec4());
|
||||
break;
|
||||
}
|
||||
case(osg::Uniform::INT):
|
||||
{
|
||||
set(in->readInt());
|
||||
break;
|
||||
}
|
||||
case(osg::Uniform::INT_VEC2):
|
||||
{
|
||||
int i0 = in->readInt();
|
||||
int i1 = in->readInt();
|
||||
set(i0,i1);
|
||||
break;
|
||||
}
|
||||
case(osg::Uniform::INT_VEC3):
|
||||
{
|
||||
int i0 = in->readInt();
|
||||
int i1 = in->readInt();
|
||||
int i2 = in->readInt();
|
||||
set(i0,i1,i2);
|
||||
break;
|
||||
}
|
||||
case(osg::Uniform::INT_VEC4):
|
||||
{
|
||||
int i0 = in->readInt();
|
||||
int i1 = in->readInt();
|
||||
int i2 = in->readInt();
|
||||
int i3 = in->readInt();
|
||||
set(i0,i1,i2,i3);
|
||||
break;
|
||||
}
|
||||
case(osg::Uniform::FLOAT_MAT2):
|
||||
{
|
||||
osg::Matrix2 m2;
|
||||
for(int i=0; i<9; ++i) m2[i]=in->readFloat();
|
||||
set(m2);
|
||||
break;
|
||||
}
|
||||
case(osg::Uniform::FLOAT_MAT3):
|
||||
{
|
||||
osg::Matrix3 m3;
|
||||
for(int i=0; i<9; ++i) m3[i]=in->readFloat();
|
||||
set(m3);
|
||||
break;
|
||||
}
|
||||
case(osg::Uniform::FLOAT_MAT4):
|
||||
{
|
||||
set( in->readMatrixf() );
|
||||
break;
|
||||
}
|
||||
default:
|
||||
{
|
||||
osg::notify(osg::WARN)<<"Warning : uniform "<<getType()<<"type not supported for reading."<<std::endl;
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user