mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-26 00:40:56 +00:00
BUT YOU DONT KNOW HOW.. ?
git-svn-id: https://svn.eduke32.com/eduke32@700 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
7c7b1c6590
commit
7b03cef01a
2 changed files with 18 additions and 12 deletions
|
@ -88,6 +88,7 @@ typedef struct s_prwall {
|
||||||
GLfloat* overbuffer;
|
GLfloat* overbuffer;
|
||||||
GLfloat* portal;
|
GLfloat* portal;
|
||||||
GLfloat* bigportal;
|
GLfloat* bigportal;
|
||||||
|
GLdouble plane[4];
|
||||||
// attributes
|
// attributes
|
||||||
GLfloat wallcolor[4], overcolor[4], maskcolor[4];
|
GLfloat wallcolor[4], overcolor[4], maskcolor[4];
|
||||||
GLuint wallglpic, overglpic, wallfbglpic, overfbglpic, maskglpic;
|
GLuint wallglpic, overglpic, wallfbglpic, overfbglpic, maskglpic;
|
||||||
|
|
|
@ -1644,6 +1644,8 @@ static void polymer_updatewall(short wallnum)
|
||||||
memcpy(&w->bigportal[6], &s->ceilbuffer[(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);
|
memcpy(&w->bigportal[9], &s->ceilbuffer[(wallnum - sec->wallptr) * 5], sizeof(GLfloat) * 3);
|
||||||
|
|
||||||
|
polymer_buffertoplane(w->portal, NULL, w->plane);
|
||||||
|
|
||||||
w->controlstate = 1;
|
w->controlstate = 1;
|
||||||
|
|
||||||
if (pr_verbosity >= 3) OSD_Printf("PR : Updated wall %i.\n", wallnum);
|
if (pr_verbosity >= 3) OSD_Printf("PR : Updated wall %i.\n", wallnum);
|
||||||
|
@ -1660,18 +1662,20 @@ static void polymer_drawwall(short sectnum, short wallnum)
|
||||||
if ((w->underover & 1) && !(w->underover & 4))
|
if ((w->underover & 1) && !(w->underover & 4))
|
||||||
{
|
{
|
||||||
polymer_drawplane(sectnum, wallnum, w->wallglpic, w->wallcolor,
|
polymer_drawplane(sectnum, wallnum, w->wallglpic, w->wallcolor,
|
||||||
w->wallbuffer, NULL, 0, NULL);
|
w->wallbuffer, NULL, 0, w->plane);
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((w->underover & 2) && !(w->underover & 8))
|
if ((w->underover & 2) && !(w->underover & 8))
|
||||||
{
|
{
|
||||||
polymer_drawplane(sectnum, wallnum, w->overglpic, w->overcolor,
|
polymer_drawplane(sectnum, wallnum, w->overglpic, w->overcolor,
|
||||||
w->overbuffer, NULL, 0, NULL);
|
w->overbuffer, NULL, 0, w->plane);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (pr_verbosity >= 3) OSD_Printf("PR : Finished drawing wall %i...\n", wallnum);
|
if (pr_verbosity >= 3) OSD_Printf("PR : Finished drawing wall %i...\n", wallnum);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#define INDICE(n) ((indices) ? (indices[i+n]*5) : ((i+n)*5))
|
||||||
|
|
||||||
// HSR
|
// HSR
|
||||||
static void polymer_buffertoplane(GLfloat* buffer, GLushort* indices, GLdouble* plane)
|
static void polymer_buffertoplane(GLfloat* buffer, GLushort* indices, GLdouble* plane)
|
||||||
{
|
{
|
||||||
|
@ -1680,21 +1684,22 @@ static void polymer_buffertoplane(GLfloat* buffer, GLushort* indices, GL
|
||||||
|
|
||||||
i = 0;
|
i = 0;
|
||||||
do {
|
do {
|
||||||
vec1[0] = buffer[(indices[i+1]*5) + 0] - buffer[(indices[i+0]*5) + 0];
|
vec1[0] = buffer[(INDICE(1)) + 0] - buffer[(INDICE(0)) + 0];
|
||||||
vec1[1] = buffer[(indices[i+1]*5) + 1] - buffer[(indices[i+0]*5) + 1];
|
vec1[1] = buffer[(INDICE(1)) + 1] - buffer[(INDICE(0)) + 1];
|
||||||
vec1[2] = buffer[(indices[i+1]*5) + 2] - buffer[(indices[i+0]*5) + 2];
|
vec1[2] = buffer[(INDICE(1)) + 2] - buffer[(INDICE(0)) + 2];
|
||||||
|
|
||||||
vec2[0] = buffer[(indices[i+2]*5) + 0] - buffer[(indices[i+1]*5) + 0];
|
vec2[0] = buffer[(INDICE(2)) + 0] - buffer[(INDICE(1)) + 0];
|
||||||
vec2[1] = buffer[(indices[i+2]*5) + 1] - buffer[(indices[i+1]*5) + 1];
|
vec2[1] = buffer[(INDICE(2)) + 1] - buffer[(INDICE(1)) + 1];
|
||||||
vec2[2] = buffer[(indices[i+2]*5) + 2] - buffer[(indices[i+1]*5) + 2];
|
vec2[2] = buffer[(INDICE(2)) + 2] - buffer[(INDICE(1)) + 2];
|
||||||
|
|
||||||
polymer_crossproduct(vec2, vec1, plane);
|
polymer_crossproduct(vec2, vec1, plane);
|
||||||
|
|
||||||
// normalize
|
// normalize
|
||||||
vec1[0] = plane[0] * plane[0] + plane[1] * plane[1] + plane[2] * plane[2];
|
vec1[0] = plane[0] * plane[0] + plane[1] * plane[1] + plane[2] * plane[2];
|
||||||
i+= 3;
|
i+= 3;
|
||||||
}
|
}
|
||||||
while (vec1[0] == 0);
|
while (vec1[0] == 0);
|
||||||
|
|
||||||
vec1[0] = sqrt(vec1[0]);
|
vec1[0] = sqrt(vec1[0]);
|
||||||
plane[0] /= vec1[0];
|
plane[0] /= vec1[0];
|
||||||
plane[1] /= vec1[0];
|
plane[1] /= vec1[0];
|
||||||
|
|
Loading…
Reference in a new issue