mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-12 19:20:38 +00:00
engine.c: always setup blending table whenever drawing translucent objects.
BUILD_LUNATIC. git-svn-id: https://svn.eduke32.com/eduke32@4338 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
caed55e9a4
commit
2afb680d22
2 changed files with 25 additions and 27 deletions
|
@ -3604,6 +3604,23 @@ static int32_t setup_globals_cf1(const sectortype *sec, int32_t pal, int32_t zd,
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void setup_blend(int32_t blend, int32_t doreverse)
|
||||||
|
{
|
||||||
|
if (blendtable[blend] == NULL)
|
||||||
|
blend = 0;
|
||||||
|
|
||||||
|
if (globalblend != blend)
|
||||||
|
{
|
||||||
|
globalblend = blend;
|
||||||
|
fixtransluscence(FP_OFF(getblendtab(blend)));
|
||||||
|
}
|
||||||
|
|
||||||
|
if (doreverse)
|
||||||
|
settransreverse();
|
||||||
|
else
|
||||||
|
settransnormal();
|
||||||
|
}
|
||||||
|
|
||||||
//
|
//
|
||||||
// ceilscan (internal)
|
// ceilscan (internal)
|
||||||
//
|
//
|
||||||
|
@ -3658,11 +3675,11 @@ static void ceilscan(int32_t x1, int32_t x2, int32_t sectnum)
|
||||||
msethlineshift(picsiz[globalpicnum]&15,picsiz[globalpicnum]>>4);
|
msethlineshift(picsiz[globalpicnum]&15,picsiz[globalpicnum]>>4);
|
||||||
break;
|
break;
|
||||||
case 256:
|
case 256:
|
||||||
settransnormal();
|
setup_blend(0, 0);
|
||||||
tsethlineshift(picsiz[globalpicnum]&15,picsiz[globalpicnum]>>4);
|
tsethlineshift(picsiz[globalpicnum]&15,picsiz[globalpicnum]>>4);
|
||||||
break;
|
break;
|
||||||
case 384:
|
case 384:
|
||||||
settransreverse();
|
setup_blend(0, 0);
|
||||||
tsethlineshift(picsiz[globalpicnum]&15,picsiz[globalpicnum]>>4);
|
tsethlineshift(picsiz[globalpicnum]&15,picsiz[globalpicnum]>>4);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -3753,11 +3770,11 @@ static void florscan(int32_t x1, int32_t x2, int32_t sectnum)
|
||||||
msethlineshift(picsiz[globalpicnum]&15,picsiz[globalpicnum]>>4);
|
msethlineshift(picsiz[globalpicnum]&15,picsiz[globalpicnum]>>4);
|
||||||
break;
|
break;
|
||||||
case 256:
|
case 256:
|
||||||
settransnormal();
|
setup_blend(0, 0);
|
||||||
tsethlineshift(picsiz[globalpicnum]&15,picsiz[globalpicnum]>>4);
|
tsethlineshift(picsiz[globalpicnum]&15,picsiz[globalpicnum]>>4);
|
||||||
break;
|
break;
|
||||||
case 384:
|
case 384:
|
||||||
settransreverse();
|
setup_blend(0, 1);
|
||||||
tsethlineshift(picsiz[globalpicnum]&15,picsiz[globalpicnum]>>4);
|
tsethlineshift(picsiz[globalpicnum]&15,picsiz[globalpicnum]>>4);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -5589,18 +5606,6 @@ static void drawsprite_opengl(int32_t snum)
|
||||||
//============================================================================= //POLYMOST ENDS
|
//============================================================================= //POLYMOST ENDS
|
||||||
}
|
}
|
||||||
|
|
||||||
static void setup_blend(int32_t blend)
|
|
||||||
{
|
|
||||||
if (blendtable[blend] == NULL)
|
|
||||||
blend = 0;
|
|
||||||
|
|
||||||
if (globalblend != blend)
|
|
||||||
{
|
|
||||||
globalblend = blend;
|
|
||||||
fixtransluscence(FP_OFF(getblendtab(blend)));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static void drawsprite_classic(int32_t snum)
|
static void drawsprite_classic(int32_t snum)
|
||||||
{
|
{
|
||||||
int32_t xoff, yoff, xspan, yspan;
|
int32_t xoff, yoff, xspan, yspan;
|
||||||
|
@ -5680,12 +5685,8 @@ static void drawsprite_classic(int32_t snum)
|
||||||
if (palookup[globalpal] == NULL) globalpal = 0; // JBF: fixes null-pointer crash
|
if (palookup[globalpal] == NULL) globalpal = 0; // JBF: fixes null-pointer crash
|
||||||
globalshade = tspr->shade;
|
globalshade = tspr->shade;
|
||||||
|
|
||||||
setup_blend(tspr->blend);
|
|
||||||
|
|
||||||
if (cstat&2)
|
if (cstat&2)
|
||||||
{
|
setup_blend(tspr->blend, cstat&512);
|
||||||
if (cstat&512) settransreverse(); else settransnormal();
|
|
||||||
}
|
|
||||||
|
|
||||||
xoff = picanm[tilenum].xofs + tspr->xoffset;
|
xoff = picanm[tilenum].xofs + tspr->xoffset;
|
||||||
yoff = picanm[tilenum].yofs + tspr->yoffset;
|
yoff = picanm[tilenum].yofs + tspr->yoffset;
|
||||||
|
@ -6693,9 +6694,7 @@ static void drawmaskwall(int16_t damaskwallcnt)
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if (globalorientation&128)
|
if (globalorientation&128)
|
||||||
{
|
setup_blend(0, globalorientation&512);
|
||||||
if (globalorientation&512) settransreverse(); else settransnormal();
|
|
||||||
}
|
|
||||||
|
|
||||||
transmaskwallscan(xb1[z],xb2[z], 0);
|
transmaskwallscan(xb1[z],xb2[z], 0);
|
||||||
}
|
}
|
||||||
|
@ -7713,7 +7712,7 @@ static void dorotatesprite(int32_t sx, int32_t sy, int32_t z, int16_t a, int16_t
|
||||||
#else
|
#else
|
||||||
tsetupspritevline(palookupoffs,xv,yv,ysiz);
|
tsetupspritevline(palookupoffs,xv,yv,ysiz);
|
||||||
#endif
|
#endif
|
||||||
if (dastat & RS_TRANS2) settransreverse(); else settransnormal();
|
setup_blend(0, dastat & RS_TRANS2);
|
||||||
}
|
}
|
||||||
|
|
||||||
for (x=x1; x<x2; x++)
|
for (x=x1; x<x2; x++)
|
||||||
|
@ -9942,7 +9941,7 @@ void drawmapview(int32_t dax, int32_t day, int32_t zoome, int16_t ang)
|
||||||
msethlineshift(ox,oy);
|
msethlineshift(ox,oy);
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if (spr->cstat&512) settransreverse(); else settransnormal();
|
setup_blend(spr->blend, spr->cstat&512);
|
||||||
tsethlineshift(ox,oy);
|
tsethlineshift(ox,oy);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -3424,7 +3424,6 @@ static void palaccum_add(palaccum_t *pa, const palette_t *pal, int32_t f)
|
||||||
pa->maxf = max(pa->maxf, f);
|
pa->maxf = max(pa->maxf, f);
|
||||||
pa->sumf += f;
|
pa->sumf += f;
|
||||||
|
|
||||||
// TODO: we need to do away with this 0-63 scale weirdness someday.
|
|
||||||
pa->r += f*clamp(pal->r, 0, 63);
|
pa->r += f*clamp(pal->r, 0, 63);
|
||||||
pa->g += f*clamp(pal->g, 0, 63);
|
pa->g += f*clamp(pal->g, 0, 63);
|
||||||
pa->b += f*clamp(pal->b, 0, 63);
|
pa->b += f*clamp(pal->b, 0, 63);
|
||||||
|
|
Loading…
Reference in a new issue