mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-11 18:50:46 +00:00
One way walls and masks. Masks don't really have correct texture coordinates yet but they should be sorted like polymost is or so.
git-svn-id: https://svn.eduke32.com/eduke32@687 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
1d320f6eec
commit
5c0276882e
4 changed files with 136 additions and 38 deletions
|
@ -25,6 +25,7 @@ extern "C" {
|
||||||
|
|
||||||
#define MAXSECTORS MAXSECTORSV8
|
#define MAXSECTORS MAXSECTORSV8
|
||||||
#define MAXWALLS MAXWALLSV8
|
#define MAXWALLS MAXWALLSV8
|
||||||
|
#define MAXWALLSB ((MAXWALLS>>2)+(MAXWALLS>>3))
|
||||||
#define MAXSPRITES MAXSPRITESV8
|
#define MAXSPRITES MAXSPRITESV8
|
||||||
|
|
||||||
#define MAXTILES 15360
|
#define MAXTILES 15360
|
||||||
|
@ -185,6 +186,8 @@ EXTERN int guniqhudid;
|
||||||
|
|
||||||
EXTERN sectortype *sector;
|
EXTERN sectortype *sector;
|
||||||
EXTERN walltype *wall;
|
EXTERN walltype *wall;
|
||||||
|
EXTERN short maskwall[MAXWALLSB], maskwallcnt;
|
||||||
|
EXTERN short thewall[MAXWALLSB];
|
||||||
EXTERN spritetype *sprite;
|
EXTERN spritetype *sprite;
|
||||||
EXTERN spritetype *tspriteptr[MAXSPRITESONSCREEN];
|
EXTERN spritetype *tspriteptr[MAXSPRITESONSCREEN];
|
||||||
|
|
||||||
|
|
|
@ -7,8 +7,7 @@
|
||||||
// o also sliding doors are still fucked up sometimes (like under the bar in E1L2)
|
// o also sliding doors are still fucked up sometimes (like under the bar in E1L2)
|
||||||
// o port glowmaps and detail maps from hacked polymost (:(
|
// o port glowmaps and detail maps from hacked polymost (:(
|
||||||
// o shading needs a lot of work
|
// o shading needs a lot of work
|
||||||
// o make the portal smaller
|
// o proper mask texture coordinates and color/palette and shit
|
||||||
// o one-way walls and masks
|
|
||||||
// o remove all the IM matrix crap and write real functions now that it works
|
// o remove all the IM matrix crap and write real functions now that it works
|
||||||
// o polymer.c possibly needs to be split in several source files
|
// o polymer.c possibly needs to be split in several source files
|
||||||
// o some crap really needs factorization
|
// o some crap really needs factorization
|
||||||
|
@ -88,9 +87,10 @@ typedef struct s_prwall {
|
||||||
GLfloat* wallbuffer;
|
GLfloat* wallbuffer;
|
||||||
GLfloat* overbuffer;
|
GLfloat* overbuffer;
|
||||||
GLfloat* portal;
|
GLfloat* portal;
|
||||||
|
GLfloat* bigportal;
|
||||||
// attributes
|
// attributes
|
||||||
GLfloat wallcolor[4], overcolor[4];
|
GLfloat wallcolor[4], overcolor[4];
|
||||||
GLfloat wallglpic, overglpic, wallfbglpic, overfbglpic;
|
GLfloat wallglpic, overglpic, wallfbglpic, overfbglpic, maskglpic;
|
||||||
// build wall data# ifdef POLYMER_C
|
// build wall data# ifdef POLYMER_C
|
||||||
|
|
||||||
short cstat, nwallcstat;
|
short cstat, nwallcstat;
|
||||||
|
|
|
@ -38,7 +38,6 @@
|
||||||
#define MAXTILEFILES 256
|
#define MAXTILEFILES 256
|
||||||
#define MAXYSAVES ((MAXXDIM*MAXSPRITES)>>7)
|
#define MAXYSAVES ((MAXXDIM*MAXSPRITES)>>7)
|
||||||
#define MAXNODESPERLINE 42 //Warning: This depends on MAXYSAVES & MAXYDIM!
|
#define MAXNODESPERLINE 42 //Warning: This depends on MAXYSAVES & MAXYDIM!
|
||||||
#define MAXWALLSB ((MAXWALLS>>2)+(MAXWALLS>>3))
|
|
||||||
#define MAXCLIPDIST 1024
|
#define MAXCLIPDIST 1024
|
||||||
|
|
||||||
|
|
||||||
|
@ -558,7 +557,8 @@ inline int getkensmessagecrc(int b)
|
||||||
|
|
||||||
static int xb1[MAXWALLSB], yb1[MAXWALLSB], xb2[MAXWALLSB], yb2[MAXWALLSB];
|
static int xb1[MAXWALLSB], yb1[MAXWALLSB], xb2[MAXWALLSB], yb2[MAXWALLSB];
|
||||||
static int rx1[MAXWALLSB], ry1[MAXWALLSB], rx2[MAXWALLSB], ry2[MAXWALLSB];
|
static int rx1[MAXWALLSB], ry1[MAXWALLSB], rx2[MAXWALLSB], ry2[MAXWALLSB];
|
||||||
static short p2[MAXWALLSB], thesector[MAXWALLSB], thewall[MAXWALLSB];
|
static short p2[MAXWALLSB], thesector[MAXWALLSB];
|
||||||
|
short thewall[MAXWALLSB];
|
||||||
|
|
||||||
static short bunchfirst[MAXWALLSB], bunchlast[MAXWALLSB];
|
static short bunchfirst[MAXWALLSB], bunchlast[MAXWALLSB];
|
||||||
|
|
||||||
|
@ -567,7 +567,7 @@ static short smoststart[MAXWALLSB];
|
||||||
static char smostwalltype[MAXWALLSB];
|
static char smostwalltype[MAXWALLSB];
|
||||||
static int smostwall[MAXWALLSB], smostwallcnt = -1L;
|
static int smostwall[MAXWALLSB], smostwallcnt = -1L;
|
||||||
|
|
||||||
static short maskwall[MAXWALLSB], maskwallcnt;
|
short maskwall[MAXWALLSB], maskwallcnt;
|
||||||
static int spritesx[MAXSPRITESONSCREEN];
|
static int spritesx[MAXSPRITESONSCREEN];
|
||||||
static int spritesy[MAXSPRITESONSCREEN+1];
|
static int spritesy[MAXSPRITESONSCREEN+1];
|
||||||
static int spritesz[MAXSPRITESONSCREEN];
|
static int spritesz[MAXSPRITESONSCREEN];
|
||||||
|
@ -4120,7 +4120,18 @@ static void drawmaskwall(short damaskwallcnt)
|
||||||
//============================================================================= //POLYMOST BEGINS
|
//============================================================================= //POLYMOST BEGINS
|
||||||
#ifdef POLYMOST
|
#ifdef POLYMOST
|
||||||
if (rendmode == 3) { polymost_drawmaskwall(damaskwallcnt); return; }
|
if (rendmode == 3) { polymost_drawmaskwall(damaskwallcnt); return; }
|
||||||
if (rendmode == 4) { polymer_drawmaskwall(damaskwallcnt); return; }
|
if (rendmode == 4)
|
||||||
|
{
|
||||||
|
bglEnable(GL_ALPHA_TEST);
|
||||||
|
bglEnable(GL_BLEND);
|
||||||
|
|
||||||
|
polymer_drawmaskwall(damaskwallcnt);
|
||||||
|
|
||||||
|
bglDisable(GL_BLEND);
|
||||||
|
bglDisable(GL_ALPHA_TEST);
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
//============================================================================= //POLYMOST ENDS
|
//============================================================================= //POLYMOST ENDS
|
||||||
|
|
||||||
|
@ -6237,10 +6248,20 @@ killsprite:
|
||||||
{
|
{
|
||||||
maskwallcnt--;
|
maskwallcnt--;
|
||||||
|
|
||||||
dot.x = wall[thewall[maskwall[maskwallcnt]]].x;
|
if (rendmode == 4)
|
||||||
dot.y = wall[thewall[maskwall[maskwallcnt]]].y;
|
{
|
||||||
dot2.x = wall[wall[thewall[maskwall[maskwallcnt]]].point2].x;
|
dot.x = wall[maskwall[maskwallcnt]].x;
|
||||||
dot2.y = wall[wall[thewall[maskwall[maskwallcnt]]].point2].y;
|
dot.y = wall[maskwall[maskwallcnt]].y;
|
||||||
|
dot2.x = wall[wall[maskwall[maskwallcnt]].point2].x;
|
||||||
|
dot2.y = wall[wall[maskwall[maskwallcnt]].point2].y;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
dot.x = wall[thewall[maskwall[maskwallcnt]]].x;
|
||||||
|
dot.y = wall[thewall[maskwall[maskwallcnt]]].y;
|
||||||
|
dot2.x = wall[wall[thewall[maskwall[maskwallcnt]]].point2].x;
|
||||||
|
dot2.y = wall[wall[thewall[maskwall[maskwallcnt]]].point2].y;
|
||||||
|
}
|
||||||
|
|
||||||
maskeq = equation(dot.x, dot.y, dot2.x, dot2.y);
|
maskeq = equation(dot.x, dot.y, dot2.x, dot2.y);
|
||||||
p1eq = equation(pos.x, pos.y, dot.x, dot.y);
|
p1eq = equation(pos.x, pos.y, dot.x, dot.y);
|
||||||
|
|
|
@ -326,6 +326,10 @@ void polymer_drawrooms(int daposx, int daposy, int daposz, short
|
||||||
(polymer_portalinfrustum(sec->wallptr + i)))
|
(polymer_portalinfrustum(sec->wallptr + i)))
|
||||||
{
|
{
|
||||||
polymer_drawwall(sec->wallptr + i);
|
polymer_drawwall(sec->wallptr + i);
|
||||||
|
// mask
|
||||||
|
if ((wal->cstat&48) == 16) maskwall[maskwallcnt++] = sec->wallptr + i;
|
||||||
|
//thewall[maskwall[maskwallcnt++]] = sec->wallptr + i;
|
||||||
|
|
||||||
if ((wal->nextsector != -1) &&
|
if ((wal->nextsector != -1) &&
|
||||||
(prsectors[wal->nextsector]->drawingstate == 0))
|
(prsectors[wal->nextsector]->drawingstate == 0))
|
||||||
{
|
{
|
||||||
|
@ -352,7 +356,7 @@ void polymer_drawrooms(int daposx, int daposy, int daposz, short
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
querydelay[sectorqueue[front] + 1] = pr_occlusionculling;
|
querydelay[sectorqueue[front] + 1] = pr_occlusionculling-1;
|
||||||
}
|
}
|
||||||
else if ((front >= firstback) && (pr_occlusionculling) && (querydelay[sectorqueue[front] + 1]))
|
else if ((front >= firstback) && (pr_occlusionculling) && (querydelay[sectorqueue[front] + 1]))
|
||||||
querydelay[sectorqueue[front] + 1]--;
|
querydelay[sectorqueue[front] + 1]--;
|
||||||
|
@ -371,6 +375,10 @@ void polymer_drawrooms(int daposx, int daposy, int daposz, short
|
||||||
(polymer_portalinfrustum(sec->wallptr + i)))
|
(polymer_portalinfrustum(sec->wallptr + i)))
|
||||||
{
|
{
|
||||||
polymer_drawwall(sec->wallptr + i);
|
polymer_drawwall(sec->wallptr + i);
|
||||||
|
// mask
|
||||||
|
if ((wal->cstat&48) == 16) maskwall[maskwallcnt++] = sec->wallptr + i;
|
||||||
|
//thewall[maskwall[maskwallcnt++]] = sec->wallptr + i;
|
||||||
|
|
||||||
if ((wal->nextsector != -1) &&
|
if ((wal->nextsector != -1) &&
|
||||||
(prsectors[wal->nextsector]->drawingstate == 0))
|
(prsectors[wal->nextsector]->drawingstate == 0))
|
||||||
{
|
{
|
||||||
|
@ -389,7 +397,6 @@ void polymer_drawrooms(int daposx, int daposy, int daposz, short
|
||||||
bglDepthMask(GL_FALSE);
|
bglDepthMask(GL_FALSE);
|
||||||
|
|
||||||
bglBeginQueryARB(GL_SAMPLES_PASSED_ARB, wal->nextsector + 1);
|
bglBeginQueryARB(GL_SAMPLES_PASSED_ARB, wal->nextsector + 1);
|
||||||
bglBegin(GL_QUADS);
|
|
||||||
|
|
||||||
j = 0;
|
j = 0;
|
||||||
while (j < nextsec->wallnum)
|
while (j < nextsec->wallnum)
|
||||||
|
@ -399,16 +406,13 @@ void polymer_drawrooms(int daposx, int daposy, int daposz, short
|
||||||
(wallvisible(nextwal->nextwall)) &&
|
(wallvisible(nextwal->nextwall)) &&
|
||||||
(polymer_portalinfrustum(nextwal->nextwall))))
|
(polymer_portalinfrustum(nextwal->nextwall))))
|
||||||
{
|
{
|
||||||
bglVertex3fv(&prwalls[nextwal->nextwall]->portal[0]);
|
bglVertexPointer(3, GL_FLOAT, 5 * sizeof(GLfloat), prwalls[nextwal->nextwall]->portal);
|
||||||
bglVertex3fv(&prwalls[nextwal->nextwall]->portal[3]);
|
bglDrawArrays(GL_QUADS, 0, 4);
|
||||||
bglVertex3fv(&prwalls[nextwal->nextwall]->portal[6]);
|
|
||||||
bglVertex3fv(&prwalls[nextwal->nextwall]->portal[9]);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
j++;
|
j++;
|
||||||
nextwal = &wall[nextsec->wallptr + j];
|
nextwal = &wall[nextsec->wallptr + j];
|
||||||
}
|
}
|
||||||
bglEnd();
|
|
||||||
bglEndQueryARB(GL_SAMPLES_PASSED_ARB);
|
bglEndQueryARB(GL_SAMPLES_PASSED_ARB);
|
||||||
|
|
||||||
bglDepthMask(GL_TRUE);
|
bglDepthMask(GL_TRUE);
|
||||||
|
@ -476,7 +480,19 @@ void polymer_rotatesprite(int sx, int sy, int z, short a, short p
|
||||||
|
|
||||||
void polymer_drawmaskwall(int damaskwallcnt)
|
void polymer_drawmaskwall(int damaskwallcnt)
|
||||||
{
|
{
|
||||||
OSD_Printf("PR : Masked wall %i...\n", damaskwallcnt);
|
_prwall *w;
|
||||||
|
|
||||||
|
if (pr_verbosity >= 3) OSD_Printf("PR : Masked wall %i...\n", damaskwallcnt);
|
||||||
|
|
||||||
|
w = prwalls[maskwall[damaskwallcnt]];
|
||||||
|
|
||||||
|
bglBindTexture(GL_TEXTURE_2D, w->maskglpic);
|
||||||
|
|
||||||
|
bglColor4f(1.0f, 1.0f, 1.0f, 0.33f);
|
||||||
|
|
||||||
|
bglVertexPointer(3, GL_FLOAT, 5 * sizeof(GLfloat), w->portal);
|
||||||
|
bglTexCoordPointer(2, GL_FLOAT, 5 * sizeof(GLfloat), &w->portal[3]);
|
||||||
|
bglDrawArrays(GL_QUADS, 0, 4);
|
||||||
}
|
}
|
||||||
|
|
||||||
void polymer_drawsprite(int snum)
|
void polymer_drawsprite(int snum)
|
||||||
|
@ -937,7 +953,7 @@ static int polymer_buildfloor(short sectnum)
|
||||||
sectortype *sec;
|
sectortype *sec;
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
if (pr_verbosity >= 2) OSD_Printf("PR : Tesselating floor of sector %i...\n", sectnum);
|
if (pr_verbosity >= 0) OSD_Printf("PR : Tesselating floor of sector %i...\n", sectnum);
|
||||||
|
|
||||||
s = prsectors[sectnum];
|
s = prsectors[sectnum];
|
||||||
sec = §or[sectnum];
|
sec = §or[sectnum];
|
||||||
|
@ -1079,7 +1095,7 @@ static int polymer_initwall(short wallnum)
|
||||||
static void polymer_updatewall(short wallnum)
|
static void polymer_updatewall(short wallnum)
|
||||||
{
|
{
|
||||||
short nwallnum, nnwallnum, curpicnum, wallpicnum, walloverpicnum, nwallpicnum;
|
short nwallnum, nnwallnum, curpicnum, wallpicnum, walloverpicnum, nwallpicnum;
|
||||||
char curxpanning, curypanning;
|
char curxpanning, curypanning, underwall, overwall;
|
||||||
walltype *wal;
|
walltype *wal;
|
||||||
sectortype *sec, *nsec;
|
sectortype *sec, *nsec;
|
||||||
_prwall *w;
|
_prwall *w;
|
||||||
|
@ -1100,6 +1116,7 @@ static void polymer_updatewall(short wallnum)
|
||||||
{
|
{
|
||||||
ns = prsectors[wal->nextsector];
|
ns = prsectors[wal->nextsector];
|
||||||
invalid += ns->invalidid;
|
invalid += ns->invalidid;
|
||||||
|
nsec = §or[wal->nextsector];
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
ns = NULL;
|
ns = NULL;
|
||||||
|
@ -1158,7 +1175,7 @@ static void polymer_updatewall(short wallnum)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
w->underover = 0;
|
w->underover = underwall = overwall = 0;
|
||||||
|
|
||||||
w->wallcolor[0] = w->wallcolor[1] = w->wallcolor[2] = ((float)(numpalookups-min(max(wal->shade,0),numpalookups)))/((float)numpalookups);
|
w->wallcolor[0] = w->wallcolor[1] = w->wallcolor[2] = ((float)(numpalookups-min(max(wal->shade,0),numpalookups)))/((float)numpalookups);
|
||||||
w->wallcolor[3] = 1.0f;
|
w->wallcolor[3] = 1.0f;
|
||||||
|
@ -1168,7 +1185,7 @@ static void polymer_updatewall(short wallnum)
|
||||||
else
|
else
|
||||||
xref = 0;
|
xref = 0;
|
||||||
|
|
||||||
if (wal->nextsector == -1)
|
if ((wal->nextsector == -1) || (wal->cstat & 32))
|
||||||
{
|
{
|
||||||
memcpy(w->wallbuffer, &s->floorbuffer[(wallnum - sec->wallptr) * 5], sizeof(GLfloat) * 3);
|
memcpy(w->wallbuffer, &s->floorbuffer[(wallnum - sec->wallptr) * 5], sizeof(GLfloat) * 3);
|
||||||
memcpy(&w->wallbuffer[5], &s->floorbuffer[(wal->point2 - sec->wallptr) * 5], sizeof(GLfloat) * 3);
|
memcpy(&w->wallbuffer[5], &s->floorbuffer[(wal->point2 - sec->wallptr) * 5], sizeof(GLfloat) * 3);
|
||||||
|
@ -1200,6 +1217,14 @@ static void polymer_updatewall(short wallnum)
|
||||||
else
|
else
|
||||||
yref = sec->ceilingz;
|
yref = sec->ceilingz;
|
||||||
|
|
||||||
|
if ((wal->cstat & 32) && (wal->nextsector != -1))
|
||||||
|
{
|
||||||
|
if ((!(wal->cstat & 2) && (wal->cstat & 4)) || ((wal->cstat & 2) && (wall[nwallnum].cstat & 4)))
|
||||||
|
yref = sec->ceilingz;
|
||||||
|
else
|
||||||
|
yref = nsec->floorz;
|
||||||
|
}
|
||||||
|
|
||||||
if (wal->ypanning)
|
if (wal->ypanning)
|
||||||
{
|
{
|
||||||
ypancoef = (float)(pow2long[picsiz[curpicnum] >> 4]);
|
ypancoef = (float)(pow2long[picsiz[curpicnum] >> 4]);
|
||||||
|
@ -1231,12 +1256,14 @@ static void polymer_updatewall(short wallnum)
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
nnwallnum = wall[nwallnum].point2;
|
nnwallnum = wall[nwallnum].point2;
|
||||||
nsec = §or[wal->nextsector];
|
|
||||||
|
|
||||||
if (((s->floorbuffer[((wallnum - sec->wallptr) * 5) + 1] != ns->floorbuffer[((nnwallnum - nsec->wallptr) * 5) + 1]) ||
|
if (((s->floorbuffer[((wallnum - sec->wallptr) * 5) + 1] != ns->floorbuffer[((nnwallnum - nsec->wallptr) * 5) + 1]) ||
|
||||||
(s->floorbuffer[((wal->point2 - sec->wallptr) * 5) + 1] != ns->floorbuffer[((nwallnum - nsec->wallptr) * 5) + 1])) &&
|
(s->floorbuffer[((wal->point2 - sec->wallptr) * 5) + 1] != ns->floorbuffer[((nwallnum - nsec->wallptr) * 5) + 1])) &&
|
||||||
((s->floorbuffer[((wallnum - sec->wallptr) * 5) + 1] <= ns->floorbuffer[((nnwallnum - nsec->wallptr) * 5) + 1]) ||
|
((s->floorbuffer[((wallnum - sec->wallptr) * 5) + 1] <= ns->floorbuffer[((nnwallnum - nsec->wallptr) * 5) + 1]) ||
|
||||||
(s->floorbuffer[((wal->point2 - sec->wallptr) * 5) + 1] <= ns->floorbuffer[((nwallnum - nsec->wallptr) * 5) + 1])))
|
(s->floorbuffer[((wal->point2 - sec->wallptr) * 5) + 1] <= ns->floorbuffer[((nwallnum - nsec->wallptr) * 5) + 1])))
|
||||||
|
underwall = 1;
|
||||||
|
|
||||||
|
if ((underwall) || (wal->cstat & 16))
|
||||||
{
|
{
|
||||||
memcpy(w->wallbuffer, &s->floorbuffer[(wallnum - sec->wallptr) * 5], sizeof(GLfloat) * 3);
|
memcpy(w->wallbuffer, &s->floorbuffer[(wallnum - sec->wallptr) * 5], sizeof(GLfloat) * 3);
|
||||||
memcpy(&w->wallbuffer[5], &s->floorbuffer[(wal->point2 - sec->wallptr) * 5], sizeof(GLfloat) * 3);
|
memcpy(&w->wallbuffer[5], &s->floorbuffer[(wal->point2 - sec->wallptr) * 5], sizeof(GLfloat) * 3);
|
||||||
|
@ -1305,15 +1332,21 @@ static void polymer_updatewall(short wallnum)
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
|
|
||||||
w->underover |= 1;
|
if (underwall)
|
||||||
if ((sec->floorstat & 1) && (nsec->floorstat & 1))
|
{
|
||||||
w->underover |= 4;
|
w->underover |= 1;
|
||||||
|
if ((sec->floorstat & 1) && (nsec->floorstat & 1))
|
||||||
|
w->underover |= 4;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (((s->ceilbuffer[((wallnum - sec->wallptr) * 5) + 1] != ns->ceilbuffer[((nnwallnum - nsec->wallptr) * 5) + 1]) ||
|
if (((s->ceilbuffer[((wallnum - sec->wallptr) * 5) + 1] != ns->ceilbuffer[((nnwallnum - nsec->wallptr) * 5) + 1]) ||
|
||||||
(s->ceilbuffer[((wal->point2 - sec->wallptr) * 5) + 1] != ns->ceilbuffer[((nwallnum - nsec->wallptr) * 5) + 1])) &&
|
(s->ceilbuffer[((wal->point2 - sec->wallptr) * 5) + 1] != ns->ceilbuffer[((nwallnum - nsec->wallptr) * 5) + 1])) &&
|
||||||
((s->ceilbuffer[((wallnum - sec->wallptr) * 5) + 1] >= ns->ceilbuffer[((nnwallnum - nsec->wallptr) * 5) + 1]) ||
|
((s->ceilbuffer[((wallnum - sec->wallptr) * 5) + 1] >= ns->ceilbuffer[((nnwallnum - nsec->wallptr) * 5) + 1]) ||
|
||||||
(s->ceilbuffer[((wal->point2 - sec->wallptr) * 5) + 1] >= ns->ceilbuffer[((nwallnum - nsec->wallptr) * 5) + 1])))
|
(s->ceilbuffer[((wal->point2 - sec->wallptr) * 5) + 1] >= ns->ceilbuffer[((nwallnum - nsec->wallptr) * 5) + 1])))
|
||||||
|
overwall = 1;
|
||||||
|
|
||||||
|
if ((overwall) || (wal->cstat & 16))
|
||||||
{
|
{
|
||||||
if (w->overbuffer == NULL)
|
if (w->overbuffer == NULL)
|
||||||
w->overbuffer = calloc(4, sizeof(GLfloat) * 5);
|
w->overbuffer = calloc(4, sizeof(GLfloat) * 5);
|
||||||
|
@ -1331,6 +1364,16 @@ static void polymer_updatewall(short wallnum)
|
||||||
if (!waloff[curpicnum])
|
if (!waloff[curpicnum])
|
||||||
loadtile(curpicnum);
|
loadtile(curpicnum);
|
||||||
|
|
||||||
|
if (wal->cstat & 16)
|
||||||
|
{
|
||||||
|
if (!waloff[wal->overpicnum])
|
||||||
|
loadtile(wal->overpicnum);
|
||||||
|
|
||||||
|
pth = gltexcache(wal->overpicnum, wal->pal, 0);
|
||||||
|
w->maskglpic = pth ? pth->glpic : 0;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
pth = gltexcache(curpicnum, wal->pal, 0);
|
pth = gltexcache(curpicnum, wal->pal, 0);
|
||||||
w->overglpic = pth ? pth->glpic : 0;
|
w->overglpic = pth ? pth->glpic : 0;
|
||||||
|
|
||||||
|
@ -1379,19 +1422,50 @@ static void polymer_updatewall(short wallnum)
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
|
|
||||||
w->underover |= 2;
|
if (overwall)
|
||||||
if ((sec->ceilingstat & 1) && (nsec->ceilingstat & 1))
|
{
|
||||||
w->underover |= 8;
|
w->underover |= 2;
|
||||||
|
if ((sec->ceilingstat & 1) && (nsec->ceilingstat & 1))
|
||||||
|
w->underover |= 8;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (w->portal == NULL)
|
if (w->portal == NULL)
|
||||||
w->portal = calloc(4, sizeof(GLfloat) * 3);
|
w->portal = calloc(4, sizeof(GLfloat) * 5);
|
||||||
|
if (w->bigportal == NULL)
|
||||||
|
w->bigportal = calloc(4, sizeof(GLfloat) * 3);
|
||||||
|
|
||||||
memcpy(w->portal, &s->floorbuffer[(wallnum - sec->wallptr) * 5], sizeof(GLfloat) * 3);
|
if ((wal->nextsector == -1) || (wal->cstat & 32))
|
||||||
memcpy(&w->portal[3], &s->floorbuffer[(wal->point2 - sec->wallptr) * 5], sizeof(GLfloat) * 3);
|
memcpy(w->portal, w->wallbuffer, sizeof(GLfloat) * 4 * 5);
|
||||||
memcpy(&w->portal[6], &s->ceilbuffer[(wal->point2 - sec->wallptr) * 5], sizeof(GLfloat) * 3);
|
else
|
||||||
memcpy(&w->portal[9], &s->ceilbuffer[(wallnum - sec->wallptr) * 5], sizeof(GLfloat) * 3);
|
{
|
||||||
|
if ((underwall) || (wal->cstat & 16))
|
||||||
|
{
|
||||||
|
memcpy(w->portal, &w->wallbuffer[15], sizeof(GLfloat) * 5);
|
||||||
|
memcpy(&w->portal[5], &w->wallbuffer[10], sizeof(GLfloat) * 5);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
memcpy(w->portal, &s->floorbuffer[(wallnum - sec->wallptr) * 5], sizeof(GLfloat) * 5);
|
||||||
|
memcpy(&w->portal[5], &s->floorbuffer[(wal->point2 - sec->wallptr) * 5], sizeof(GLfloat) * 5);
|
||||||
|
}
|
||||||
|
if ((overwall) || (wal->cstat & 16))
|
||||||
|
{
|
||||||
|
memcpy(&w->portal[10], &w->overbuffer[5], sizeof(GLfloat) * 5);
|
||||||
|
memcpy(&w->portal[15], &w->overbuffer[0], sizeof(GLfloat) * 5);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
memcpy(&w->portal[10], &s->ceilbuffer[(wal->point2 - sec->wallptr) * 5], sizeof(GLfloat) * 5);
|
||||||
|
memcpy(&w->portal[15], &s->ceilbuffer[(wallnum - sec->wallptr) * 5], sizeof(GLfloat) * 5);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
memcpy(w->bigportal, &s->floorbuffer[(wallnum - sec->wallptr) * 5], sizeof(GLfloat) * 3);
|
||||||
|
memcpy(&w->bigportal[3], &s->floorbuffer[(wal->point2 - sec->wallptr) * 5], sizeof(GLfloat) * 3);
|
||||||
|
memcpy(&w->bigportal[6], &s->ceilbuffer[(wal->point2 - sec->wallptr) * 5], sizeof(GLfloat) * 3);
|
||||||
|
memcpy(&w->bigportal[9], &s->ceilbuffer[(wallnum - sec->wallptr) * 5], sizeof(GLfloat) * 3);
|
||||||
|
|
||||||
w->controlstate = 1;
|
w->controlstate = 1;
|
||||||
|
|
||||||
|
@ -1522,9 +1596,9 @@ static int polymer_portalinfrustum(short wallnum)
|
||||||
j = k = 0;
|
j = k = 0;
|
||||||
while (j < 4)
|
while (j < 4)
|
||||||
{
|
{
|
||||||
sqdist = frustum[(i * 4) + 0] * w->portal[(j * 3) + 0] +
|
sqdist = frustum[(i * 4) + 0] * w->bigportal[(j * 3) + 0] +
|
||||||
frustum[(i * 4) + 1] * w->portal[(j * 3) + 1] +
|
frustum[(i * 4) + 1] * w->bigportal[(j * 3) + 1] +
|
||||||
frustum[(i * 4) + 2] * w->portal[(j * 3) + 2] +
|
frustum[(i * 4) + 2] * w->bigportal[(j * 3) + 2] +
|
||||||
frustum[(i * 4) + 3];
|
frustum[(i * 4) + 3];
|
||||||
if (sqdist < 0)
|
if (sqdist < 0)
|
||||||
k++;
|
k++;
|
||||||
|
|
Loading…
Reference in a new issue