* Fixes to MDR implementation from Thilo Schulz

This commit is contained in:
Tim Angus 2006-04-14 20:13:49 +00:00
parent 2b75754cdb
commit a235245e35

View file

@ -660,19 +660,20 @@ static qboolean R_LoadMDR( model_t *mod, void *buffer, int filesize, const char
curtri++; curtri++;
} }
// tri and curtri now point to the end of their surfaces. // tri now points to the end of the surface.
surf->ofsEnd = (byte *) tri - (byte *) surf; surf->ofsEnd = (byte *) tri - (byte *) surf;
// find the next surface
surf = (mdrSurface_t *) tri; surf = (mdrSurface_t *) tri;
cursurf = (mdrSurface_t *) curtri;
// find the next surface.
cursurf = (mdrSurface_t *) ((byte *) cursurf + LittleLong(cursurf->ofsEnd));
} }
// surf points to the next lod now. // surf points to the next lod now.
lod->ofsEnd = (int)((byte *) surf - (byte *) lod); lod->ofsEnd = (int)((byte *) surf - (byte *) lod);
lod = (mdrLOD_t *) surf; lod = (mdrLOD_t *) surf;
curlod = (mdrLOD_t *) cursurf;
// find the next LOD.
curlod = (mdrLOD_t *)((byte *) curlod + LittleLong(curlod->ofsEnd));
} }
// lod points to the first tag now, so update the offset too. // lod points to the first tag now, so update the offset too.
@ -958,7 +959,7 @@ static md3Tag_t *R_GetTag( md3Header_t *mod, int frame, const char *tagName ) {
#ifdef RAVENMD4 #ifdef RAVENMD4
void R_GetAnimTag( mdrHeader_t *mod, int framenum, const char *tagName, md3Tag_t * dest) void R_GetAnimTag( mdrHeader_t *mod, int framenum, const char *tagName, md3Tag_t * dest)
{ {
int i; int i, j, k;
int frameSize; int frameSize;
mdrFrame_t *frame; mdrFrame_t *frame;
mdrTag_t *tag; mdrTag_t *tag;
@ -980,20 +981,13 @@ void R_GetAnimTag( mdrHeader_t *mod, int framenum, const char *tagName, md3Tag_t
// //
frameSize = (long)( &((mdrFrame_t *)0)->bones[ mod->numBones ] ); frameSize = (long)( &((mdrFrame_t *)0)->bones[ mod->numBones ] );
frame = (mdrFrame_t *)((byte *)mod + mod->ofsFrames + framenum * frameSize ); frame = (mdrFrame_t *)((byte *)mod + mod->ofsFrames + framenum * frameSize );
#if 1
VectorCopy(&frame->bones[tag->boneIndex].matrix[0][0], dest->axis[0] );
VectorCopy(&frame->bones[tag->boneIndex].matrix[1][0], dest->axis[1] );
VectorCopy(&frame->bones[tag->boneIndex].matrix[2][0], dest->axis[2] );
#else
{
int j,k;
for (j = 0; j < 3; j++) for (j = 0; j < 3; j++)
{ {
for (k = 0; k < 3; k++) for (k = 0; k < 3; k++)
dest->axis[j][k]=frame->bones[tag->boneIndex].matrix[k][j]; dest->axis[j][k]=frame->bones[tag->boneIndex].matrix[k][j];
} }
}
#endif
dest->origin[0]=frame->bones[tag->boneIndex].matrix[0][3]; dest->origin[0]=frame->bones[tag->boneIndex].matrix[0][3];
dest->origin[1]=frame->bones[tag->boneIndex].matrix[1][3]; dest->origin[1]=frame->bones[tag->boneIndex].matrix[1][3];
dest->origin[2]=frame->bones[tag->boneIndex].matrix[2][3]; dest->origin[2]=frame->bones[tag->boneIndex].matrix[2][3];