mirror of
https://github.com/OpenMW/openmw.git
synced 2025-03-27 04:10:24 +00:00
Make the read_* methods private and remove the generic load() methods
This commit is contained in:
parent
930459365b
commit
d30f64650a
6 changed files with 87 additions and 102 deletions
|
@ -105,16 +105,16 @@ public:
|
||||||
int verts = nif->getUShort();
|
int verts = nif->getUShort();
|
||||||
|
|
||||||
if(nif->getInt())
|
if(nif->getInt())
|
||||||
nif->load(vertices, verts*3);
|
nif->getFloats(vertices, verts*3);
|
||||||
|
|
||||||
if(nif->getInt())
|
if(nif->getInt())
|
||||||
nif->load(normals, verts*3);
|
nif->getFloats(normals, verts*3);
|
||||||
|
|
||||||
center = nif->getVector();
|
center = nif->getVector();
|
||||||
radius = nif->getFloat();
|
radius = nif->getFloat();
|
||||||
|
|
||||||
if(nif->getInt())
|
if(nif->getInt())
|
||||||
nif->load(colors, verts*4);
|
nif->getFloats(colors, verts*4);
|
||||||
|
|
||||||
// Only the first 6 bits are used as a count. I think the rest are
|
// Only the first 6 bits are used as a count. I think the rest are
|
||||||
// flags of some sort.
|
// flags of some sort.
|
||||||
|
@ -122,7 +122,7 @@ public:
|
||||||
uvs &= 0x3f;
|
uvs &= 0x3f;
|
||||||
|
|
||||||
if(nif->getInt())
|
if(nif->getInt())
|
||||||
nif->load(uvlist, uvs*verts*2);
|
nif->getFloats(uvlist, uvs*verts*2);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -142,7 +142,7 @@ public:
|
||||||
// We have three times as many vertices as triangles, so this
|
// We have three times as many vertices as triangles, so this
|
||||||
// is always equal to tris*3.
|
// is always equal to tris*3.
|
||||||
int cnt = nif->getInt();
|
int cnt = nif->getInt();
|
||||||
nif->load(triangles, cnt);
|
nif->getShorts(triangles, cnt);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Read the match list, which lists the vertices that are equal to
|
// Read the match list, which lists the vertices that are equal to
|
||||||
|
@ -153,7 +153,7 @@ public:
|
||||||
{
|
{
|
||||||
// Number of vertices matching vertex 'i'
|
// Number of vertices matching vertex 'i'
|
||||||
int num = nif->getUShort();
|
int num = nif->getUShort();
|
||||||
nif->skip(num*sizeof(short));
|
nif->skip(num * sizeof(short));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
|
@ -44,7 +44,7 @@ struct NiLight : Effect
|
||||||
|
|
||||||
void read(NIFFile *nif)
|
void read(NIFFile *nif)
|
||||||
{
|
{
|
||||||
nif->load(dimmer);
|
dimmer = nif->getFloat();
|
||||||
ambient = nif->getVector();
|
ambient = nif->getVector();
|
||||||
diffuse = nif->getVector();
|
diffuse = nif->getVector();
|
||||||
specular = nif->getVector();
|
specular = nif->getVector();
|
||||||
|
|
|
@ -47,21 +47,16 @@ public:
|
||||||
class NiVertWeightsExtraData : public Extra
|
class NiVertWeightsExtraData : public Extra
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
std::vector<float> weights;
|
|
||||||
|
|
||||||
void read(NIFFile *nif)
|
void read(NIFFile *nif)
|
||||||
{
|
{
|
||||||
Extra::read(nif);
|
Extra::read(nif);
|
||||||
|
|
||||||
int i;
|
|
||||||
unsigned short s;
|
|
||||||
|
|
||||||
// We should have s*4+2 == i, for some reason. Might simply be the
|
// We should have s*4+2 == i, for some reason. Might simply be the
|
||||||
// size of the rest of the record, unhelpful as that may be.
|
// size of the rest of the record, unhelpful as that may be.
|
||||||
nif->load(i);
|
/*int i =*/ nif->getInt();
|
||||||
|
int s = nif->getUShort();
|
||||||
|
|
||||||
nif->load(s); // number of vertices
|
nif->skip(s * sizeof(float)); // vertex weights I guess
|
||||||
nif->load(weights, s); // vertex weights I guess
|
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -46,7 +46,7 @@ using namespace Misc;
|
||||||
void NIFFile::parse()
|
void NIFFile::parse()
|
||||||
{
|
{
|
||||||
// Check the header string
|
// Check the header string
|
||||||
std::string head = read_string(40);
|
std::string head = getString(40);
|
||||||
if(head.compare(0, 22, "NetImmerse File Format") != 0)
|
if(head.compare(0, 22, "NetImmerse File Format") != 0)
|
||||||
fail("Invalid NIF header");
|
fail("Invalid NIF header");
|
||||||
|
|
||||||
|
|
|
@ -62,6 +62,33 @@ class NIFFile
|
||||||
/// Parse the file
|
/// Parse the file
|
||||||
void parse();
|
void parse();
|
||||||
|
|
||||||
|
uint8_t read_byte()
|
||||||
|
{
|
||||||
|
uint8_t byte;
|
||||||
|
if(inp->read(&byte, 1) != 1) return 0;
|
||||||
|
return byte;
|
||||||
|
}
|
||||||
|
uint16_t read_le16()
|
||||||
|
{
|
||||||
|
uint8_t buffer[2];
|
||||||
|
if(inp->read(buffer, 2) != 2) return 0;
|
||||||
|
return buffer[0] | (buffer[1]<<8);
|
||||||
|
}
|
||||||
|
uint32_t read_le32()
|
||||||
|
{
|
||||||
|
uint8_t buffer[4];
|
||||||
|
if(inp->read(buffer, 4) != 4) return 0;
|
||||||
|
return buffer[0] | (buffer[1]<<8) | (buffer[2]<<16) | (buffer[3]<<24);
|
||||||
|
}
|
||||||
|
float read_le32f()
|
||||||
|
{
|
||||||
|
union {
|
||||||
|
int i;
|
||||||
|
float f;
|
||||||
|
} u = { read_le32() };
|
||||||
|
return u.f;
|
||||||
|
}
|
||||||
|
|
||||||
public:
|
public:
|
||||||
/// Used for error handling
|
/// Used for error handling
|
||||||
void fail(const std::string &msg)
|
void fail(const std::string &msg)
|
||||||
|
@ -102,91 +129,34 @@ public:
|
||||||
|
|
||||||
void skip(size_t size) { inp->skip(size); }
|
void skip(size_t size) { inp->skip(size); }
|
||||||
|
|
||||||
uint32_t read_le32()
|
char getChar() { return read_byte(); }
|
||||||
{
|
short getShort() { return read_le16(); }
|
||||||
uint8_t buffer[4];
|
unsigned short getUShort() { return read_le16(); }
|
||||||
if(inp->read(buffer, 4) != 4) return 0;
|
int getInt() { return read_le32(); }
|
||||||
return buffer[0] | (buffer[1]<<8) | (buffer[2]<<16) | (buffer[3]<<24);
|
float getFloat() { return read_le32f(); }
|
||||||
}
|
|
||||||
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'));
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
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;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
char getChar() { char c; return load(c); }
|
|
||||||
unsigned short getUShort() { unsigned short s; return load(s); }
|
|
||||||
int getInt() { int i; return load(i); }
|
|
||||||
float getFloat() { float f; return load(f); }
|
|
||||||
Ogre::Vector3 getVector()
|
Ogre::Vector3 getVector()
|
||||||
{
|
{
|
||||||
float a[3];
|
float a[3];
|
||||||
load(a);
|
for(size_t i = 0;i < 3;i++)
|
||||||
|
a[i] = getFloat();
|
||||||
return Ogre::Vector3(a);
|
return Ogre::Vector3(a);
|
||||||
}
|
}
|
||||||
Ogre::Vector4 getVector4()
|
Ogre::Vector4 getVector4()
|
||||||
{
|
{
|
||||||
float a[4];
|
float a[4];
|
||||||
load(a);
|
for(size_t i = 0;i < 4;i++)
|
||||||
|
a[i] = getFloat();
|
||||||
return Ogre::Vector4(a);
|
return Ogre::Vector4(a);
|
||||||
}
|
}
|
||||||
Ogre::Matrix3 getMatrix()
|
Ogre::Matrix3 getMatrix()
|
||||||
{
|
{
|
||||||
float a[3*3];
|
Ogre::Real a[3][3];
|
||||||
load(a);
|
for(size_t i = 0;i < 3;i++)
|
||||||
return Ogre::Matrix3(Ogre::Real(a[0]), Ogre::Real(a[1]), Ogre::Real(a[2]),
|
{
|
||||||
Ogre::Real(a[3]), Ogre::Real(a[4]), Ogre::Real(a[5]),
|
for(size_t j = 0;j < 3;j++)
|
||||||
Ogre::Real(a[6]), Ogre::Real(a[7]), Ogre::Real(a[8]));
|
a[i][j] = Ogre::Real(getFloat());
|
||||||
|
}
|
||||||
|
return Ogre::Matrix3(a);
|
||||||
}
|
}
|
||||||
Transformation getTrafo()
|
Transformation getTrafo()
|
||||||
{
|
{
|
||||||
|
@ -198,11 +168,31 @@ public:
|
||||||
return t;
|
return t;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
std::string getString(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'));
|
||||||
|
}
|
||||||
std::string getString()
|
std::string getString()
|
||||||
{
|
{
|
||||||
size_t size = read_le32();
|
size_t size = read_le32();
|
||||||
return read_string(size);
|
return getString(size);
|
||||||
|
}
|
||||||
|
|
||||||
|
void getShorts(std::vector<short> &vec, size_t size)
|
||||||
|
{
|
||||||
|
vec.resize(size);
|
||||||
|
for(size_t i = 0;i < vec.size();i++)
|
||||||
|
vec[i] = getShort();
|
||||||
|
}
|
||||||
|
void getFloats(std::vector<float> &vec, size_t size)
|
||||||
|
{
|
||||||
|
vec.resize(size);
|
||||||
|
for(size_t i = 0;i < vec.size();i++)
|
||||||
|
vec[i] = getFloat();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -221,19 +221,19 @@ struct NiCamera : Node
|
||||||
|
|
||||||
void read(NIFFile *nif)
|
void read(NIFFile *nif)
|
||||||
{
|
{
|
||||||
nif->load(left);
|
left = nif->getFloat();
|
||||||
nif->load(right);
|
right = nif->getFloat();
|
||||||
nif->load(top);
|
top = nif->getFloat();
|
||||||
nif->load(bottom);
|
bottom = nif->getFloat();
|
||||||
nif->load(nearDist);
|
nearDist = nif->getFloat();
|
||||||
nif->load(farDist);
|
farDist = nif->getFloat();
|
||||||
|
|
||||||
nif->load(vleft);
|
vleft = nif->getFloat();
|
||||||
nif->load(vright);
|
vright = nif->getFloat();
|
||||||
nif->load(vtop);
|
vtop = nif->getFloat();
|
||||||
nif->load(vbottom);
|
vbottom = nif->getFloat();
|
||||||
|
|
||||||
nif->load(LOD);
|
LOD = nif->getFloat();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
Camera cam;
|
Camera cam;
|
||||||
|
|
Loading…
Reference in a new issue