mirror of
https://github.com/ZDoom/raze-gles.git
synced 2024-12-26 03:30:46 +00:00
engine.c: Rewrite tslopevlin (translucent slope vline texmapping) for clarity.
git-svn-id: https://svn.eduke32.com/eduke32@2348 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
c900e4ef87
commit
0538c70242
1 changed files with 7 additions and 8 deletions
|
@ -4027,30 +4027,29 @@ static void setupslopevlin_alsotrans(int32_t logylogx, intptr_t bufplc, int32_t
|
||||||
ggpal = palookup[globalpal] + (getpalookup(0,globalshade)<<8);
|
ggpal = palookup[globalpal] + (getpalookup(0,globalshade)<<8);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void tslopevlin(intptr_t p, int32_t i, intptr_t slopaloffs, int32_t cnt, int32_t bx, int32_t by)
|
static void tslopevlin(uint8_t *p, int32_t i, const intptr_t *slopalptr, int32_t cnt, int32_t bx, int32_t by)
|
||||||
{
|
{
|
||||||
intptr_t *slopalptr;
|
|
||||||
int32_t bz, bzinc;
|
int32_t bz, bzinc;
|
||||||
uint32_t u, v;
|
uint32_t u, v;
|
||||||
|
|
||||||
char ch;
|
uint8_t ch;
|
||||||
|
|
||||||
bz = asm3; bzinc = (asm1>>3);
|
bz = asm3; bzinc = (asm1>>3);
|
||||||
slopalptr = (intptr_t *)slopaloffs;
|
|
||||||
|
|
||||||
for (; cnt>0; cnt--)
|
for (; cnt>0; cnt--)
|
||||||
{
|
{
|
||||||
i = krecipasm(bz>>6); bz += bzinc;
|
i = krecipasm(bz>>6); bz += bzinc;
|
||||||
u = bx+globalx3*i;
|
u = bx+globalx3*i;
|
||||||
v = by+globaly3*i;
|
v = by+globaly3*i;
|
||||||
ch = *(char *)(slopalptr[0] + ggbuf[((u>>(32-gglogx))<<gglogy)+(v>>(32-gglogy))]);
|
ch = *(uint8_t *)(slopalptr[0] + ggbuf[((u>>(32-gglogx))<<gglogy)+(v>>(32-gglogy))]);
|
||||||
|
|
||||||
if (globalorientation&128)
|
if (globalorientation&128)
|
||||||
{
|
{
|
||||||
if (ch != 255) *((char *)p) = transluc[*((char *)p)+(ggpal[ch]<<8)];
|
if (ch != 255) *p = transluc[*p+(ggpal[ch]<<8)];
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if (ch != 255) *((char *)p) = transluc[(*((char *)p)<<8)+ggpal[ch]];
|
if (ch != 255) *p = transluc[(*p<<8)+ggpal[ch]];
|
||||||
}
|
}
|
||||||
|
|
||||||
slopalptr--;
|
slopalptr--;
|
||||||
|
@ -4214,7 +4213,7 @@ static void grouscan(int32_t dax1, int32_t dax2, int32_t sectnum, char dastat)
|
||||||
if ((globalorientation&256)==0)
|
if ((globalorientation&256)==0)
|
||||||
slopevlin(ylookup[y2]+x+frameoffset,krecipasm(asm3>>3),(intptr_t)nptr2,y2-y1+1,globalx1,globaly1);
|
slopevlin(ylookup[y2]+x+frameoffset,krecipasm(asm3>>3),(intptr_t)nptr2,y2-y1+1,globalx1,globaly1);
|
||||||
else
|
else
|
||||||
tslopevlin(ylookup[y2]+x+frameoffset,krecipasm(asm3>>3),(intptr_t)nptr2,y2-y1+1,globalx1,globaly1);
|
tslopevlin((uint8_t *)(ylookup[y2]+x+frameoffset),0,nptr2,y2-y1+1,globalx1,globaly1);
|
||||||
|
|
||||||
if ((x&15) == 0) faketimerhandler();
|
if ((x&15) == 0) faketimerhandler();
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue