mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-12 03:00:38 +00:00
Added xpanning and ypanning actor members to control the new sprite panning feature.
git-svn-id: https://svn.eduke32.com/eduke32@590 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
a1e00d78ee
commit
cfa399998a
5 changed files with 100 additions and 2 deletions
|
@ -163,7 +163,8 @@ typedef struct BPACK {
|
||||||
short pitch, roll;
|
short pitch, roll;
|
||||||
int xoff, yoff, zoff;
|
int xoff, yoff, zoff;
|
||||||
unsigned char flags;
|
unsigned char flags;
|
||||||
char filler[3];
|
unsigned char xpanning, ypanning;
|
||||||
|
char filler[1];
|
||||||
} spriteexttype;
|
} spriteexttype;
|
||||||
|
|
||||||
typedef struct BPACK {
|
typedef struct BPACK {
|
||||||
|
|
|
@ -99,6 +99,8 @@ int zbufmem = 0, zbufysiz = 0, zbufbpl = 0, *zbufoff = 0;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef USE_OPENGL
|
#ifdef USE_OPENGL
|
||||||
|
static int srepeat = 0, trepeat = 0;
|
||||||
|
|
||||||
int glredbluemode = 0;
|
int glredbluemode = 0;
|
||||||
static int lastglredbluemode = 0, redblueclearcnt = 0;
|
static int lastglredbluemode = 0, redblueclearcnt = 0;
|
||||||
|
|
||||||
|
@ -1795,6 +1797,11 @@ void drawpoly(double *dpx, double *dpy, int n, int method)
|
||||||
|
|
||||||
bglBindTexture(GL_TEXTURE_2D, pth ? pth->glpic : 0);
|
bglBindTexture(GL_TEXTURE_2D, pth ? pth->glpic : 0);
|
||||||
|
|
||||||
|
if (srepeat)
|
||||||
|
bglTexParameteri(GL_TEXTURE_2D,GL_TEXTURE_WRAP_S,GL_REPEAT);
|
||||||
|
if (trepeat)
|
||||||
|
bglTexParameteri(GL_TEXTURE_2D,GL_TEXTURE_WRAP_T,GL_REPEAT);
|
||||||
|
|
||||||
// texture scale by parkar request
|
// texture scale by parkar request
|
||||||
if (pth && pth->hicr && ((pth->hicr->xscale != 1.0f) || (pth->hicr->yscale != 1.0f)) && !drawingskybox)
|
if (pth && pth->hicr && ((pth->hicr->xscale != 1.0f) || (pth->hicr->yscale != 1.0f)) && !drawingskybox)
|
||||||
{
|
{
|
||||||
|
@ -2131,6 +2138,11 @@ void drawpoly(double *dpx, double *dpy, int n, int method)
|
||||||
bglActiveTextureARB(--texunits);
|
bglActiveTextureARB(--texunits);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (srepeat)
|
||||||
|
bglTexParameteri(GL_TEXTURE_2D,GL_TEXTURE_WRAP_S,glinfo.clamptoedge?GL_CLAMP_TO_EDGE:GL_CLAMP);
|
||||||
|
if (trepeat)
|
||||||
|
bglTexParameteri(GL_TEXTURE_2D,GL_TEXTURE_WRAP_T,glinfo.clamptoedge?GL_CLAMP_TO_EDGE:GL_CLAMP);
|
||||||
|
|
||||||
if (fullbrightdrawingpass == 1) // tile has fullbright colors ?
|
if (fullbrightdrawingpass == 1) // tile has fullbright colors ?
|
||||||
{
|
{
|
||||||
fullbrightdrawingpass = 2;
|
fullbrightdrawingpass = 2;
|
||||||
|
@ -4443,6 +4455,12 @@ void polymost_drawsprite(int snum)
|
||||||
{ gvy = (float)tilesizy[globalpicnum]*gdo/(py[3]-py[0]+.002); gvo = -gvy*(py[0]-.001); }
|
{ gvy = (float)tilesizy[globalpicnum]*gdo/(py[3]-py[0]+.002); gvo = -gvy*(py[0]-.001); }
|
||||||
else { gvy = (float)tilesizy[globalpicnum]*gdo/(py[0]-py[3]-.002); gvo = -gvy*(py[3]+.001); }
|
else { gvy = (float)tilesizy[globalpicnum]*gdo/(py[0]-py[3]-.002); gvo = -gvy*(py[3]+.001); }
|
||||||
|
|
||||||
|
// sprite panning
|
||||||
|
guy -= gdy*((float)(spriteext[spritenum].xpanning)/255.f)*tilesizx[globalpicnum];
|
||||||
|
guo -= gdo*((float)(spriteext[spritenum].xpanning)/255.f)*tilesizx[globalpicnum];
|
||||||
|
gvy -= gdy*((float)(spriteext[spritenum].ypanning)/255.f)*tilesizy[globalpicnum];
|
||||||
|
gvo -= gdo*((float)(spriteext[spritenum].ypanning)/255.f)*tilesizy[globalpicnum];
|
||||||
|
|
||||||
//Clip sprites to ceilings/floors when no parallaxing and not sloped
|
//Clip sprites to ceilings/floors when no parallaxing and not sloped
|
||||||
if (!(sector[tspr->sectnum].ceilingstat&3))
|
if (!(sector[tspr->sectnum].ceilingstat&3))
|
||||||
{
|
{
|
||||||
|
@ -4455,7 +4473,22 @@ void polymost_drawsprite(int snum)
|
||||||
if (py[2] > sy0) py[2] = py[3] = sy0;
|
if (py[2] > sy0) py[2] = py[3] = sy0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef USE_OPENGL
|
||||||
|
if (spriteext[spritenum].xpanning)
|
||||||
|
srepeat = 1;
|
||||||
|
if (spriteext[spritenum].ypanning)
|
||||||
|
trepeat = 1;
|
||||||
|
#endif
|
||||||
|
|
||||||
pow2xsplit = 0; drawpoly(px,py,4,method);
|
pow2xsplit = 0; drawpoly(px,py,4,method);
|
||||||
|
|
||||||
|
#ifdef USE_OPENGL
|
||||||
|
if (spriteext[spritenum].xpanning)
|
||||||
|
srepeat = 0;
|
||||||
|
if (spriteext[spritenum].ypanning)
|
||||||
|
trepeat = 0;
|
||||||
|
#endif
|
||||||
|
|
||||||
break;
|
break;
|
||||||
case 1: //Wall sprite
|
case 1: //Wall sprite
|
||||||
|
|
||||||
|
@ -4519,6 +4552,10 @@ void polymost_drawsprite(int snum)
|
||||||
//gux*sx0 + guo = t0*tilesizx[globalpicnum]*yp0
|
//gux*sx0 + guo = t0*tilesizx[globalpicnum]*yp0
|
||||||
//gux*sx1 + guo = t1*tilesizx[globalpicnum]*yp1
|
//gux*sx1 + guo = t1*tilesizx[globalpicnum]*yp1
|
||||||
if (globalorientation&4) { t0 = 1.f-t0; t1 = 1.f-t1; }
|
if (globalorientation&4) { t0 = 1.f-t0; t1 = 1.f-t1; }
|
||||||
|
|
||||||
|
//sprite panning
|
||||||
|
t0 -= ((float)(spriteext[spritenum].xpanning)/255.f);
|
||||||
|
t1 -= ((float)(spriteext[spritenum].xpanning)/255.f);
|
||||||
gux = (t0*ryp0 - t1*ryp1)*gxyaspect*(float)tilesizx[globalpicnum] / (sx0-sx1);
|
gux = (t0*ryp0 - t1*ryp1)*gxyaspect*(float)tilesizx[globalpicnum] / (sx0-sx1);
|
||||||
guy = 0;
|
guy = 0;
|
||||||
guo = t0*ryp0*gxyaspect*(float)tilesizx[globalpicnum] - gux*sx0;
|
guo = t0*ryp0*gxyaspect*(float)tilesizx[globalpicnum] - gux*sx0;
|
||||||
|
@ -4540,6 +4577,11 @@ void polymost_drawsprite(int snum)
|
||||||
gvo = -gvx*sx0 - gvy*sf0;
|
gvo = -gvx*sx0 - gvy*sf0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// sprite panning
|
||||||
|
gvx -= gdx*((float)(spriteext[spritenum].ypanning)/255.f)*tilesizy[globalpicnum];
|
||||||
|
gvy -= gdy*((float)(spriteext[spritenum].ypanning)/255.f)*tilesizy[globalpicnum];
|
||||||
|
gvo -= gdo*((float)(spriteext[spritenum].ypanning)/255.f)*tilesizy[globalpicnum];
|
||||||
|
|
||||||
//Clip sprites to ceilings/floors when no parallaxing
|
//Clip sprites to ceilings/floors when no parallaxing
|
||||||
if (!(sector[tspr->sectnum].ceilingstat&1))
|
if (!(sector[tspr->sectnum].ceilingstat&1))
|
||||||
{
|
{
|
||||||
|
@ -4571,7 +4613,23 @@ void polymost_drawsprite(int snum)
|
||||||
px[1] = sx1; py[1] = sc1;
|
px[1] = sx1; py[1] = sc1;
|
||||||
px[2] = sx1; py[2] = sf1;
|
px[2] = sx1; py[2] = sf1;
|
||||||
px[3] = sx0; py[3] = sf0;
|
px[3] = sx0; py[3] = sf0;
|
||||||
|
|
||||||
|
#ifdef USE_OPENGL
|
||||||
|
if (spriteext[spritenum].xpanning)
|
||||||
|
srepeat = 1;
|
||||||
|
if (spriteext[spritenum].ypanning)
|
||||||
|
trepeat = 1;
|
||||||
|
#endif
|
||||||
|
|
||||||
pow2xsplit = 0; drawpoly(px,py,4,method);
|
pow2xsplit = 0; drawpoly(px,py,4,method);
|
||||||
|
|
||||||
|
#ifdef USE_OPENGL
|
||||||
|
if (spriteext[spritenum].xpanning)
|
||||||
|
srepeat = 0;
|
||||||
|
if (spriteext[spritenum].ypanning)
|
||||||
|
trepeat = 0;
|
||||||
|
#endif
|
||||||
|
|
||||||
break;
|
break;
|
||||||
case 2: //Floor sprite
|
case 2: //Floor sprite
|
||||||
|
|
||||||
|
@ -4661,7 +4719,28 @@ void polymost_drawsprite(int snum)
|
||||||
guo = ((float)tilesizx[globalpicnum])*gdo - guo;
|
guo = ((float)tilesizx[globalpicnum])*gdo - guo;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// sprite panning
|
||||||
|
guy -= gdy*((float)(spriteext[spritenum].xpanning)/255.f)*tilesizx[globalpicnum];
|
||||||
|
guo -= gdo*((float)(spriteext[spritenum].xpanning)/255.f)*tilesizx[globalpicnum];
|
||||||
|
gvy -= gdy*((float)(spriteext[spritenum].ypanning)/255.f)*tilesizy[globalpicnum];
|
||||||
|
gvo -= gdo*((float)(spriteext[spritenum].ypanning)/255.f)*tilesizy[globalpicnum];
|
||||||
|
|
||||||
|
#ifdef USE_OPENGL
|
||||||
|
if (spriteext[spritenum].xpanning)
|
||||||
|
srepeat = 1;
|
||||||
|
if (spriteext[spritenum].ypanning)
|
||||||
|
trepeat = 1;
|
||||||
|
#endif
|
||||||
|
|
||||||
pow2xsplit = 0; drawpoly(px,py,npoints,method);
|
pow2xsplit = 0; drawpoly(px,py,npoints,method);
|
||||||
|
|
||||||
|
#ifdef USE_OPENGL
|
||||||
|
if (spriteext[spritenum].xpanning)
|
||||||
|
srepeat = 0;
|
||||||
|
if (spriteext[spritenum].ypanning)
|
||||||
|
trepeat = 0;
|
||||||
|
#endif
|
||||||
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 3: //Voxel sprite
|
case 3: //Voxel sprite
|
||||||
|
|
|
@ -549,6 +549,8 @@ LABELS actorlabels[]=
|
||||||
{ "mdyoff", ACTOR_MDYOFF, 0, 0 },
|
{ "mdyoff", ACTOR_MDYOFF, 0, 0 },
|
||||||
{ "mdzoff", ACTOR_MDZOFF, 0, 0 },
|
{ "mdzoff", ACTOR_MDZOFF, 0, 0 },
|
||||||
{ "mdflags", ACTOR_MDFLAGS, 0, 0 },
|
{ "mdflags", ACTOR_MDFLAGS, 0, 0 },
|
||||||
|
{ "xpanning", ACTOR_XPANNING, 0, 0 },
|
||||||
|
{ "ypanning", ACTOR_YPANNING, 0, 0 },
|
||||||
{ "", -1, 0, 0 } // END OF LIST
|
{ "", -1, 0, 0 } // END OF LIST
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -434,7 +434,9 @@ enum actorlabels
|
||||||
ACTOR_MDXOFF,
|
ACTOR_MDXOFF,
|
||||||
ACTOR_MDYOFF,
|
ACTOR_MDYOFF,
|
||||||
ACTOR_MDZOFF,
|
ACTOR_MDZOFF,
|
||||||
ACTOR_MDFLAGS
|
ACTOR_MDFLAGS,
|
||||||
|
ACTOR_XPANNING,
|
||||||
|
ACTOR_YPANNING
|
||||||
};
|
};
|
||||||
|
|
||||||
enum inputlabels
|
enum inputlabels
|
||||||
|
|
|
@ -2732,6 +2732,20 @@ static void DoActor(int iSet, int lVar1, int lLabelID, int lVar2, int lParm2)
|
||||||
SetGameVarID(lVar2,spriteext[iActor].flags, g_i, g_p);
|
SetGameVarID(lVar2,spriteext[iActor].flags, g_i, g_p);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case ACTOR_XPANNING:
|
||||||
|
if (iSet)
|
||||||
|
spriteext[iActor].xpanning=lValue;
|
||||||
|
else
|
||||||
|
SetGameVarID(lVar2, spriteext[iActor].xpanning,g_i,g_p);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case ACTOR_YPANNING:
|
||||||
|
if (iSet)
|
||||||
|
spriteext[iActor].ypanning=lValue;
|
||||||
|
else
|
||||||
|
SetGameVarID(lVar2, spriteext[iActor].ypanning,g_i,g_p);
|
||||||
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue