mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-26 00:40:56 +00:00
More core stuff. There's a bug somewhere but I can't seem to find it at the moment. I'll debug it when it's not 5AM.
git-svn-id: https://svn.eduke32.com/eduke32@641 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
dd4a7b5450
commit
9fc846754f
1 changed files with 99 additions and 25 deletions
|
@ -573,6 +573,7 @@ void PR_CALLBACK polymer_tessvertex(void* vertex, void* sector)
|
||||||
s->ceilindices[s->curindice] = (int)vertex;
|
s->ceilindices[s->curindice] = (int)vertex;
|
||||||
s->curindice++;
|
s->curindice++;
|
||||||
}
|
}
|
||||||
|
|
||||||
int polymer_buildfloor(short sectnum)
|
int polymer_buildfloor(short sectnum)
|
||||||
{
|
{
|
||||||
// This function tesselates the floor/ceiling of a sector and stores the triangles in a display list.
|
// This function tesselates the floor/ceiling of a sector and stores the triangles in a display list.
|
||||||
|
@ -1039,8 +1040,8 @@ void polymer_portaltofrustum(GLfloat* portal, int portalpointcoun
|
||||||
}
|
}
|
||||||
|
|
||||||
//near
|
//near
|
||||||
memcpy(&triangle[3], &portal[(i-2) * 3], sizeof(GLfloat) * 3);
|
//memcpy(&triangle[3], &portal[(i-2) * 3], sizeof(GLfloat) * 3);
|
||||||
polymer_triangletoplane(triangle, &frustum[i*4]);
|
//polymer_triangletoplane(triangle, &frustum[i*4]);
|
||||||
}
|
}
|
||||||
|
|
||||||
void polymer_triangletoplane(GLfloat* triangle, GLfloat* plane)
|
void polymer_triangletoplane(GLfloat* triangle, GLfloat* plane)
|
||||||
|
@ -1059,6 +1060,7 @@ void polymer_triangletoplane(GLfloat* triangle, GLfloat* plane)
|
||||||
|
|
||||||
plane[3] = -(plane[0] * triangle[0] + plane[1] * triangle[1] + plane[2] * triangle[2]);
|
plane[3] = -(plane[0] * triangle[0] + plane[1] * triangle[1] + plane[2] * triangle[2]);
|
||||||
}
|
}
|
||||||
|
|
||||||
void polymer_crossproduct(GLfloat* in_a, GLfloat* in_b, GLfloat* out)
|
void polymer_crossproduct(GLfloat* in_a, GLfloat* in_b, GLfloat* out)
|
||||||
{
|
{
|
||||||
out[0] = in_a[1] * in_b[2] - in_a[2] * in_b[1];
|
out[0] = in_a[1] * in_b[2] - in_a[2] * in_b[1];
|
||||||
|
@ -1102,7 +1104,7 @@ void polymer_extractfrustum(GLdouble* modelview, GLdouble* projec
|
||||||
|
|
||||||
void polymer_drawroom(short sectnum)
|
void polymer_drawroom(short sectnum)
|
||||||
{
|
{
|
||||||
int i, j;
|
int i, j, secwallcount, curwallcount, walclips;
|
||||||
sectortype *sec;
|
sectortype *sec;
|
||||||
walltype *wal;
|
walltype *wal;
|
||||||
|
|
||||||
|
@ -1111,30 +1113,95 @@ void polymer_drawroom(short sectnum)
|
||||||
sec = §or[sectnum];
|
sec = §or[sectnum];
|
||||||
wal = &wall[sec->wallptr];
|
wal = &wall[sec->wallptr];
|
||||||
|
|
||||||
|
secwallcount = sec->wallnum;
|
||||||
|
|
||||||
// first draw the sector
|
// first draw the sector
|
||||||
polymer_drawsector(sectnum);
|
polymer_drawsector(sectnum);
|
||||||
prsectors[sectnum]->drawingstate = 1;
|
prsectors[sectnum]->drawingstate = 1;
|
||||||
|
|
||||||
i = 0;
|
i = 0;
|
||||||
while (i < sec->wallnum)
|
while (i < secwallcount)
|
||||||
{
|
{
|
||||||
if ((prwalls[sec->wallptr + i]->drawn == 0) && (wallvisible(sec->wallptr + i)) && (j = polymer_portalinfrustum(sec->wallptr + i)))
|
walclips = 0;
|
||||||
|
curwallcount = 1;
|
||||||
|
|
||||||
|
if ((prwalls[sec->wallptr + i]->drawn == 0) &&
|
||||||
|
(wallvisible(sec->wallptr + i)) &&
|
||||||
|
(walclips |= polymer_portalinfrustum(sec->wallptr + i)))
|
||||||
{
|
{
|
||||||
prwalls[sec->wallptr + i]->drawn = 1;
|
if ((wal->nextsector != -1) && (prsectors[wal->nextsector]->drawingstate == 0))
|
||||||
|
{
|
||||||
|
// check for contigous walls with the same nextsector
|
||||||
|
if ((i == 0) &&
|
||||||
|
(wal->nextsector == wall[sec->wallptr + secwallcount - 1].nextsector) &&
|
||||||
|
(prwalls[sec->wallptr + secwallcount - 1]->drawn == 0) &&
|
||||||
|
(wallvisible(sec->wallptr + secwallcount - 1)) &&
|
||||||
|
(walclips |= polymer_portalinfrustum(sec->wallptr + secwallcount - 1)))
|
||||||
|
{
|
||||||
|
j = secwallcount - 2;
|
||||||
|
while ((j > 1) &&
|
||||||
|
(wall[sec->wallptr + j].nextsector == wal->nextsector) &&
|
||||||
|
(prwalls[sec->wallptr + j]->drawn == 0) &&
|
||||||
|
(wallvisible(sec->wallptr + j)) &&
|
||||||
|
(walclips |= polymer_portalinfrustum(sec->wallptr + j)))
|
||||||
|
j--;
|
||||||
|
secwallcount = i = j + 1;
|
||||||
|
curwallcount += sec->wallnum - secwallcount;
|
||||||
|
}
|
||||||
|
j = i + 1;
|
||||||
|
while ((wall[sec->wallptr + j].nextsector == wal->nextsector) &&
|
||||||
|
(prwalls[sec->wallptr + j]->drawn == 0) &&
|
||||||
|
(wallvisible(sec->wallptr + j)) &&
|
||||||
|
(walclips |= polymer_portalinfrustum(sec->wallptr + j)))
|
||||||
|
j++;
|
||||||
|
curwallcount += j - i - 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
j = 0;
|
||||||
|
while (j < curwallcount)
|
||||||
|
{
|
||||||
|
prwalls[sec->wallptr + ((i + j) % sec->wallnum)]->drawn = 1;
|
||||||
|
j++;
|
||||||
|
}
|
||||||
|
|
||||||
if ((wal->nextsector != -1) && (prsectors[wal->nextsector]->drawingstate == 0))
|
if ((wal->nextsector != -1) && (prsectors[wal->nextsector]->drawingstate == 0))
|
||||||
{
|
{
|
||||||
if (j > 1)
|
clippedportalpointcount = 4 + ((curwallcount - 1) * 2);
|
||||||
{
|
|
||||||
// the wall intersected at least one plane and needs to be clipped
|
// generate the portal from all the walls
|
||||||
clippedportalpointcount = polymer_cliptofrustum(sec->wallptr + i);
|
if (curwallcount == 1)
|
||||||
}
|
memcpy(clippedportalpoints, prwalls[sec->wallptr + i]->portal, sizeof(float) * 4 * 3);
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
clippedportalpointcount = 4;
|
if (clippedportalpointcount > maxclippedportalpointcount)
|
||||||
memcpy(clippedportalpoints, prwalls[sec->wallptr + i]->portal, sizeof(float) * clippedportalpointcount * 3);
|
{
|
||||||
|
clippedportalpoints = realloc(clippedportalpoints, sizeof(GLfloat) * 3 * clippedportalpointcount);
|
||||||
|
distances = realloc(distances, sizeof(float) * clippedportalpointcount);
|
||||||
|
maxclippedportalpointcount = clippedportalpointcount;
|
||||||
|
}
|
||||||
|
|
||||||
|
j = 0;
|
||||||
|
while (j < curwallcount)
|
||||||
|
{
|
||||||
|
memcpy(&clippedportalpoints[j * 3],
|
||||||
|
&prwalls[sec->wallptr + ((i + j) % sec->wallnum)]->portal[0],
|
||||||
|
sizeof(GLfloat) * 3);
|
||||||
|
memcpy(&clippedportalpoints[(clippedportalpointcount - j - 1) * 3],
|
||||||
|
&prwalls[sec->wallptr + ((i + j) % sec->wallnum)]->portal[9],
|
||||||
|
sizeof(GLfloat) * 3);
|
||||||
|
j++;
|
||||||
|
}
|
||||||
|
memcpy(&clippedportalpoints[j * 3],
|
||||||
|
&prwalls[sec->wallptr + ((i + j - 1) % sec->wallnum)]->portal[3],
|
||||||
|
sizeof(GLfloat) * 3);
|
||||||
|
memcpy(&clippedportalpoints[(clippedportalpointcount - j - 1) * 3],
|
||||||
|
&prwalls[sec->wallptr + ((i + j - 1) % sec->wallnum)]->portal[6],
|
||||||
|
sizeof(GLfloat) * 3);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (walclips > 1) // the wall intersected at least one plane and needs to be clipped
|
||||||
|
clippedportalpointcount = polymer_cliptofrustum(sec->wallptr + i);
|
||||||
|
|
||||||
if (pr_showportals)
|
if (pr_showportals)
|
||||||
{
|
{
|
||||||
bglDisable(GL_FOG);
|
bglDisable(GL_FOG);
|
||||||
|
@ -1154,7 +1221,7 @@ void polymer_drawroom(short sectnum)
|
||||||
|
|
||||||
if (frustumstacksize <= (frustumstackposition + (frustumsizes[frustumdepth] + clippedportalpointcount + 1) * 4))
|
if (frustumstacksize <= (frustumstackposition + (frustumsizes[frustumdepth] + clippedportalpointcount + 1) * 4))
|
||||||
{
|
{
|
||||||
frustumstacksize += (clippedportalpointcount + 1) * 4; // don't forget the near plane
|
frustumstacksize += clippedportalpointcount * 4;
|
||||||
frustumstack = realloc(frustumstack, sizeof(GLfloat) * frustumstacksize);
|
frustumstack = realloc(frustumstack, sizeof(GLfloat) * frustumstacksize);
|
||||||
}
|
}
|
||||||
if (maxfrustumcount == (frustumdepth + 1))
|
if (maxfrustumcount == (frustumdepth + 1))
|
||||||
|
@ -1166,7 +1233,7 @@ void polymer_drawroom(short sectnum)
|
||||||
// push a new frustum on the stack
|
// push a new frustum on the stack
|
||||||
frustumstackposition += frustumsizes[frustumdepth] * 4;
|
frustumstackposition += frustumsizes[frustumdepth] * 4;
|
||||||
frustumdepth++;
|
frustumdepth++;
|
||||||
frustumsizes[frustumdepth] = (clippedportalpointcount + 1); // don't forget the near plane
|
frustumsizes[frustumdepth] = clippedportalpointcount;
|
||||||
|
|
||||||
// calculate the new frustum data
|
// calculate the new frustum data
|
||||||
polymer_portaltofrustum(clippedportalpoints, clippedportalpointcount, pos, &frustumstack[frustumstackposition]);
|
polymer_portaltofrustum(clippedportalpoints, clippedportalpointcount, pos, &frustumstack[frustumstackposition]);
|
||||||
|
@ -1198,11 +1265,18 @@ void polymer_drawroom(short sectnum)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
polymer_drawwall(sec->wallptr + i);
|
j = 0;
|
||||||
|
while (j < curwallcount)
|
||||||
prwalls[sec->wallptr + i]->drawn = 0;
|
{
|
||||||
|
polymer_drawwall(sec->wallptr + ((i + j) % sec->wallnum));
|
||||||
|
prwalls[sec->wallptr + ((i + j) % sec->wallnum)]->drawn = 0;
|
||||||
|
j++;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
i++;
|
i += curwallcount;
|
||||||
|
if (i > sec->wallnum)
|
||||||
|
i = i % sec->wallnum;
|
||||||
|
|
||||||
wal = &wall[sec->wallptr + i];
|
wal = &wall[sec->wallptr + i];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1229,14 +1303,13 @@ int polymer_portalinfrustum(short wallnum)
|
||||||
frustum[(i * 4) + 2] * w->portal[(j * 3) + 2] +
|
frustum[(i * 4) + 2] * w->portal[(j * 3) + 2] +
|
||||||
frustum[(i * 4) + 3];
|
frustum[(i * 4) + 3];
|
||||||
if (sqdist < 0)
|
if (sqdist < 0)
|
||||||
{
|
|
||||||
k++;
|
k++;
|
||||||
result |= 2<<j;
|
|
||||||
}
|
|
||||||
j++;
|
j++;
|
||||||
}
|
}
|
||||||
if (k == 4)
|
if (k == 4)
|
||||||
return (0); // OUT !
|
return (0); // OUT !
|
||||||
|
if (k != 0)
|
||||||
|
result |= 2<<i;
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1256,6 +1329,7 @@ float polymer_pointdistancetoplane(GLfloat* point, GLfloat* plane)
|
||||||
|
|
||||||
return (result);
|
return (result);
|
||||||
}
|
}
|
||||||
|
|
||||||
float polymer_pointdistancetopoint(GLfloat* point1, GLfloat* point2)
|
float polymer_pointdistancetopoint(GLfloat* point1, GLfloat* point2)
|
||||||
{
|
{
|
||||||
return ((point2[0] - point1[0]) * (point2[0] - point1[0]) +
|
return ((point2[0] - point1[0]) * (point2[0] - point1[0]) +
|
||||||
|
@ -1286,9 +1360,9 @@ int polymer_cliptofrustum(short wallnum)
|
||||||
exitpoint = 0; // annoying "warning: 'exitpoint' may be used uninialized in this function"
|
exitpoint = 0; // annoying "warning: 'exitpoint' may be used uninialized in this function"
|
||||||
|
|
||||||
frustum = &frustumstack[frustumstackposition];
|
frustum = &frustumstack[frustumstackposition];
|
||||||
result = 4; // 4 points to start with
|
result = clippedportalpointcount; // 4 points to start with
|
||||||
if (pr_verbosity >= 3) OSD_Printf("PR : Clipping wall %d...\n", wallnum);
|
if (pr_verbosity >= 3) OSD_Printf("PR : Clipping wall %d...\n", wallnum);
|
||||||
memcpy(clippedportalpoints, prwalls[wallnum]->portal, sizeof(GLfloat) * 3 * 4);
|
//memcpy(clippedportalpoints, prwalls[wallnum]->portal, sizeof(GLfloat) * 3 * 4);
|
||||||
|
|
||||||
i = 0;
|
i = 0;
|
||||||
while (i < frustumsizes[frustumdepth])
|
while (i < frustumsizes[frustumdepth])
|
||||||
|
|
Loading…
Reference in a new issue