From 3d83c3eb1516829243e456f581ff0e469a7cef87 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Beno=C3=AEt=20Minisini?= Date: Fri, 22 Nov 2013 23:12:54 +0000 Subject: [PATCH] [GB.OPENGL.SGE] * BUG: Don't crash if a model has only one frame. git-svn-id: svn://localhost/gambas/trunk@5967 867c0c6c-44f3-4631-809d-bfa615b0a4ec --- gb.opengl/src/sge/cmd2model.c | 28 ++++++++++++++++++++-------- gb.opengl/src/sge/cmd2model.h | 2 +- 2 files changed, 21 insertions(+), 9 deletions(-) diff --git a/gb.opengl/src/sge/cmd2model.c b/gb.opengl/src/sge/cmd2model.c index 7e3ad97bf..a57eeba7b 100644 --- a/gb.opengl/src/sge/cmd2model.c +++ b/gb.opengl/src/sge/cmd2model.c @@ -205,7 +205,7 @@ CMD2MODEL *MD2MODEL_create(void) int MD2MODEL_draw(CMD2MODEL *_object, double frame, int texture, float *pos, float *scale, float *rotate) { int i; - int n; + int n, n2; double interp; GLfloat v_curr[3], v_next[3], v[3], norm[3]; GLfloat *n_curr, *n_next; @@ -223,11 +223,12 @@ int MD2MODEL_draw(CMD2MODEL *_object, double frame, int texture, float *pos, flo n = (int)frame; interp = frame - n; - if ((n < 0) || (n >= (THIS->num_frames - 1))) - { - n = 0; - interp = 0; - } + if (n < 0 || n >= THIS->num_frames) + return 0; + + n2 = n + 1; + if (n2 >= THIS->num_frames) + n2 = 0; enabled = glIsEnabled(GL_TEXTURE_2D); if (!enabled) @@ -256,11 +257,15 @@ int MD2MODEL_draw(CMD2MODEL *_object, double frame, int texture, float *pos, flo pglcmds = THIS->glcmds; pframe1 = &THIS->frames[n]; - pframe2 = &THIS->frames[n + 1]; + pframe2 = &THIS->frames[n2]; + + //fprintf(stderr, "\n******** %p: n = %d / %d | %p %p\n", _object, n, THIS->num_frames, pframe1->verts, pframe2->verts); // Draw the model while ((i = *(pglcmds++)) != 0) { + //fprintf(stderr, "i = %d\n", i); + if (i < 0) { glBegin(GL_TRIANGLE_FAN); @@ -275,8 +280,13 @@ int MD2MODEL_draw(CMD2MODEL *_object, double frame, int texture, float *pos, flo for (/* Nothing */ ; i > 0; --i, pglcmds += 3) { packet = (glcmd *)pglcmds; + + //fprintf(stderr, "%d (%d) ", i, packet->index); + pvert1 = &pframe1->verts[packet->index]; pvert2 = &pframe2->verts[packet->index]; + //if (!pvert1 || !pvert2) + // continue; // Pass texture coordinates to OpenGL //glTexCoord2f (pGLcmd->s, 1.0f - pGLcmd->t); @@ -309,6 +319,8 @@ int MD2MODEL_draw(CMD2MODEL *_object, double frame, int texture, float *pos, flo nvert++; } + //fprintf(stderr, "\n"); + glEnd(); } #else @@ -323,7 +335,7 @@ int MD2MODEL_draw(CMD2MODEL *_object, double frame, int texture, float *pos, flo for (j = 0; j < 3; ++j) { pframe1 = &THIS->frames[n]; - pframe2 = &THIS->frames[n + 1]; + pframe2 = &THIS->frames[n2]; pvert1 = &pframe1->verts[THIS->triangles[i].vertex[j]]; pvert2 = &pframe2->verts[THIS->triangles[i].vertex[j]]; diff --git a/gb.opengl/src/sge/cmd2model.h b/gb.opengl/src/sge/cmd2model.h index 537458f15..b3fa2c396 100644 --- a/gb.opengl/src/sge/cmd2model.h +++ b/gb.opengl/src/sge/cmd2model.h @@ -72,7 +72,7 @@ typedef float vec3[3]; typedef struct md2_skin { - char name[64]; + char name[68]; }skinmd2; /* Texture coords */