1
0
Fork 1
mirror of https://github.com/TES3MP/openmw-tes3mp.git synced 2025-01-21 09:53:50 +00:00

Remove NIFFile::getType

This commit is contained in:
Chris Robinson 2012-07-10 00:27:13 -07:00
parent 98ae7168b1
commit 10072f74b4
6 changed files with 166 additions and 30 deletions

View file

@ -105,16 +105,16 @@ public:
int verts = nif->getShort(); int verts = nif->getShort();
if(nif->getInt()) if(nif->getInt())
vertices = nif->getFloatLen(verts*3); vertices = nif->getArrayLen<float>(verts*3);
if(nif->getInt()) if(nif->getInt())
normals = nif->getFloatLen(verts*3); normals = nif->getArrayLen<float>(verts*3);
center = nif->getVector(); center = nif->getVector();
radius = nif->getFloat(); radius = nif->getFloat();
if(nif->getInt()) if(nif->getInt())
colors = nif->getFloatLen(verts*4); colors = nif->getArrayLen<float>(verts*4);
int uvs = nif->getShort(); int uvs = nif->getShort();
@ -123,7 +123,7 @@ public:
uvs &= 0x3f; uvs &= 0x3f;
if(nif->getInt()) if(nif->getInt())
uvlist = nif->getFloatLen(uvs*verts*2); uvlist = nif->getArrayLen<float>(uvs*verts*2);
} }
}; };
@ -181,7 +181,7 @@ public:
if(nif->getInt()) if(nif->getInt())
{ {
// Particle sizes // Particle sizes
nif->getFloatLen(activeCount); nif->getArrayLen<float>(activeCount);
} }
} }
}; };
@ -414,7 +414,9 @@ public:
assert(sizeof(BoneTrafo) == 4*(9+3+1)); assert(sizeof(BoneTrafo) == 4*(9+3+1));
assert(sizeof(VertWeight) == 6); assert(sizeof(VertWeight) == 6);
trafo = nif->getType<BoneTrafo>(); trafo.rotation = nif->getMatrix();
trafo.trans = nif->getVector();
trafo.scale = nif->getFloat();
int boneNum = nif->getInt(); int boneNum = nif->getInt();
nif->getInt(); // -1 nif->getInt(); // -1
@ -424,7 +426,9 @@ public:
{ {
BoneInfo &bi = bones[i]; BoneInfo &bi = bones[i];
bi.trafo = nif->getType<BoneTrafo>(); bi.trafo.rotation = nif->getMatrix();
bi.trafo.trans = nif->getVector();
bi.trafo.scale = nif->getFloat();
bi.unknown = nif->getVector4(); bi.unknown = nif->getVector4();
// Number of vertex weights // Number of vertex weights

View file

@ -41,6 +41,14 @@ struct NiLight : Effect
Vector ambient; Vector ambient;
Vector diffuse; Vector diffuse;
Vector specular; Vector specular;
void read(NIFFile *nif)
{
nif->load(dimmer);
ambient = nif->getVector();
diffuse = nif->getVector();
specular = nif->getVector();
}
}; };
SLight light; SLight light;
@ -50,7 +58,7 @@ struct NiLight : Effect
nif->getInt(); // 1 nif->getInt(); // 1
nif->getInt(); // 1? nif->getInt(); // 1?
light = nif->getType<SLight>(); light.read(nif);
} }
}; };

View file

@ -56,7 +56,7 @@ public:
/*int i =*/ nif->getInt(); /*int i =*/ nif->getInt();
int s = nif->getShort(); // number of vertices int s = nif->getShort(); // number of vertices
nif->getFloatLen(s); // vertex weights I guess nif->getArrayLen<float>(s); // vertex weights I guess
} }
}; };

View file

@ -99,20 +99,70 @@ public:
void skip(size_t size) { inp->skip(size); } void skip(size_t size) { inp->skip(size); }
template<class X> X getType() uint32_t read_le32()
{ {
X obj; uint8_t buffer[4];
if(inp->read(&obj, sizeof(X)) != sizeof(X)) if(inp->read(buffer, 4) != 4) return 0;
fail("Failed to read from NIF"); return buffer[0] | (buffer[1]<<8) | (buffer[2]<<16) | (buffer[3]<<24);
return obj; }
uint16_t read_le16()
{
uint8_t buffer[2];
if(inp->read(buffer, 2) != 2) return 0;
return buffer[0] | (buffer[1]<<8);
}
uint8_t read_byte()
{
uint8_t byte;
if(inp->read(&byte, 1) != 1) return 0;
return byte;
}
std::string read_string(size_t length)
{
std::string str;
str.resize(length);
if(inp->read(&str[0], length) != length)
return std::string();
return str.substr(0, str.find('\0'));
} }
unsigned short getShort() { return getType<unsigned short>(); }
int getInt() { return getType<int>(); }
float getFloat() { return getType<float>(); }
char getByte() { return getType<char>(); }
template<class X>
std::vector<X> getArrayLen(int num) char& load(char &c) { c = read_byte(); return c; }
unsigned char& load(unsigned char &c) { c = read_byte(); return c; }
short& load(short &s) { s = read_le16(); return s; }
unsigned short& load(unsigned short &s) { s = read_le16(); return s; }
int& load(int &i) { i = read_le32(); return i; }
unsigned int& load(unsigned int &i) { i = read_le32(); return i; }
float& load(float &f)
{
union {
int i;
float f;
} u = { read_le32() };
f = u.f;
return f;
}
template<typename T, size_t N>
T* load(T (&a)[N])
{
for(size_t i = 0;i < N;i++)
load(a[i]);
return a;
}
template<typename T>
std::vector<T>& load(std::vector<T> &v, size_t size)
{
v.resize(size);
for(size_t i = 0;i < size;i++)
load(v[i]);
return v;
}
template<typename X>
std::vector<X> getArrayLen(size_t num)
{ {
std::vector<X> v(num); std::vector<X> v(num);
if(inp->read(&v[0], num*sizeof(X)) != num*sizeof(X)) if(inp->read(&v[0], num*sizeof(X)) != num*sizeof(X))
@ -120,20 +170,47 @@ public:
return v; return v;
} }
template<class X> template<typename X>
std::vector<X> getArray() std::vector<X> getArray()
{ {
int len = getInt(); size_t len = read_le32();
return getArrayLen<X>(len); return getArrayLen<X>(len);
} }
Vector getVector() { return getType<Vector>(); } char getByte() { char c; return load(c); }
Matrix getMatrix() { return getType<Matrix>(); } unsigned short getShort() { unsigned short s; return load(s); }
Transformation getTrafo() { return getType<Transformation>(); } int getInt() { int i; return load(i); }
Vector4 getVector4() { return getType<Vector4>(); } float getFloat() { float f; return load(f); }
Vector getVector()
{
Vector v;
load(v.array);
return v;
}
Vector4 getVector4()
{
Vector4 v;
load(v.array);
return v;
}
Matrix getMatrix()
{
Matrix m;
m.v[0] = getVector();
m.v[1] = getVector();
m.v[2] = getVector();
return m;
}
Transformation getTrafo()
{
Transformation t;
t.pos = getVector();
t.rotation = getMatrix();
load(t.scale);
t.velocity = getVector();
return t;
}
std::vector<float> getFloatLen(int num)
{ return getArrayLen<float>(num); }
// For fixed-size strings where you already know the size // For fixed-size strings where you already know the size
std::string getString(size_t size) std::string getString(size_t size)
@ -151,5 +228,14 @@ public:
} }
}; };
template<>
inline std::vector<float> NIFFile::getArrayLen<float>(size_t num)
{
std::vector<float> v(num);
for(size_t i = 0;i < num;i++)
load(v[i]);
return v;
}
} // Namespace } // Namespace
#endif #endif

View file

@ -218,6 +218,23 @@ struct NiCamera : Node
// Level of detail modifier // Level of detail modifier
float LOD; float LOD;
void read(NIFFile *nif)
{
nif->load(left);
nif->load(right);
nif->load(top);
nif->load(bottom);
nif->load(nearDist);
nif->load(farDist);
nif->load(vleft);
nif->load(vright);
nif->load(vtop);
nif->load(vbottom);
nif->load(LOD);
}
}; };
Camera cam; Camera cam;
@ -225,7 +242,7 @@ struct NiCamera : Node
{ {
Node::read(nif); Node::read(nif);
cam = nif->getType<Camera>(); cam.read(nif);
nif->getInt(); // -1 nif->getInt(); // -1
nif->getInt(); // 0 nif->getInt(); // 0

View file

@ -160,7 +160,7 @@ struct StructPropT : Property
void read(NIFFile *nif) void read(NIFFile *nif)
{ {
Property::read(nif); Property::read(nif);
data = nif->getType<T>(); data.read(nif);
} }
}; };
@ -169,6 +169,16 @@ struct S_MaterialProperty
// The vector components are R,G,B // The vector components are R,G,B
Vector ambient, diffuse, specular, emissive; Vector ambient, diffuse, specular, emissive;
float glossiness, alpha; float glossiness, alpha;
void read(NIFFile *nif)
{
ambient = nif->getVector();
diffuse = nif->getVector();
specular = nif->getVector();
emissive = nif->getVector();
nif->load(glossiness);
nif->load(alpha);
}
}; };
struct S_VertexColorProperty struct S_VertexColorProperty
@ -183,6 +193,12 @@ struct S_VertexColorProperty
1 - lighting emmisive ambient/diffuse 1 - lighting emmisive ambient/diffuse
*/ */
int vertmode, lightmode; int vertmode, lightmode;
void read(NIFFile *nif)
{
nif->load(vertmode);
nif->load(lightmode);
}
}; };
struct S_AlphaProperty struct S_AlphaProperty
@ -234,6 +250,11 @@ struct S_AlphaProperty
// Tested against when certain flags are set (see above.) // Tested against when certain flags are set (see above.)
unsigned char threshold; unsigned char threshold;
void read(NIFFile *nif)
{
nif->load(threshold);
}
}; };
typedef StructPropT<S_AlphaProperty> NiAlphaProperty; typedef StructPropT<S_AlphaProperty> NiAlphaProperty;