Re-implements the old light priority system, removes applylights() and optimizes the light invalidation code.

git-svn-id: https://svn.eduke32.com/eduke32@1405 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
plagman 2009-06-06 13:40:15 +00:00
parent dbb84c7ee8
commit b112e1d3c3

View file

@ -917,6 +917,7 @@ void polymer_drawsprite(int32_t snum)
float xratio, yratio, ang; float xratio, yratio, ang;
float spos[3]; float spos[3];
GLfloat *inbuffer; GLfloat *inbuffer;
uint8_t curpriority;
if (pr_verbosity >= 3) OSD_Printf("PR : Sprite %i...\n", snum); if (pr_verbosity >= 3) OSD_Printf("PR : Sprite %i...\n", snum);
@ -1068,20 +1069,32 @@ void polymer_drawsprite(int32_t snum)
spriteplane.lightcount = 0; spriteplane.lightcount = 0;
i = j = 0; curpriority = 0;
while (j < lightcount)
{
while (prlights[i].flags.active == 0) {
i++;
}
if (polymer_planeinlight(&spriteplane, &prlights[i])) while (curpriority < pr_maxlightpriority)
{
i = j = 0;
while (j < lightcount)
{ {
spriteplane.lights[spriteplane.lightcount] = i; while (prlights[i].flags.active == 0) {
spriteplane.lightcount++; i++;
}
if (prlights[i].priority != curpriority) {
i++;
j++;
continue;
}
if (polymer_planeinlight(&spriteplane, &prlights[i]))
{
spriteplane.lights[spriteplane.lightcount] = i;
spriteplane.lightcount++;
}
i++;
j++;
} }
i++; curpriority++;
j++;
} }
if ((tspr->cstat & 64) && ((tspr->cstat>>4) & 3)) if ((tspr->cstat & 64) && ((tspr->cstat>>4) & 3))
@ -1119,6 +1132,9 @@ int16_t polymer_addlight(_prlight* light)
if (lightcount >= PR_MAXLIGHTS) if (lightcount >= PR_MAXLIGHTS)
return (-1); return (-1);
if (light->priority > pr_maxlightpriority)
return (-1);
lighti = 0; lighti = 0;
while ((lighti < PR_MAXLIGHTS) && (prlights[lighti].flags.active)) { while ((lighti < PR_MAXLIGHTS) && (prlights[lighti].flags.active)) {
lighti++; lighti++;
@ -2317,6 +2333,9 @@ static void polymer_updatewall(int16_t wallnum)
} }
else else
{ {
if (w->invalidid != invalid)
polymer_invalidatesectorlights(sectorofwall(wallnum));
w->invalidid = invalid; w->invalidid = invalid;
w->cstat = wal->cstat; w->cstat = wal->cstat;
w->picnum = wallpicnum; w->picnum = wallpicnum;
@ -2336,8 +2355,6 @@ static void polymer_updatewall(int16_t wallnum)
} }
} }
polymer_invalidatesectorlights(sectorofwall(wallnum));
w->underover = underwall = overwall = 0; w->underover = underwall = overwall = 0;
if (wal->cstat & 8) if (wal->cstat & 8)
@ -3113,6 +3130,7 @@ static void polymer_drawmdsprite(spritetype *tspr)
float sradius, lradius; float sradius, lradius;
int16_t modellights[PR_MAXLIGHTS]; int16_t modellights[PR_MAXLIGHTS];
char modellightcount; char modellightcount;
uint8_t curpriority;
m = (md3model_t*)models[tile2model[Ptile2tile(tspr->picnum,sprite[tspr->owner].pal)].modelid]; m = (md3model_t*)models[tile2model[Ptile2tile(tspr->picnum,sprite[tspr->owner].pal)].modelid];
updateanimation((md2model_t *)m,tspr); updateanimation((md2model_t *)m,tspr);
@ -3259,6 +3277,7 @@ static void polymer_drawmdsprite(spritetype *tspr)
mdspritematerial.mdspritespace = GL_TRUE; mdspritematerial.mdspritespace = GL_TRUE;
modellightcount = 0; modellightcount = 0;
curpriority = 0;
// light culling // light culling
if (lightcount) if (lightcount)
@ -3279,38 +3298,47 @@ static void polymer_drawmdsprite(spritetype *tspr)
polymer_transformpoint(spos, tspos, spritemodelview); polymer_transformpoint(spos, tspos, spritemodelview);
polymer_transformpoint(tspos, spos, rootmodelviewmatrix); polymer_transformpoint(tspos, spos, rootmodelviewmatrix);
i = j = 0; while (curpriority < pr_maxlightpriority)
while (j < lightcount)
{ {
while (prlights[i].flags.active == 0) { i = j = 0;
i++; while (j < lightcount)
}
lradius = prlights[i].range / 1000.0f;
lpos[0] = prlights[i].y;
lpos[1] = -prlights[i].z / 16.0f;
lpos[2] = -prlights[i].x;
polymer_transformpoint(lpos, tlpos, rootmodelviewmatrix);
vec[0] = tlpos[0] - spos[0];
vec[0] *= vec[0];
vec[1] = tlpos[1] - spos[1];
vec[1] *= vec[1];
vec[2] = tlpos[2] - spos[2];
vec[2] *= vec[2];
if ((vec[0] + vec[1] + vec[2]) <=
((sradius+lradius) * (sradius+lradius)))
{ {
modellights[modellightcount] = i; while (prlights[i].flags.active == 0) {
modellightcount++; i++;
} }
i++;
j++;
}
if (prlights[i].priority != curpriority) {
i++;
j++;
continue;
}
lradius = prlights[i].range / 1000.0f;
lpos[0] = prlights[i].y;
lpos[1] = -prlights[i].z / 16.0f;
lpos[2] = -prlights[i].x;
polymer_transformpoint(lpos, tlpos, rootmodelviewmatrix);
vec[0] = tlpos[0] - spos[0];
vec[0] *= vec[0];
vec[1] = tlpos[1] - spos[1];
vec[1] *= vec[1];
vec[2] = tlpos[2] - spos[2];
vec[2] *= vec[2];
if ((vec[0] + vec[1] + vec[2]) <=
((sradius+lradius) * (sradius+lradius)))
{
modellights[modellightcount] = i;
modellightcount++;
}
i++;
j++;
}
curpriority++;
}
} }
for (surfi=0;surfi<m->head.numsurfs;surfi++) for (surfi=0;surfi<m->head.numsurfs;surfi++)
@ -4236,9 +4264,15 @@ static void polymer_addplanelight(_prplane* plane, int16_t lighti)
{ {
int16_t i; int16_t i;
if (plane->lightcount == PR_MAXLIGHTS)
return;
i = 0; i = 0;
while (i < PR_MAXLIGHTS) while (i < PR_MAXLIGHTS)
{ {
if ((plane->lights[i] != -1) && (prlights[plane->lights[i]].priority > prlights[lighti].priority))
break;
if (plane->lights[i] == -1) if (plane->lights[i] == -1)
{ {
plane->lights[i] = lighti; plane->lights[i] = lighti;
@ -4247,6 +4281,11 @@ static void polymer_addplanelight(_prplane* plane, int16_t lighti)
} }
i++; i++;
} }
memcpy(&plane->lights[i+1], &plane->lights[i], sizeof(int16_t) * (PR_MAXLIGHTS - (i+1)));
plane->lights[i] = lighti;
plane->lightcount++;
} }
static void polymer_deleteplanelight(_prplane* plane, int16_t lighti) static void polymer_deleteplanelight(_prplane* plane, int16_t lighti)