mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-28 18:00:40 +00:00
- fixed clipping info not properly reset when rendering the scene in two passes.
We need to reset the gotsector array for that, but since we also need the accumulate result of both passes there's now two such arrays.
This commit is contained in:
parent
caa8efd3d5
commit
7a03967ceb
3 changed files with 27 additions and 21 deletions
|
@ -85,6 +85,7 @@ void BunchDrawer::StartScene()
|
||||||
Bunches.Clear();
|
Bunches.Clear();
|
||||||
CompareData.Clear();
|
CompareData.Clear();
|
||||||
gotsector.Zero();
|
gotsector.Zero();
|
||||||
|
gotsector2.Zero();
|
||||||
gotwall.Zero();
|
gotwall.Zero();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -435,8 +436,8 @@ int BunchDrawer::FindClosestBunch()
|
||||||
|
|
||||||
void BunchDrawer::ProcessSector(int sectnum, bool portal)
|
void BunchDrawer::ProcessSector(int sectnum, bool portal)
|
||||||
{
|
{
|
||||||
if (gotsector[sectnum]) return;
|
if (gotsector2[sectnum]) return;
|
||||||
gotsector.Set(sectnum);
|
gotsector2.Set(sectnum);
|
||||||
|
|
||||||
auto sect = §or[sectnum];
|
auto sect = §or[sectnum];
|
||||||
bool inbunch;
|
bool inbunch;
|
||||||
|
@ -445,6 +446,9 @@ void BunchDrawer::ProcessSector(int sectnum, bool portal)
|
||||||
SetupSprite.Clock();
|
SetupSprite.Clock();
|
||||||
|
|
||||||
int z;
|
int z;
|
||||||
|
if (!gotsector[sectnum])
|
||||||
|
{
|
||||||
|
gotsector.Set(sectnum);
|
||||||
SectIterator it(sectnum);
|
SectIterator it(sectnum);
|
||||||
while ((z = it.NextIndex()) >= 0)
|
while ((z = it.NextIndex()) >= 0)
|
||||||
{
|
{
|
||||||
|
@ -467,6 +471,7 @@ void BunchDrawer::ProcessSector(int sectnum, bool portal)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
SetupSprite.Unclock();
|
SetupSprite.Unclock();
|
||||||
|
}
|
||||||
|
|
||||||
if (automapping)
|
if (automapping)
|
||||||
show2dsector.Set(sectnum);
|
show2dsector.Set(sectnum);
|
||||||
|
@ -547,6 +552,7 @@ void BunchDrawer::RenderScene(const int* viewsectors, unsigned sectcount, bool p
|
||||||
ang2 = bamang(rotang + ANGLE_90);
|
ang2 = bamang(rotang + ANGLE_90);
|
||||||
process();
|
process();
|
||||||
clipper->Clear();
|
clipper->Clear();
|
||||||
|
gotsector2.Zero();
|
||||||
ang1 = bamang(rotang + ANGLE_90);
|
ang1 = bamang(rotang + ANGLE_90);
|
||||||
ang2 = bamang(rotang - ANGLE_90);
|
ang2 = bamang(rotang - ANGLE_90);
|
||||||
process();
|
process();
|
||||||
|
|
|
@ -28,6 +28,7 @@ class BunchDrawer
|
||||||
vec2_t iview;
|
vec2_t iview;
|
||||||
float gcosang, gsinang;
|
float gcosang, gsinang;
|
||||||
FixedBitArray<MAXSECTORS> gotsector;
|
FixedBitArray<MAXSECTORS> gotsector;
|
||||||
|
FixedBitArray<MAXSECTORS> gotsector2;
|
||||||
FixedBitArray<MAXWALLS> gotwall;
|
FixedBitArray<MAXWALLS> gotwall;
|
||||||
binangle ang1, ang2;
|
binangle ang1, ang2;
|
||||||
|
|
||||||
|
|
|
@ -1046,7 +1046,6 @@ void HWWall::Process(HWDrawInfo* di, walltype* wal, sectortype* frontsector, sec
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
globalr = globalg = globalb = 255;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void HWWall::ProcessWallSprite(HWDrawInfo* di, spritetype* spr, sectortype* sector)
|
void HWWall::ProcessWallSprite(HWDrawInfo* di, spritetype* spr, sectortype* sector)
|
||||||
|
|
Loading…
Reference in a new issue