|
|
@ -44,16 +44,16 @@ public:
|
|
|
|
int verts = nif->getUShort();
|
|
|
|
int verts = nif->getUShort();
|
|
|
|
|
|
|
|
|
|
|
|
if(nif->getInt())
|
|
|
|
if(nif->getInt())
|
|
|
|
nif->getVector3s(vertices, verts);
|
|
|
|
vertices = nif->getItems<Ogre::Vector3>(verts);
|
|
|
|
|
|
|
|
|
|
|
|
if(nif->getInt())
|
|
|
|
if(nif->getInt())
|
|
|
|
nif->getVector3s(normals, verts);
|
|
|
|
normals = nif->getItems<Ogre::Vector3>(verts);
|
|
|
|
|
|
|
|
|
|
|
|
center = nif->getVector3();
|
|
|
|
center = nif->getVector3();
|
|
|
|
radius = nif->getFloat();
|
|
|
|
radius = nif->getFloat();
|
|
|
|
|
|
|
|
|
|
|
|
if(nif->getInt())
|
|
|
|
if(nif->getInt())
|
|
|
|
nif->getVector4s(colors, verts);
|
|
|
|
colors = nif->getItems<Ogre::Vector4>(verts);
|
|
|
|
|
|
|
|
|
|
|
|
// 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.
|
|
|
@ -64,7 +64,7 @@ public:
|
|
|
|
{
|
|
|
|
{
|
|
|
|
uvlist.resize(uvs);
|
|
|
|
uvlist.resize(uvs);
|
|
|
|
for(int i = 0;i < uvs;i++)
|
|
|
|
for(int i = 0;i < uvs;i++)
|
|
|
|
nif->getVector2s(uvlist[i], verts);
|
|
|
|
uvlist[i] = nif->getItems<Ogre::Vector2>(verts);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
};
|
|
|
@ -84,7 +84,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->getShorts(triangles, cnt);
|
|
|
|
triangles = nif->getItems<short>(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
|
|
|
|
// vertices. We don't actually need need this for anything, so
|
|
|
|
// vertices. We don't actually need need this for anything, so
|
|
|
@ -123,7 +123,7 @@ public:
|
|
|
|
if(nif->getInt())
|
|
|
|
if(nif->getInt())
|
|
|
|
{
|
|
|
|
{
|
|
|
|
// Particle sizes
|
|
|
|
// Particle sizes
|
|
|
|
nif->getFloats(sizes, vertices.size());
|
|
|
|
sizes = nif->getItems<float>(vertices.size());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
};
|
|
|
@ -140,7 +140,7 @@ public:
|
|
|
|
if(nif->getInt())
|
|
|
|
if(nif->getInt())
|
|
|
|
{
|
|
|
|
{
|
|
|
|
// Rotation quaternions.
|
|
|
|
// Rotation quaternions.
|
|
|
|
nif->getQuaternions(rotations, vertices.size());
|
|
|
|
rotations = nif->getItems<Ogre::Quaternion>(vertices.size());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
};
|
|
|
@ -341,7 +341,7 @@ struct NiMorphData : public Record
|
|
|
|
for(int i = 0;i < morphCount;i++)
|
|
|
|
for(int i = 0;i < morphCount;i++)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
mMorphs[i].mData.read(nif, true);
|
|
|
|
mMorphs[i].mData.read(nif, true);
|
|
|
|
nif->getVector3s(mMorphs[i].mVertices, vertCount);
|
|
|
|
mMorphs[i].mVertices = nif->getItems<Ogre::Vector3>(vertCount);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
};
|
|
|
|