Repack model geometry as floats (preliminary work for model normals).

git-svn-id: https://svn.eduke32.com/eduke32@1238 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
plagman 2009-03-10 12:08:33 +00:00
parent dec9c2cbac
commit 9995cc46c2
3 changed files with 32 additions and 11 deletions

View file

@ -127,9 +127,10 @@ typedef struct
md3shader_t *shaders; md3shader_t *shaders;
md3uv_t *uv; md3uv_t *uv;
md3xyzn_t *xyzn; md3xyzn_t *xyzn;
float *geometry;
} md3surf_t; } md3surf_t;
#define SIZEOF_MD3SURF_T (sizeof(md3surf_t)-4*sizeof(void*)) #define SIZEOF_MD3SURF_T (11*sizeof(int32_t) + 64*sizeof(char))
typedef struct typedef struct
{ {

View file

@ -1624,6 +1624,26 @@ static void md3postload(md3model_t* m)
framei++; framei++;
} }
// let's also repack the geometry to more usable formats
surfi = 0;
while (surfi < m->head.numsurfs)
{
m->head.surfs[surfi].geometry = malloc(m->head.numframes * m->head.surfs[surfi].numverts * sizeof(float) * 6);
verti = 0;
while (verti < (m->head.numframes * m->head.surfs[surfi].numverts))
{
m->head.surfs[surfi].geometry[(verti * 6) + 0] = m->head.surfs[surfi].xyzn[verti].x;
m->head.surfs[surfi].geometry[(verti * 6) + 1] = m->head.surfs[surfi].xyzn[verti].y;
m->head.surfs[surfi].geometry[(verti * 6) + 2] = m->head.surfs[surfi].xyzn[verti].z;
verti++;
}
surfi++;
}
} }
static int32_t md3draw(md3model_t *m, spritetype *tspr) static int32_t md3draw(md3model_t *m, spritetype *tspr)

View file

@ -2427,7 +2427,7 @@ static void polymer_drawmdsprite(spritetype *tspr)
{ {
md3model_t* m; md3model_t* m;
mdskinmap_t* sk; mdskinmap_t* sk;
md3xyzn_t *v0, *v1; float *v0, *v1;
md3surf_t *s; md3surf_t *s;
char lpal; char lpal;
float spos[3]; float spos[3];
@ -2550,8 +2550,8 @@ static void polymer_drawmdsprite(spritetype *tspr)
for (surfi=0;surfi<m->head.numsurfs;surfi++) for (surfi=0;surfi<m->head.numsurfs;surfi++)
{ {
s = &m->head.surfs[surfi]; s = &m->head.surfs[surfi];
v0 = &s->xyzn[m->cframe*s->numverts]; v0 = &s->geometry[m->cframe*s->numverts*6];
v1 = &s->xyzn[m->nframe*s->numverts]; v1 = &s->geometry[m->nframe*s->numverts*6];
mdspritematerial.diffusemap = mdspritematerial.diffusemap =
mdloadskin((md2model_t *)m,tile2model[Ptile2tile(tspr->picnum,sprite[tspr->owner].pal)].skinnum,tspr->pal,surfi); mdloadskin((md2model_t *)m,tile2model[Ptile2tile(tspr->picnum,sprite[tspr->owner].pal)].skinnum,tspr->pal,surfi);
@ -2582,12 +2582,12 @@ static void polymer_drawmdsprite(spritetype *tspr)
bglTexCoordPointer(2, GL_FLOAT, 0, 0); bglTexCoordPointer(2, GL_FLOAT, 0, 0);
bglBindBufferARB(GL_ARRAY_BUFFER_ARB, m->geometry[surfi]); bglBindBufferARB(GL_ARRAY_BUFFER_ARB, m->geometry[surfi]);
bglVertexPointer(3, GL_SHORT, sizeof(md3xyzn_t), (GLfloat*)(m->cframe * s->numverts * sizeof(md3xyzn_t))); bglVertexPointer(3, GL_FLOAT, sizeof(float) * 6, (GLfloat*)(m->cframe * s->numverts * sizeof(float) * 6));
if (pr_gpusmoothing) if (pr_gpusmoothing)
{ {
mdspritematerial.nextframedata = (GLfloat*)(m->nframe * s->numverts * sizeof(md3xyzn_t)); mdspritematerial.nextframedata = (GLfloat*)(m->nframe * s->numverts * sizeof(float) * 6);
mdspritematerial.nextframedatastride = sizeof(md3xyzn_t); mdspritematerial.nextframedatastride = sizeof(float) * 6;
} }
materialbits = polymer_bindmaterial(mdspritematerial, NULL, 0); materialbits = polymer_bindmaterial(mdspritematerial, NULL, 0);
@ -2602,13 +2602,13 @@ static void polymer_drawmdsprite(spritetype *tspr)
} }
else else
{ {
bglVertexPointer(3, GL_SHORT, sizeof(md3xyzn_t), v0); bglVertexPointer(3, GL_FLOAT, sizeof(float) * 6, v0);
bglTexCoordPointer(2, GL_FLOAT, 0, s->uv); bglTexCoordPointer(2, GL_FLOAT, 0, s->uv);
if (pr_gpusmoothing) if (pr_gpusmoothing)
{ {
mdspritematerial.nextframedata = (GLfloat*)(v1); mdspritematerial.nextframedata = (GLfloat*)(v1);
mdspritematerial.nextframedatastride = sizeof(md3xyzn_t); mdspritematerial.nextframedatastride = sizeof(float) * 6;
} }
materialbits = polymer_bindmaterial(mdspritematerial, NULL, 0); materialbits = polymer_bindmaterial(mdspritematerial, NULL, 0);
@ -2651,7 +2651,7 @@ static void polymer_loadmodelvbos(md3model_t* m)
bglBufferDataARB(GL_ARRAY_BUFFER_ARB, s->numverts * sizeof(md3uv_t), s->uv, modelvbousage); bglBufferDataARB(GL_ARRAY_BUFFER_ARB, s->numverts * sizeof(md3uv_t), s->uv, modelvbousage);
bglBindBufferARB(GL_ARRAY_BUFFER_ARB, m->geometry[i]); bglBindBufferARB(GL_ARRAY_BUFFER_ARB, m->geometry[i]);
bglBufferDataARB(GL_ARRAY_BUFFER_ARB, s->numframes * s->numverts * sizeof(md3xyzn_t), s->xyzn, modelvbousage); bglBufferDataARB(GL_ARRAY_BUFFER_ARB, s->numframes * s->numverts * sizeof(float) * 6, s->geometry, modelvbousage);
bglBindBufferARB(GL_ARRAY_BUFFER_ARB, 0); bglBindBufferARB(GL_ARRAY_BUFFER_ARB, 0);
i++; i++;
@ -2812,7 +2812,7 @@ static int32_t polymer_bindmaterial(_prmaterial material, char* lights, int
{ {
bglEnableVertexAttribArrayARB(prprograms[programbits].attrib_nextFrameData); bglEnableVertexAttribArrayARB(prprograms[programbits].attrib_nextFrameData);
bglVertexAttribPointerARB(prprograms[programbits].attrib_nextFrameData, bglVertexAttribPointerARB(prprograms[programbits].attrib_nextFrameData,
3, GL_SHORT, GL_FALSE, 3, GL_FLOAT, GL_FALSE,
material.nextframedatastride, material.nextframedatastride,
material.nextframedata); material.nextframedata);