MD3 normals.

git-svn-id: https://svn.eduke32.com/eduke32@1239 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
plagman 2009-03-10 14:30:34 +00:00
parent 9995cc46c2
commit 512bb9a5ab
3 changed files with 81 additions and 34 deletions

View file

@ -76,6 +76,7 @@ typedef struct s_prrograminfo {
GLhandleARB handle; GLhandleARB handle;
// PR_BIT_ANIM_INTERPOLATION // PR_BIT_ANIM_INTERPOLATION
GLint attrib_nextFrameData; GLint attrib_nextFrameData;
GLint attrib_nextFrameNormal;
GLint uniform_frameProgress; GLint uniform_frameProgress;
// PR_BIT_DIFFUSE_MAP // PR_BIT_DIFFUSE_MAP
GLint uniform_diffuseMap; GLint uniform_diffuseMap;

View file

@ -1538,7 +1538,7 @@ static void md3postload(md3model_t* m)
{ {
int framei, surfi, verti; int framei, surfi, verti;
md3xyzn_t *frameverts; md3xyzn_t *frameverts;
float dist; float dist, lat, lng;
// apparently we can't trust loaded models bounding box/sphere information, // apparently we can't trust loaded models bounding box/sphere information,
// so let's compute it ourselves // so let's compute it ourselves
@ -1639,6 +1639,15 @@ static void md3postload(md3model_t* m)
m->head.surfs[surfi].geometry[(verti * 6) + 1] = m->head.surfs[surfi].xyzn[verti].y; 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; m->head.surfs[surfi].geometry[(verti * 6) + 2] = m->head.surfs[surfi].xyzn[verti].z;
// normal extraction from packed spherical coordinates
// FIXME: swapping lat and lng because of npherno's compiler
lat = m->head.surfs[surfi].xyzn[verti].nlng * (2 * PI) / 255.0f;
lng = m->head.surfs[surfi].xyzn[verti].nlat * (2 * PI) / 255.0f;
m->head.surfs[surfi].geometry[(verti * 6) + 3] = cos(lat) * sin(lng);
m->head.surfs[surfi].geometry[(verti * 6) + 4] = sin(lat) * sin(lng);
m->head.surfs[surfi].geometry[(verti * 6) + 5] = cos(lng);
verti++; verti++;
} }
surfi++; surfi++;

View file

@ -166,16 +166,20 @@ _prprogrambit prprogrambits[PR_BIT_COUNT] = {
1 << PR_BIT_ANIM_INTERPOLATION, 1 << PR_BIT_ANIM_INTERPOLATION,
// vert_def // vert_def
"attribute vec4 nextFrameData;\n" "attribute vec4 nextFrameData;\n"
"attribute vec4 nextFrameNormal;\n"
"uniform float frameProgress;\n" "uniform float frameProgress;\n"
"\n", "\n",
// vert_prog // vert_prog
" vec4 currentFramePosition;\n" " vec4 currentFramePosition;\n"
" vec4 nextFramePosition;\n" " vec4 nextFramePosition;\n"
"\n" "\n"
" currentFramePosition = gl_Vertex * (1.0 - frameProgress);\n" " currentFramePosition = curVertex * (1.0 - frameProgress);\n"
" nextFramePosition = nextFrameData * frameProgress;\n" " nextFramePosition = nextFrameData * frameProgress;\n"
" currentFramePosition = currentFramePosition + nextFramePosition;\n" " curVertex = currentFramePosition + nextFramePosition;\n"
" result = gl_ModelViewProjectionMatrix * currentFramePosition;\n" "\n"
" currentFramePosition = vec4(curNormal, 1.0) * (1.0 - frameProgress);\n"
" nextFramePosition = nextFrameNormal * frameProgress;\n"
" curNormal = vec3(currentFramePosition + nextFramePosition);\n"
"\n", "\n",
// frag_def // frag_def
"", "",
@ -234,8 +238,8 @@ _prprogrambit prprogrambits[PR_BIT_COUNT] = {
"varying vec3 vertexPos;\n" "varying vec3 vertexPos;\n"
"\n", "\n",
// vert_prog // vert_prog
" vertexNormal = normalize(gl_NormalMatrix * gl_Normal);\n" " vertexNormal = normalize(gl_NormalMatrix * curNormal);\n"
" vertexPos = vec3(gl_ModelViewMatrix * gl_Vertex);\n" " vertexPos = vec3(gl_ModelViewMatrix * curVertex);\n"
"\n", "\n",
// frag_def // frag_def
"uniform int lightCount;\n" "uniform int lightCount;\n"
@ -302,11 +306,11 @@ _prprogrambit prprogrambits[PR_BIT_COUNT] = {
// vert_def // vert_def
"void main(void)\n" "void main(void)\n"
"{\n" "{\n"
" vec4 result = ftransform();\n" " vec4 curVertex = gl_Vertex;\n"
" int l = 0;\n" " vec3 curNormal = gl_Normal;\n"
"\n", "\n",
// vert_prog // vert_prog
" gl_Position = result;\n" " gl_Position = gl_ModelViewProjectionMatrix * curVertex;\n"
"}\n", "}\n",
// frag_def // frag_def
"void main(void)\n" "void main(void)\n"
@ -2485,31 +2489,31 @@ static void polymer_drawmdsprite(spritetype *tspr)
bglTranslatef(0.0f, 0.0, m->zadd * 64); bglTranslatef(0.0f, 0.0, m->zadd * 64);
// debug code for drawing the model bounding sphere // debug code for drawing the model bounding sphere
// bglDisable(GL_TEXTURE_2D); // bglDisable(GL_TEXTURE_2D);
// bglBegin(GL_LINES); // bglBegin(GL_LINES);
// bglColor4f(1.0, 0.0, 0.0, 1.0); // bglColor4f(1.0, 0.0, 0.0, 1.0);
// bglVertex3f(m->head.frames[m->cframe].cen.x, // bglVertex3f(m->head.frames[m->cframe].cen.x,
// m->head.frames[m->cframe].cen.y, // m->head.frames[m->cframe].cen.y,
// m->head.frames[m->cframe].cen.z); // m->head.frames[m->cframe].cen.z);
// bglVertex3f(m->head.frames[m->cframe].cen.x + m->head.frames[m->cframe].r, // bglVertex3f(m->head.frames[m->cframe].cen.x + m->head.frames[m->cframe].r,
// m->head.frames[m->cframe].cen.y, // m->head.frames[m->cframe].cen.y,
// m->head.frames[m->cframe].cen.z); // m->head.frames[m->cframe].cen.z);
// bglColor4f(0.0, 1.0, 0.0, 1.0); // bglColor4f(0.0, 1.0, 0.0, 1.0);
// bglVertex3f(m->head.frames[m->cframe].cen.x, // bglVertex3f(m->head.frames[m->cframe].cen.x,
// m->head.frames[m->cframe].cen.y, // m->head.frames[m->cframe].cen.y,
// m->head.frames[m->cframe].cen.z); // m->head.frames[m->cframe].cen.z);
// bglVertex3f(m->head.frames[m->cframe].cen.x, // bglVertex3f(m->head.frames[m->cframe].cen.x,
// m->head.frames[m->cframe].cen.y + m->head.frames[m->cframe].r, // m->head.frames[m->cframe].cen.y + m->head.frames[m->cframe].r,
// m->head.frames[m->cframe].cen.z); // m->head.frames[m->cframe].cen.z);
// bglColor4f(0.0, 0.0, 1.0, 1.0); // bglColor4f(0.0, 0.0, 1.0, 1.0);
// bglVertex3f(m->head.frames[m->cframe].cen.x, // bglVertex3f(m->head.frames[m->cframe].cen.x,
// m->head.frames[m->cframe].cen.y, // m->head.frames[m->cframe].cen.y,
// m->head.frames[m->cframe].cen.z); // m->head.frames[m->cframe].cen.z);
// bglVertex3f(m->head.frames[m->cframe].cen.x, // bglVertex3f(m->head.frames[m->cframe].cen.x,
// m->head.frames[m->cframe].cen.y, // m->head.frames[m->cframe].cen.y,
// m->head.frames[m->cframe].cen.z + m->head.frames[m->cframe].r); // m->head.frames[m->cframe].cen.z + m->head.frames[m->cframe].r);
// bglEnd(); // bglEnd();
// bglEnable(GL_TEXTURE_2D); // bglEnable(GL_TEXTURE_2D);
polymer_getscratchmaterial(&mdspritematerial); polymer_getscratchmaterial(&mdspritematerial);
@ -2553,6 +2557,26 @@ static void polymer_drawmdsprite(spritetype *tspr)
v0 = &s->geometry[m->cframe*s->numverts*6]; v0 = &s->geometry[m->cframe*s->numverts*6];
v1 = &s->geometry[m->nframe*s->numverts*6]; v1 = &s->geometry[m->nframe*s->numverts*6];
// debug code for drawing model normals
// bglDisable(GL_TEXTURE_2D);
// bglBegin(GL_LINES);
// bglColor4f(1.0, 1.0, 1.0, 1.0);
//
// int i = 0;
// while (i < s->numverts)
// {
// bglVertex3f(v0[(i * 6) + 0],
// v0[(i * 6) + 1],
// v0[(i * 6) + 2]);
// bglVertex3f(v0[(i * 6) + 0] + v0[(i * 6) + 3] * 100,
// v0[(i * 6) + 1] + v0[(i * 6) + 4] * 100,
// v0[(i * 6) + 2] + v0[(i * 6) + 5] * 100);
// i++;
// }
// bglEnd();
// bglEnable(GL_TEXTURE_2D);
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);
if (!mdspritematerial.diffusemap) if (!mdspritematerial.diffusemap)
@ -2576,6 +2600,8 @@ static void polymer_drawmdsprite(spritetype *tspr)
mdloadskin((md2model_t *)m,tile2model[Ptile2tile(tspr->picnum,lpal)].skinnum,GLOWPAL,surfi); mdloadskin((md2model_t *)m,tile2model[Ptile2tile(tspr->picnum,lpal)].skinnum,GLOWPAL,surfi);
} }
bglEnableClientState(GL_NORMAL_ARRAY);
if (pr_vbos > 1) if (pr_vbos > 1)
{ {
bglBindBufferARB(GL_ARRAY_BUFFER_ARB, m->texcoords[surfi]); bglBindBufferARB(GL_ARRAY_BUFFER_ARB, m->texcoords[surfi]);
@ -2583,6 +2609,7 @@ static void polymer_drawmdsprite(spritetype *tspr)
bglBindBufferARB(GL_ARRAY_BUFFER_ARB, m->geometry[surfi]); bglBindBufferARB(GL_ARRAY_BUFFER_ARB, m->geometry[surfi]);
bglVertexPointer(3, GL_FLOAT, sizeof(float) * 6, (GLfloat*)(m->cframe * s->numverts * sizeof(float) * 6)); bglVertexPointer(3, GL_FLOAT, sizeof(float) * 6, (GLfloat*)(m->cframe * s->numverts * sizeof(float) * 6));
bglNormalPointer(GL_FLOAT, sizeof(float) * 6, (GLfloat*)(m->cframe * s->numverts * sizeof(float) * 6) + 3);
if (pr_gpusmoothing) if (pr_gpusmoothing)
{ {
@ -2603,6 +2630,7 @@ static void polymer_drawmdsprite(spritetype *tspr)
else else
{ {
bglVertexPointer(3, GL_FLOAT, sizeof(float) * 6, v0); bglVertexPointer(3, GL_FLOAT, sizeof(float) * 6, v0);
bglNormalPointer(GL_FLOAT, sizeof(float) * 6, v0 + 3);
bglTexCoordPointer(2, GL_FLOAT, 0, s->uv); bglTexCoordPointer(2, GL_FLOAT, 0, s->uv);
if (pr_gpusmoothing) if (pr_gpusmoothing)
@ -2617,6 +2645,8 @@ static void polymer_drawmdsprite(spritetype *tspr)
polymer_unbindmaterial(materialbits); polymer_unbindmaterial(materialbits);
} }
bglDisableClientState(GL_NORMAL_ARRAY);
} }
bglPopMatrix(); bglPopMatrix();
@ -2811,10 +2841,15 @@ static int32_t polymer_bindmaterial(_prmaterial material, char* lights, int
if (programbits & prprogrambits[PR_BIT_ANIM_INTERPOLATION].bit) if (programbits & prprogrambits[PR_BIT_ANIM_INTERPOLATION].bit)
{ {
bglEnableVertexAttribArrayARB(prprograms[programbits].attrib_nextFrameData); bglEnableVertexAttribArrayARB(prprograms[programbits].attrib_nextFrameData);
bglEnableVertexAttribArrayARB(prprograms[programbits].attrib_nextFrameNormal);
bglVertexAttribPointerARB(prprograms[programbits].attrib_nextFrameData, bglVertexAttribPointerARB(prprograms[programbits].attrib_nextFrameData,
3, GL_FLOAT, GL_FALSE, 3, GL_FLOAT, GL_FALSE,
material.nextframedatastride, material.nextframedatastride,
material.nextframedata); material.nextframedata);
bglVertexAttribPointerARB(prprograms[programbits].attrib_nextFrameNormal,
3, GL_FLOAT, GL_FALSE,
material.nextframedatastride,
material.nextframedata + 3);
bglUniform1fARB(prprograms[programbits].uniform_frameProgress, material.frameprogress); bglUniform1fARB(prprograms[programbits].uniform_frameProgress, material.frameprogress);
} }
@ -2919,6 +2954,7 @@ static void polymer_unbindmaterial(int32_t programbits)
// PR_BIT_ANIM_INTERPOLATION // PR_BIT_ANIM_INTERPOLATION
if (programbits & prprogrambits[PR_BIT_ANIM_INTERPOLATION].bit) if (programbits & prprogrambits[PR_BIT_ANIM_INTERPOLATION].bit)
{ {
bglDisableVertexAttribArrayARB(prprograms[programbits].attrib_nextFrameNormal);
bglDisableVertexAttribArrayARB(prprograms[programbits].attrib_nextFrameData); bglDisableVertexAttribArrayARB(prprograms[programbits].attrib_nextFrameData);
} }
@ -3003,6 +3039,7 @@ static void polymer_compileprogram(int32_t programbits)
if (programbits & prprogrambits[PR_BIT_ANIM_INTERPOLATION].bit) if (programbits & prprogrambits[PR_BIT_ANIM_INTERPOLATION].bit)
{ {
prprograms[programbits].attrib_nextFrameData = bglGetAttribLocationARB(program, "nextFrameData"); prprograms[programbits].attrib_nextFrameData = bglGetAttribLocationARB(program, "nextFrameData");
prprograms[programbits].attrib_nextFrameNormal = bglGetAttribLocationARB(program, "nextFrameNormal");
prprograms[programbits].uniform_frameProgress = bglGetUniformLocationARB(program, "frameProgress"); prprograms[programbits].uniform_frameProgress = bglGetUniformLocationARB(program, "frameProgress");
} }