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:
helixhorned 2014-02-19 19:47:28 +00:00
parent caed55e9a4
commit 2afb680d22
2 changed files with 25 additions and 27 deletions

View file

@ -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);
} }

View file

@ -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);