mirror of
https://github.com/ZDoom/raze-gles.git
synced 2024-12-25 03:00:46 +00:00
Polymer: bring the ypanning correction for non-pow2 walls closer to Pmost's, pt1
This makes the corrections conditional on where they appear in (under-, over-, white or mask wall). git-svn-id: https://svn.eduke32.com/eduke32@2821 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
6bafc7d176
commit
fe1a5fe2a6
2 changed files with 17 additions and 7 deletions
|
@ -2721,14 +2721,16 @@ static int32_t polymer_initwall(int16_t wallnum)
|
||||||
return (1);
|
return (1);
|
||||||
}
|
}
|
||||||
|
|
||||||
static float calc_ypancoef(char curypanning, int16_t curpicnum)
|
static float calc_ypancoef(char curypanning, int16_t curpicnum, int32_t dopancor)
|
||||||
{
|
{
|
||||||
float ypancoef = (float)(pow2long[picsiz[curpicnum] >> 4]);
|
float ypancoef = (float)(pow2long[picsiz[curpicnum] >> 4]);
|
||||||
|
|
||||||
if (ypancoef < tilesizy[curpicnum])
|
if (ypancoef < tilesizy[curpicnum])
|
||||||
ypancoef *= 2;
|
ypancoef *= 2;
|
||||||
if (curypanning > 256 - (ypancoef - tilesizy[curpicnum]) * (256.0f / ypancoef))
|
|
||||||
curypanning -= (ypancoef - tilesizy[curpicnum]) * (256.0f / ypancoef);
|
if (dopancor)
|
||||||
|
if (curypanning > 256 - (ypancoef - tilesizy[curpicnum]) * (256.0f / ypancoef))
|
||||||
|
curypanning -= (ypancoef - tilesizy[curpicnum]) * (256.0f / ypancoef);
|
||||||
|
|
||||||
ypancoef *= (float)curypanning / (256.0f * (float)tilesizy[curpicnum]);
|
ypancoef *= (float)curypanning / (256.0f * (float)tilesizy[curpicnum]);
|
||||||
|
|
||||||
|
@ -2875,7 +2877,8 @@ static void polymer_updatewall(int16_t wallnum)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (wal->ypanning)
|
if (wal->ypanning)
|
||||||
ypancoef = calc_ypancoef(wal->ypanning, curpicnum);
|
// white
|
||||||
|
ypancoef = calc_ypancoef(wal->ypanning, curpicnum, !(wal->cstat & 4));
|
||||||
else
|
else
|
||||||
ypancoef = 0;
|
ypancoef = 0;
|
||||||
|
|
||||||
|
@ -2940,7 +2943,8 @@ static void polymer_updatewall(int16_t wallnum)
|
||||||
yref = nsec->floorz;
|
yref = nsec->floorz;
|
||||||
|
|
||||||
if (curypanning)
|
if (curypanning)
|
||||||
ypancoef = calc_ypancoef(curypanning, curpicnum);
|
// under
|
||||||
|
ypancoef = calc_ypancoef(curypanning, curpicnum, !(wall[nwallnum].cstat & 4));
|
||||||
else
|
else
|
||||||
ypancoef = 0;
|
ypancoef = 0;
|
||||||
|
|
||||||
|
@ -3020,7 +3024,8 @@ static void polymer_updatewall(int16_t wallnum)
|
||||||
yref = nsec->ceilingz;
|
yref = nsec->ceilingz;
|
||||||
|
|
||||||
if (wal->ypanning)
|
if (wal->ypanning)
|
||||||
ypancoef = calc_ypancoef(wal->ypanning, curpicnum);
|
// over
|
||||||
|
ypancoef = calc_ypancoef(wal->ypanning, curpicnum, wal->cstat & 4);
|
||||||
else
|
else
|
||||||
ypancoef = 0;
|
ypancoef = 0;
|
||||||
|
|
||||||
|
@ -3065,7 +3070,8 @@ static void polymer_updatewall(int16_t wallnum)
|
||||||
curpicnum = walloverpicnum;
|
curpicnum = walloverpicnum;
|
||||||
|
|
||||||
if (wal->ypanning)
|
if (wal->ypanning)
|
||||||
ypancoef = calc_ypancoef(wal->ypanning, curpicnum);
|
// mask
|
||||||
|
ypancoef = calc_ypancoef(wal->ypanning, curpicnum, 0);
|
||||||
else
|
else
|
||||||
ypancoef = 0;
|
ypancoef = 0;
|
||||||
|
|
||||||
|
|
|
@ -4082,6 +4082,7 @@ static void polymost_drawalls(int32_t bunch)
|
||||||
|
|
||||||
if (!(wal->cstat&4)) i = sector[nextsectnum].ceilingz; else i = sec->ceilingz;
|
if (!(wal->cstat&4)) i = sector[nextsectnum].ceilingz; else i = sec->ceilingz;
|
||||||
|
|
||||||
|
// over
|
||||||
calc_ypanning(i, ryp0, ryp1, x0, x1, wal->ypanning, wal->yrepeat, wal->cstat&4);
|
calc_ypanning(i, ryp0, ryp1, x0, x1, wal->ypanning, wal->yrepeat, wal->cstat&4);
|
||||||
|
|
||||||
if (wal->cstat&8) //xflip
|
if (wal->cstat&8) //xflip
|
||||||
|
@ -4118,6 +4119,7 @@ static void polymost_drawalls(int32_t bunch)
|
||||||
|
|
||||||
if (!(nwal->cstat&4)) i = sector[nextsectnum].floorz; else i = sec->ceilingz;
|
if (!(nwal->cstat&4)) i = sector[nextsectnum].floorz; else i = sec->ceilingz;
|
||||||
|
|
||||||
|
// under
|
||||||
calc_ypanning(i, ryp0, ryp1, x0, x1, nwal->ypanning, wal->yrepeat, !(nwal->cstat&4));
|
calc_ypanning(i, ryp0, ryp1, x0, x1, nwal->ypanning, wal->yrepeat, !(nwal->cstat&4));
|
||||||
|
|
||||||
if (wal->cstat&8) //xflip
|
if (wal->cstat&8) //xflip
|
||||||
|
@ -4150,6 +4152,7 @@ static void polymost_drawalls(int32_t bunch)
|
||||||
if (nextsectnum >= 0) { if (!(wal->cstat&4)) i = nextsec->ceilingz; else i = sec->ceilingz; }
|
if (nextsectnum >= 0) { if (!(wal->cstat&4)) i = nextsec->ceilingz; else i = sec->ceilingz; }
|
||||||
else { if (!(wal->cstat&4)) i = sec->ceilingz; else i = sec->floorz; }
|
else { if (!(wal->cstat&4)) i = sec->ceilingz; else i = sec->floorz; }
|
||||||
|
|
||||||
|
// white
|
||||||
calc_ypanning(i, ryp0, ryp1, x0, x1, wal->ypanning, wal->yrepeat, !(wal->cstat&4));
|
calc_ypanning(i, ryp0, ryp1, x0, x1, wal->ypanning, wal->yrepeat, !(wal->cstat&4));
|
||||||
|
|
||||||
if (wal->cstat&8) //xflip
|
if (wal->cstat&8) //xflip
|
||||||
|
@ -4717,6 +4720,7 @@ void polymost_drawmaskwall(int32_t damaskwallcnt)
|
||||||
|
|
||||||
if (!(wal->cstat&4)) i = z1; else i = z2;
|
if (!(wal->cstat&4)) i = z1; else i = z2;
|
||||||
|
|
||||||
|
// mask
|
||||||
calc_ypanning(i, ryp0, ryp1, x0, x1, wal->ypanning, wal->yrepeat, 0);
|
calc_ypanning(i, ryp0, ryp1, x0, x1, wal->ypanning, wal->yrepeat, 0);
|
||||||
|
|
||||||
if (wal->cstat&8) //xflip
|
if (wal->cstat&8) //xflip
|
||||||
|
|
Loading…
Reference in a new issue