mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-11 18:50:46 +00:00
Classic drawmasks(): if sprite is on other side of maskwall, always draw it first.
This fixes the bug reported here: http://forums.duke4.net/topic/5340-bug-with-masked-walls/page__view__findpost__p__123233 But I haven't checked the change for any adverse effects. git-svn-id: https://svn.eduke32.com/eduke32@3701 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
14b16a10eb
commit
b6be776079
1 changed files with 12 additions and 7 deletions
|
@ -9209,6 +9209,8 @@ killsprite:
|
|||
const int32_t w = (getrendermode()==REND_POLYMER) ?
|
||||
maskwall[maskwallcnt] : thewall[maskwall[maskwallcnt]];
|
||||
|
||||
const int32_t otherside_spr_first = (getrendermode() == REND_CLASSIC);
|
||||
|
||||
dot.x = (float)wall[w].x;
|
||||
dot.y = (float)wall[w].y;
|
||||
dot2.x = (float)wall[wall[w].point2].x;
|
||||
|
@ -9216,11 +9218,14 @@ killsprite:
|
|||
|
||||
maskeq = equation(dot.x, dot.y, dot2.x, dot2.y);
|
||||
|
||||
if (!otherside_spr_first)
|
||||
{
|
||||
p1eq = equation(pos.x, pos.y, dot.x, dot.y);
|
||||
p2eq = equation(pos.x, pos.y, dot2.x, dot2.y);
|
||||
|
||||
middle.x = (dot.x + dot2.x) / 2;
|
||||
middle.y = (dot.y + dot2.y) / 2;
|
||||
}
|
||||
|
||||
i = spritesortcnt;
|
||||
while (i--)
|
||||
|
@ -9233,9 +9238,9 @@ killsprite:
|
|||
spr.y = (float)tspriteptr[i]->y;
|
||||
|
||||
if (!sameside(&maskeq, &spr, &pos) &&
|
||||
sameside(&p1eq, &middle, &spr) &&
|
||||
sameside(&p2eq, &middle, &spr)
|
||||
)
|
||||
(otherside_spr_first ||
|
||||
(sameside(&p1eq, &middle, &spr) &&
|
||||
sameside(&p2eq, &middle, &spr))))
|
||||
{
|
||||
drawsprite(i);
|
||||
tspriteptr[i] = NULL;
|
||||
|
|
Loading…
Reference in a new issue