]> git.rm.cloudns.org Git - xonotic/darkplaces.git/commitdiff
changed md3 tag storage to be the original float[12] OpenGL-orientation format rather...
authorhavoc <havoc@d7cf8633-e32d-0410-b094-e92efae38249>
Mon, 6 Nov 2006 08:23:43 +0000 (08:23 +0000)
committerhavoc <havoc@d7cf8633-e32d-0410-b094-e92efae38249>
Mon, 6 Nov 2006 08:23:43 +0000 (08:23 +0000)
git-svn-id: svn://svn.icculus.org/twilight/trunk/darkplaces@6614 d7cf8633-e32d-0410-b094-e92efae38249

model_alias.c
model_alias.h

index 09d5a70b3b9e6bf77f5d82424be65fe3648b69fd..54054371e68fd562e14cb15022d8f02e7f6ef9dd 100644 (file)
@@ -277,7 +277,7 @@ int Mod_Alias_GetTagMatrix(const model_t *model, int poseframe, int tagindex, ma
                        return 4;
                if (poseframe >= model->num_tagframes)
                        return 6;
-               *outmatrix = model->data_tags[poseframe * model->num_tags + tagindex].matrix;
+               Matrix4x4_FromArray12FloatGL(outmatrix, model->data_tags[poseframe * model->num_tags + tagindex].matrixgl);
        }
        return 0;
 }
@@ -1238,14 +1238,11 @@ void Mod_IDP3_Load(model_t *mod, void *buffer, void *bufferend)
        loadmodel->data_tags = (aliastag_t *)Mem_Alloc(loadmodel->mempool, loadmodel->num_tagframes * loadmodel->num_tags * sizeof(aliastag_t));
        for (i = 0, pintag = (md3tag_t *)((unsigned char *)pinmodel + LittleLong(pinmodel->lump_tags));i < loadmodel->num_tagframes * loadmodel->num_tags;i++, pintag++)
        {
-               float m[12];
                strlcpy(loadmodel->data_tags[i].name, pintag->name, sizeof(loadmodel->data_tags[i].name));
-               loadmodel->data_tags[i].matrix = identitymatrix;
                for (j = 0;j < 9;j++)
-                       m[j] = LittleFloat(pintag->rotationmatrix[j]);
+                       loadmodel->data_tags[i].matrixgl[j] = LittleFloat(pintag->rotationmatrix[j]);
                for (j = 0;j < 3;j++)
-                       m[9+j] = LittleFloat(pintag->origin[j]);
-               Matrix4x4_FromArray12FloatGL(&loadmodel->data_tags[i].matrix, m);
+                       loadmodel->data_tags[i].matrixgl[9+j] = LittleFloat(pintag->origin[j]);
                //Con_Printf("model \"%s\" frame #%i tag #%i \"%s\"\n", loadmodel->name, i / loadmodel->num_tags, i % loadmodel->num_tags, loadmodel->data_tags[i].name);
        }
 
index 26e6492959f66cf6b9a28eb745a5130bbb414301..272b69c3ce7a2f0d322775e69238bd972a14712a 100644 (file)
@@ -212,7 +212,7 @@ md3modelheader_t;
 typedef struct aliastag_s
 {
        char name[MD3NAME];
-       matrix4x4_t matrix;
+       float matrixgl[12];
 }
 aliastag_t;