mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-23 15:40:39 +00:00
Polymer: bring the ypanning correction for non-pow2 walls closer to Pmost's, pt2
This changes a constant inside the panning calculation from 256 to 255 (making e.g. panning 255 and 0 the same in the "San Andreas fault" sign in E1L5) and uses the correct reference wall for the "do panning correction?" conditional. Now, the problematic walls should look the same as in Polymost. git-svn-id: https://svn.eduke32.com/eduke32@2822 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
fe1a5fe2a6
commit
d66856eeea
1 changed files with 14 additions and 3 deletions
|
@ -2729,8 +2729,13 @@ static float calc_ypancoef(char curypanning, int16_t curpicnum, int32_t dopancor
|
||||||
ypancoef *= 2;
|
ypancoef *= 2;
|
||||||
|
|
||||||
if (dopancor)
|
if (dopancor)
|
||||||
if (curypanning > 256 - (ypancoef - tilesizy[curpicnum]) * (256.0f / ypancoef))
|
{
|
||||||
curypanning -= (ypancoef - tilesizy[curpicnum]) * (256.0f / ypancoef);
|
int32_t yoffs;
|
||||||
|
|
||||||
|
ftol((ypancoef - tilesizy[curpicnum]) * (255.0f / ypancoef), &yoffs);
|
||||||
|
if (curypanning > 256 - yoffs)
|
||||||
|
curypanning -= yoffs;
|
||||||
|
}
|
||||||
|
|
||||||
ypancoef *= (float)curypanning / (256.0f * (float)tilesizy[curpicnum]);
|
ypancoef *= (float)curypanning / (256.0f * (float)tilesizy[curpicnum]);
|
||||||
|
|
||||||
|
@ -2910,6 +2915,8 @@ static void polymer_updatewall(int16_t wallnum)
|
||||||
|
|
||||||
if ((underwall) || (wal->cstat & 16) || (wal->cstat & 32))
|
if ((underwall) || (wal->cstat & 16) || (wal->cstat & 32))
|
||||||
{
|
{
|
||||||
|
int32_t refwall;
|
||||||
|
|
||||||
if (s->floor.buffer[((wallnum - sec->wallptr) * 5) + 1] < ns->floor.buffer[((nnwallnum - nsec->wallptr) * 5) + 1])
|
if (s->floor.buffer[((wallnum - sec->wallptr) * 5) + 1] < ns->floor.buffer[((nnwallnum - nsec->wallptr) * 5) + 1])
|
||||||
Bmemcpy(w->wall.buffer, &s->floor.buffer[(wallnum - sec->wallptr) * 5], sizeof(GLfloat) * 3);
|
Bmemcpy(w->wall.buffer, &s->floor.buffer[(wallnum - sec->wallptr) * 5], sizeof(GLfloat) * 3);
|
||||||
else
|
else
|
||||||
|
@ -2925,6 +2932,8 @@ static void polymer_updatewall(int16_t wallnum)
|
||||||
curshade = wall[nwallnum].shade;
|
curshade = wall[nwallnum].shade;
|
||||||
curxpanning = wall[nwallnum].xpanning;
|
curxpanning = wall[nwallnum].xpanning;
|
||||||
curypanning = wall[nwallnum].ypanning;
|
curypanning = wall[nwallnum].ypanning;
|
||||||
|
|
||||||
|
refwall = nwallnum;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -2933,6 +2942,8 @@ static void polymer_updatewall(int16_t wallnum)
|
||||||
curshade = wal->shade;
|
curshade = wal->shade;
|
||||||
curxpanning = wal->xpanning;
|
curxpanning = wal->xpanning;
|
||||||
curypanning = wal->ypanning;
|
curypanning = wal->ypanning;
|
||||||
|
|
||||||
|
refwall = wallnum;
|
||||||
}
|
}
|
||||||
|
|
||||||
polymer_getbuildmaterial(&w->wall.material, curpicnum, curpal, curshade, 0);
|
polymer_getbuildmaterial(&w->wall.material, curpicnum, curpal, curshade, 0);
|
||||||
|
@ -2944,7 +2955,7 @@ static void polymer_updatewall(int16_t wallnum)
|
||||||
|
|
||||||
if (curypanning)
|
if (curypanning)
|
||||||
// under
|
// under
|
||||||
ypancoef = calc_ypancoef(curypanning, curpicnum, !(wall[nwallnum].cstat & 4));
|
ypancoef = calc_ypancoef(curypanning, curpicnum, !(wall[refwall].cstat & 4));
|
||||||
else
|
else
|
||||||
ypancoef = 0;
|
ypancoef = 0;
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue