Render targets, FBO mirrors with normal displacement, fix for masked walls with animated walls, various cleanups.

git-svn-id: https://svn.eduke32.com/eduke32@1255 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
plagman 2009-03-23 14:18:20 +00:00
parent 8d372e5b66
commit b5c4b521f7
4 changed files with 297 additions and 163 deletions

View file

@ -49,6 +49,7 @@ typedef enum {
PR_BIT_DIFFUSE_MAP, PR_BIT_DIFFUSE_MAP,
PR_BIT_DIFFUSE_DETAIL_MAP, PR_BIT_DIFFUSE_DETAIL_MAP,
PR_BIT_DIFFUSE_MODULATION, PR_BIT_DIFFUSE_MODULATION,
PR_BIT_DIFFUSE_MIRROR_MAP,
PR_BIT_DIFFUSE_GLOW_MAP, PR_BIT_DIFFUSE_GLOW_MAP,
PR_BIT_POINT_LIGHT, PR_BIT_POINT_LIGHT,
PR_BIT_FOOTER, // must be just before last PR_BIT_FOOTER, // must be just before last
@ -70,6 +71,8 @@ typedef struct s_prmaterial {
GLfloat detailscale[2]; GLfloat detailscale[2];
// PR_BIT_DIFFUSE_MODULATION // PR_BIT_DIFFUSE_MODULATION
GLfloat diffusemodulation[4]; GLfloat diffusemodulation[4];
// PR_BIT_DIFFUSE_MIRROR_MAP
GLuint mirrormap;
// PR_BIT_DIFFUSE_GLOW_MAP // PR_BIT_DIFFUSE_GLOW_MAP
GLuint glowmap; GLuint glowmap;
} _prmaterial; } _prmaterial;
@ -91,6 +94,8 @@ typedef struct s_prrograminfo {
// PR_BIT_DIFFUSE_DETAIL_MAP // PR_BIT_DIFFUSE_DETAIL_MAP
GLint uniform_detailMap; GLint uniform_detailMap;
GLint uniform_detailScale; GLint uniform_detailScale;
// PR_BIT_DIFFUSE_MIRROR_MAP
GLint uniform_mirrorMap;
// PR_BIT_DIFFUSE_GLOW_MAP // PR_BIT_DIFFUSE_GLOW_MAP
GLint uniform_glowMap; GLint uniform_glowMap;
// PR_BIT_POINT_LIGHT // PR_BIT_POINT_LIGHT
@ -126,6 +131,13 @@ typedef struct s_prlight {
prlighttype type; prlighttype type;
} _prlight; } _prlight;
// RENDER TARGETS
typedef struct s_prrt {
GLuint color;
GLuint z;
GLuint fbo;
} _prrt;
// BUILD DATA // BUILD DATA
typedef struct s_prplane { typedef struct s_prplane {
// geometry // geometry
@ -140,6 +152,7 @@ typedef struct s_prplane {
_prmaterial material; _prmaterial material;
// elements // elements
GLushort* indices; GLushort* indices;
int32_t indicescount;
GLuint ivbo; GLuint ivbo;
// lights // lights
char lights[PR_MAXLIGHTS]; char lights[PR_MAXLIGHTS];
@ -192,6 +205,12 @@ typedef struct s_prwall {
char controlstate; char controlstate;
} _prwall; } _prwall;
typedef struct s_prmirror {
_prplane *plane;
int16_t sectnum;
int16_t wallnum;
} _prmirror;
typedef void (*animatespritesptr)(int32_t, int32_t, int32_t, int32_t); typedef void (*animatespritesptr)(int32_t, int32_t, int32_t, int32_t);
typedef struct s_pranimatespritesinfo { typedef struct s_pranimatespritesinfo {
@ -221,7 +240,7 @@ void polymer_addlight(_prlight light);
// CORE // CORE
static void polymer_displayrooms(int16_t sectnum); static void polymer_displayrooms(int16_t sectnum);
static void polymer_drawplane(int16_t sectnum, int16_t wallnum, _prplane* plane, int32_t indicecount); static void polymer_drawplane(_prplane* plane);
static void polymer_inb4mirror(GLfloat* buffer, GLfloat* plane); static void polymer_inb4mirror(GLfloat* buffer, GLfloat* plane);
static void polymer_animatesprites(void); static void polymer_animatesprites(void);
// SECTORS // SECTORS
@ -264,6 +283,8 @@ static void polymer_compileprogram(int32_t programbits);
// LIGHTS // LIGHTS
static int32_t polymer_planeinlight(_prplane* plane, _prlight* light); static int32_t polymer_planeinlight(_prplane* plane, _prlight* light);
static void polymer_culllight(char lightindex); static void polymer_culllight(char lightindex);
// RENDER TARGETS
static void polymer_initrendertargets(int32_t count);
# endif // !POLYMER_C # endif // !POLYMER_C

View file

@ -130,11 +130,13 @@ _prprogrambit prprogrambits[PR_BIT_COUNT] = {
1 << PR_BIT_HEADER, 1 << PR_BIT_HEADER,
// vert_def // vert_def
"#version 120\n" "#version 120\n"
"#extension GL_ARB_texture_rectangle : enable\n"
"\n", "\n",
// vert_prog // vert_prog
"", "",
// frag_def // frag_def
"#version 120\n" "#version 120\n"
"#extension GL_ARB_texture_rectangle : enable\n"
"\n", "\n",
// frag_prog // frag_prog
"", "",
@ -248,6 +250,27 @@ _prprogrambit prprogrambits[PR_BIT_COUNT] = {
" result *= vec4(gl_Color);\n" " result *= vec4(gl_Color);\n"
"\n", "\n",
}, },
{
1 << PR_BIT_DIFFUSE_MIRROR_MAP,
// vert_def
"",
// vert_prog
"",
// frag_def
"uniform sampler2DRect mirrorMap;\n"
"\n",
// frag_prog
" vec4 mirrorTexel;\n"
" vec2 mirrorCoords;\n"
"\n"
" mirrorCoords = gl_FragCoord.st;\n"
" if (isNormalMapped == 1) {\n"
" mirrorCoords += 100.0 * (normalTexel.rg - 0.5);\n"
" }\n"
" mirrorTexel = texture2DRect(mirrorMap, mirrorCoords);\n"
" result = vec4((result.rgb * result.a) + (mirrorTexel.rgb * (1.0 - result.a)), result.a);\n"
"\n",
},
{ {
1 << PR_BIT_DIFFUSE_GLOW_MAP, 1 << PR_BIT_DIFFUSE_GLOW_MAP,
// vert_def // vert_def
@ -372,6 +395,9 @@ _prprograminfo prprograms[1 << PR_BIT_COUNT];
int32_t overridematerial; int32_t overridematerial;
// RENDER TARGETS
_prrt *prrts;
// CONTROL // CONTROL
GLfloat spritemodelview[16]; GLfloat spritemodelview[16];
GLfloat rootmodelviewmatrix[16]; GLfloat rootmodelviewmatrix[16];
@ -383,7 +409,7 @@ float horizang;
int32_t updatesectors = 1; int32_t updatesectors = 1;
int32_t depth; int32_t depth;
int32_t mirrorfrom[10]; // -3: no mirror; -2: floor; -1: ceiling; >=0: wallnum _prmirror mirrors[10];
GLUtesselator* prtess; GLUtesselator* prtess;
@ -436,6 +462,8 @@ int32_t polymer_init(void)
overridematerial = 0xFFFFFFFF; overridematerial = 0xFFFFFFFF;
polymer_initrendertargets(5);
if (pr_verbosity >= 1) OSD_Printf("PR : Initialization complete.\n"); if (pr_verbosity >= 1) OSD_Printf("PR : Initialization complete.\n");
return (1); return (1);
} }
@ -457,6 +485,9 @@ void polymer_glinit(void)
bglEnable(GL_DEPTH_TEST); bglEnable(GL_DEPTH_TEST);
bglDepthFunc(GL_LEQUAL); bglDepthFunc(GL_LEQUAL);
bglDisable(GL_BLEND);
bglDisable(GL_ALPHA_TEST);
if (pr_wireframe) if (pr_wireframe)
bglPolygonMode(GL_FRONT_AND_BACK, GL_LINE); bglPolygonMode(GL_FRONT_AND_BACK, GL_LINE);
else else
@ -600,7 +631,6 @@ void polymer_drawrooms(int32_t daposx, int32_t daposy, int32_t da
// GO! // GO!
depth = 0; depth = 0;
mirrorfrom[0] = -3; // no mirror
polymer_displayrooms(dacursectnum); polymer_displayrooms(dacursectnum);
curmodelviewmatrix = rootmodelviewmatrix; curmodelviewmatrix = rootmodelviewmatrix;
@ -664,7 +694,11 @@ void polymer_drawmaskwall(int32_t damaskwallcnt)
w = prwalls[maskwall[damaskwallcnt]]; w = prwalls[maskwall[damaskwallcnt]];
polymer_drawplane(-1, -3, &w->mask, 0); bglEnable(GL_CULL_FACE);
polymer_drawplane(&w->mask);
bglDisable(GL_CULL_FACE);
} }
void polymer_drawsprite(int32_t snum) void polymer_drawsprite(int32_t snum)
@ -821,7 +855,7 @@ void polymer_drawsprite(int32_t snum)
// bglEnable(GL_POLYGON_OFFSET_FILL); // bglEnable(GL_POLYGON_OFFSET_FILL);
polymer_drawplane(-1, -3, &spriteplane, 0); polymer_drawplane(&spriteplane);
// bglDisable(GL_POLYGON_OFFSET_FILL); // bglDisable(GL_POLYGON_OFFSET_FILL);
@ -904,6 +938,11 @@ static void polymer_displayrooms(int16_t dacursectnum)
int32_t localspritesortcnt; int32_t localspritesortcnt;
spritetype localtsprite[MAXSPRITESONSCREEN]; spritetype localtsprite[MAXSPRITESONSCREEN];
int16_t localmaskwall[MAXWALLSB], localmaskwallcnt; int16_t localmaskwall[MAXWALLSB], localmaskwallcnt;
_prmirror mirrorlist[10];
int mirrorcount;
int32_t gx, gy, gz, px, py, pz;
GLdouble plane[4];
float coeff;
if (depth) if (depth)
{ {
@ -926,8 +965,10 @@ static void polymer_displayrooms(int16_t dacursectnum)
localspritesortcnt = localmaskwallcnt = 0; localspritesortcnt = localmaskwallcnt = 0;
mirrorcount = 0;
// depth-only occlusion testing pass // depth-only occlusion testing pass
overridematerial = 0; // overridematerial = 0;
while (front != back) while (front != back)
{ {
@ -937,6 +978,14 @@ static void polymer_displayrooms(int16_t dacursectnum)
polymer_drawsector(sectorqueue[front]); polymer_drawsector(sectorqueue[front]);
polymer_scansprites(sectorqueue[front], localtsprite, &localspritesortcnt); polymer_scansprites(sectorqueue[front], localtsprite, &localspritesortcnt);
// if (!depth && sectorqueue[front] == dacursectnum)
// {
// mirrorlist[mirrorcount].plane = &prsectors[sectorqueue[front]]->floor;
// mirrorlist[mirrorcount].sectnum = sectorqueue[front];
// mirrorlist[mirrorcount].wallnum = -1;
// mirrorcount++;
// }
doquery = 0; doquery = 0;
i = 0; i = 0;
@ -960,6 +1009,19 @@ static void polymer_displayrooms(int16_t dacursectnum)
(wallvisible(sec->wallptr + i)) && (wallvisible(sec->wallptr + i)) &&
(polymer_portalinfrustum(sec->wallptr + i, frustum))) (polymer_portalinfrustum(sec->wallptr + i, frustum)))
{ {
if (wall[sec->wallptr + i].cstat & 48)
localmaskwall[localmaskwallcnt++] = sec->wallptr + i;
if (!depth &&
wall[sec->wallptr + i].overpicnum == 560 &&
wall[sec->wallptr + i].cstat & 64)
{
mirrorlist[mirrorcount].plane = &prwalls[sec->wallptr + i]->wall;
mirrorlist[mirrorcount].sectnum = sectorqueue[front];
mirrorlist[mirrorcount].wallnum = sec->wallptr + i;
mirrorcount++;
}
if (doquery) if (doquery)
{ {
bglColorMask(GL_FALSE, GL_FALSE, GL_FALSE, GL_FALSE); bglColorMask(GL_FALSE, GL_FALSE, GL_FALSE, GL_FALSE);
@ -968,7 +1030,11 @@ static void polymer_displayrooms(int16_t dacursectnum)
bglGenQueriesARB(1, &queryid[sec->wallptr + i]); bglGenQueriesARB(1, &queryid[sec->wallptr + i]);
bglBeginQueryARB(GL_SAMPLES_PASSED_ARB, queryid[sec->wallptr + i]); bglBeginQueryARB(GL_SAMPLES_PASSED_ARB, queryid[sec->wallptr + i]);
polymer_drawplane(-1, -3, &prwalls[sec->wallptr + i]->mask, 0); overridematerial = 0;
polymer_drawplane(&prwalls[sec->wallptr + i]->mask);
overridematerial = 0xFFFFFFFF;
bglEndQueryARB(GL_SAMPLES_PASSED_ARB); bglEndQueryARB(GL_SAMPLES_PASSED_ARB);
@ -1012,25 +1078,103 @@ static void polymer_displayrooms(int16_t dacursectnum)
} }
// do the actual shaded drawing // do the actual shaded drawing
overridematerial = 0xFFFFFFFF; // overridematerial = 0xFFFFFFFF;
// go through the sector queue again // go through the sector queue again
front = 0; // front = 0;
while (front < back) // while (front < back)
// {
// sec = &sector[sectorqueue[front]];
//
// polymer_drawsector(sectorqueue[front]);
//
// i = 0;
// while (i < sec->wallnum)
// {
// polymer_drawwall(sectorqueue[front], sec->wallptr + i);
//
// i++;
// }
//
// front++;
// }
i = 0;
while (i < mirrorcount)
{ {
sec = &sector[sectorqueue[front]]; bglBindFramebufferEXT(GL_FRAMEBUFFER_EXT, prrts[0].fbo);
bglPushAttrib(GL_VIEWPORT_BIT);
bglViewport(0, 0, xdim, ydim);
polymer_drawsector(sectorqueue[front]); bglClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
i = 0; bglMatrixMode(GL_MODELVIEW);
while (i < sec->wallnum) bglPushMatrix();
{
polymer_drawwall(sectorqueue[front], sec->wallptr + i);
i++; plane[0] = mirrorlist[i].plane->plane[0];
} plane[1] = mirrorlist[i].plane->plane[1];
plane[2] = mirrorlist[i].plane->plane[2];
plane[3] = mirrorlist[i].plane->plane[3];
front++; bglClipPlane(GL_CLIP_PLANE0, plane);
polymer_inb4mirror(mirrorlist[i].plane->buffer, mirrorlist[i].plane->plane);
bglCullFace(GL_FRONT);
bglEnable(GL_CLIP_PLANE0);
if (mirrorlist[i].wallnum >= 0)
preparemirror(globalposx, globalposy, 0, globalang, 0,
mirrorlist[i].wallnum, 0, &gx, &gy, &viewangle);
gx = globalposx;
gy = globalposy;
gz = globalposz;
// map the player pos from build to polymer
px = globalposy;
py = -globalposz / 16;
pz = -globalposx;
// calculate new player position on the other side of the mirror
// this way the basic build visibility shit can be used (wallvisible)
coeff = mirrorlist[i].plane->plane[0] * px +
mirrorlist[i].plane->plane[1] * py +
mirrorlist[i].plane->plane[2] * pz +
mirrorlist[i].plane->plane[3];
coeff /= (float)(mirrorlist[i].plane->plane[0] * mirrorlist[i].plane->plane[0] +
mirrorlist[i].plane->plane[1] * mirrorlist[i].plane->plane[1] +
mirrorlist[i].plane->plane[2] * mirrorlist[i].plane->plane[2]);
px = -coeff*mirrorlist[i].plane->plane[0]*2 + px;
py = -coeff*mirrorlist[i].plane->plane[1]*2 + py;
pz = -coeff*mirrorlist[i].plane->plane[2]*2 + pz;
// map back from polymer to build
globalposx = -pz;
globalposy = px;
globalposz = -py * 16;
mirrors[depth++] = mirrorlist[i];
polymer_displayrooms(mirrorlist[i].sectnum);
depth--;
globalposx = gx;
globalposy = gy;
globalposz = gz;
bglDisable(GL_CLIP_PLANE0);
bglCullFace(GL_BACK);
bglMatrixMode(GL_MODELVIEW);
bglPopMatrix();
bglPopAttrib();
bglBindFramebufferEXT(GL_FRAMEBUFFER_EXT, 0);
mirrorlist[i].plane->material.mirrormap = prrts[0].color;
polymer_drawplane(mirrorlist[i].plane);
mirrorlist[i].plane->material.mirrormap = 0;
i++;
} }
spritesortcnt = localspritesortcnt; spritesortcnt = localspritesortcnt;
@ -1038,6 +1182,23 @@ static void polymer_displayrooms(int16_t dacursectnum)
maskwallcnt = localmaskwallcnt; maskwallcnt = localmaskwallcnt;
memcpy(maskwall, localmaskwall, sizeof(int16_t) * MAXWALLSB); memcpy(maskwall, localmaskwall, sizeof(int16_t) * MAXWALLSB);
if (depth)
{
// drawmasks needs these
cosglobalang = sintable[(viewangle+512)&2047];
singlobalang = sintable[viewangle&2047];
cosviewingrangeglobalang = mulscale16(cosglobalang,viewingrange);
sinviewingrangeglobalang = mulscale16(singlobalang,viewingrange);
display_mirror = 1;
polymer_animatesprites();
display_mirror = 0;
bglDisable(GL_CULL_FACE);
drawmasks();
bglEnable(GL_CULL_FACE);
}
return; return;
} }
@ -1050,7 +1211,7 @@ static void polymer_displayrooms(int16_t dacursectnum)
else \ else \
{ \ { \
bglBindBufferARB(GL_ELEMENT_ARRAY_BUFFER_ARB, plane->ivbo); \ bglBindBufferARB(GL_ELEMENT_ARRAY_BUFFER_ARB, plane->ivbo); \
bglDrawElements(GL_TRIANGLES, indicecount, GL_UNSIGNED_SHORT, NULL); \ bglDrawElements(GL_TRIANGLES, plane->indicescount, GL_UNSIGNED_SHORT, NULL); \
} \ } \
bglBindBufferARB(GL_ARRAY_BUFFER_ARB, 0); \ bglBindBufferARB(GL_ARRAY_BUFFER_ARB, 0); \
bglBindBufferARB(GL_ELEMENT_ARRAY_BUFFER_ARB, 0) bglBindBufferARB(GL_ELEMENT_ARRAY_BUFFER_ARB, 0)
@ -1061,132 +1222,12 @@ static void polymer_displayrooms(int16_t dacursectnum)
if (!plane->indices) \ if (!plane->indices) \
bglDrawArrays(GL_QUADS, 0, 4); \ bglDrawArrays(GL_QUADS, 0, 4); \
else \ else \
bglDrawElements(GL_TRIANGLES, indicecount, GL_UNSIGNED_SHORT, plane->indices) bglDrawElements(GL_TRIANGLES, plane->indicescount, GL_UNSIGNED_SHORT, plane->indices)
static void polymer_drawplane(int16_t sectnum, int16_t wallnum, _prplane* plane, int32_t indicecount) static void polymer_drawplane(_prplane* plane)
{ {
int32_t materialbits; int32_t materialbits;
// if ((depth < 1) && (plane != NULL) &&
// (wallnum >= 0) && (wall[wallnum].overpicnum == 560)) // insert mirror condition here
// {
// int32_t gx, gy, gz, px, py, pz;
// float coeff;
//
// // set the stencil to 1 and clear the area to black where the sector floor is
// bglDisable(GL_TEXTURE_2D);
// bglDisable(GL_FOG);
// bglColor4f(0.0f, 1.0f, 0.0f, 1.0f);
// bglDepthMask(GL_FALSE);
//
// bglEnable(GL_STENCIL_TEST);
// bglStencilOp(GL_KEEP, GL_KEEP, GL_INCR);
// bglStencilFunc(GL_EQUAL, 0, 0xffffffff);
//
// if (plane->vbo && (pr_vbos > 0))
// {
// OMGDRAWSHITVBO;
// }
// else
// {
// OMGDRAWSHIT;
// }
//
// bglDepthMask(GL_TRUE);
//
// // set the depth to 1 where we put the stencil by drawing a screen aligned quad
// bglStencilFunc(GL_EQUAL, 1, 0xffffffff);
// bglStencilOp(GL_KEEP, GL_KEEP, GL_KEEP);
// bglDepthFunc(GL_ALWAYS);
// bglMatrixMode(GL_PROJECTION);
// bglPushMatrix();
// bglLoadIdentity();
// bglMatrixMode(GL_MODELVIEW);
// bglPushMatrix();
// bglLoadIdentity();
//
// bglColor4f(0.0f, 0.0f, 0.0f, 1.0f);
// bglBegin(GL_QUADS);
// bglVertex3f(-1.0f, -1.0f, 1.0f);
// bglVertex3f(1.0f, -1.0f, 1.0f);
// bglVertex3f(1.0f, 1.0f, 1.0f);
// bglVertex3f(-1.0f, 1.0f, 1.0f);
// bglEnd();
//
// bglMatrixMode(GL_PROJECTION);
// bglPopMatrix();
// bglMatrixMode(GL_MODELVIEW);
// bglPopMatrix();
// bglDepthFunc(GL_LEQUAL);
// bglEnable(GL_TEXTURE_2D);
// bglEnable(GL_FOG);
// // finally draw the shit
// bglPushMatrix();
// bglClipPlane(GL_CLIP_PLANE0, plane->plane);
// polymer_inb4mirror(plane->buffer, plane->plane);
// bglCullFace(GL_FRONT);
// bglEnable(GL_CLIP_PLANE0);
//
// if (wallnum >= 0)
// preparemirror(globalposx, globalposy, 0, globalang,
// 0, wallnum, 0, &gx, &gy, &viewangle);
//
// gx = globalposx;
// gy = globalposy;
// gz = globalposz;
//
// // map the player pos from build to polymer
// px = globalposy;
// py = -globalposz / 16;
// pz = -globalposx;
//
// // calculate new player position on the other side of the mirror
// // this way the basic build visibility shit can be used (wallvisible)
// coeff = -plane->plane[0] * px +
// -plane->plane[1] * py +
// -plane->plane[2] * pz +
// -plane->plane[3];
//
// coeff /= (float)(plane->plane[0] * plane->plane[0] +
// plane->plane[1] * plane->plane[1] +
// plane->plane[2] * plane->plane[2]);
//
// px = coeff*plane->plane[0]*2 + px;
// py = coeff*plane->plane[1]*2 + py;
// pz = coeff*plane->plane[2]*2 + pz;
//
// // map back from polymer to build
// globalposx = -pz;
// globalposy = px;
// globalposz = -py * 16;
//
// depth++;
// mirrorfrom[depth] = wallnum;
// polymer_displayrooms(sectnum);
// depth--;
//
// globalposx = gx;
// globalposy = gy;
// globalposz = gz;
//
// bglDisable(GL_CLIP_PLANE0);
// bglCullFace(GL_BACK);
// bglMatrixMode(GL_MODELVIEW);
// bglPopMatrix();
//
// bglColor4f(plane->material.diffusemodulation[0],
// plane->material.diffusemodulation[1],
// plane->material.diffusemodulation[2],
// 0.0f);
// }
// else
// bglColor4f(plane->material.diffusemodulation[0],
// plane->material.diffusemodulation[1],
// plane->material.diffusemodulation[2],
// plane->material.diffusemodulation[3]);
// bglBindTexture(GL_TEXTURE_2D, plane->material.diffusemap);
// debug code for drawing plane inverse TBN // debug code for drawing plane inverse TBN
// bglDisable(GL_TEXTURE_2D); // bglDisable(GL_TEXTURE_2D);
// bglBegin(GL_LINES); // bglBegin(GL_LINES);
@ -1255,13 +1296,6 @@ static void polymer_drawplane(int16_t sectnum, int16_t wallnum, _prplane
curlight++; curlight++;
} }
// if ((depth < 1) && (plane->plane != NULL) &&
// (wallnum >= 0) && (wall[wallnum].overpicnum == 560)) // insert mirror condition here
// {
// bglDisable(GL_STENCIL_TEST);
// bglClear(GL_STENCIL_BUFFER_BIT);
// }
} }
static void polymer_inb4mirror(GLfloat* buffer, GLfloat* plane) static void polymer_inb4mirror(GLfloat* buffer, GLfloat* plane)
@ -1671,6 +1705,7 @@ static int32_t polymer_buildfloor(int16_t sectnum)
i++; i++;
} }
s->floor.indicescount = s->ceil.indicescount = s->indicescount;
if (pr_verbosity >= 2) OSD_Printf("PR : Tesselated floor of sector %i.\n", sectnum); if (pr_verbosity >= 2) OSD_Printf("PR : Tesselated floor of sector %i.\n", sectnum);
@ -1687,10 +1722,10 @@ static void polymer_drawsector(int16_t sectnum)
sec = &sector[sectnum]; sec = &sector[sectnum];
s = prsectors[sectnum]; s = prsectors[sectnum];
if (!(sec->floorstat & 1) && (mirrorfrom[depth] != -2)) if (!(sec->floorstat & 1))
polymer_drawplane(sectnum, -2, &s->floor, s->indicescount); polymer_drawplane(&s->floor);
if (!(sec->ceilingstat & 1) && (mirrorfrom[depth] != -1)) if (!(sec->ceilingstat & 1))
polymer_drawplane(sectnum, -1, &s->ceil, s->indicescount); polymer_drawplane(&s->ceil);
if (pr_verbosity >= 3) OSD_Printf("PR : Finished drawing sector %i...\n", sectnum); if (pr_verbosity >= 3) OSD_Printf("PR : Finished drawing sector %i...\n", sectnum);
} }
@ -1852,7 +1887,10 @@ static void polymer_updatewall(int16_t wallnum)
memcpy(&w->wall.buffer[10], &s->ceil.buffer[(wal->point2 - sec->wallptr) * 5], sizeof(GLfloat) * 3); memcpy(&w->wall.buffer[10], &s->ceil.buffer[(wal->point2 - sec->wallptr) * 5], sizeof(GLfloat) * 3);
memcpy(&w->wall.buffer[15], &s->ceil.buffer[(wallnum - sec->wallptr) * 5], sizeof(GLfloat) * 3); memcpy(&w->wall.buffer[15], &s->ceil.buffer[(wallnum - sec->wallptr) * 5], sizeof(GLfloat) * 3);
curpicnum = wallpicnum; if (wal->cstat & 32)
curpicnum = walloverpicnum;
else
curpicnum = wallpicnum;
polymer_getbuildmaterial(&w->wall.material, curpicnum, wal->pal, wal->shade); polymer_getbuildmaterial(&w->wall.material, curpicnum, wal->pal, wal->shade);
@ -2007,7 +2045,7 @@ static void polymer_updatewall(int16_t wallnum)
if (wal->cstat & 16) if (wal->cstat & 16)
{ {
// mask // mask
polymer_getbuildmaterial(&w->mask.material, wal->overpicnum, wal->pal, wal->shade); polymer_getbuildmaterial(&w->mask.material, walloverpicnum, wal->pal, wal->shade);
if (wal->cstat & 128) if (wal->cstat & 128)
{ {
if (wal->cstat & 512) if (wal->cstat & 512)
@ -2065,7 +2103,7 @@ static void polymer_updatewall(int16_t wallnum)
else else
yref = max(sec->ceilingz, nsec->ceilingz); yref = max(sec->ceilingz, nsec->ceilingz);
curpicnum = wal->overpicnum; curpicnum = walloverpicnum;
if (wal->ypanning) if (wal->ypanning)
{ {
@ -2120,8 +2158,7 @@ static void polymer_updatewall(int16_t wallnum)
polymer_buffertoplane(w->wall.buffer, NULL, 4, w->wall.plane, w->wall.t, w->wall.b, w->wall.n); polymer_buffertoplane(w->wall.buffer, NULL, 4, w->wall.plane, w->wall.t, w->wall.b, w->wall.n);
if (w->underover & 2) if (w->underover & 2)
polymer_buffertoplane(w->over.buffer, NULL, 4, w->over.plane, w->over.t, w->over.b, w->over.n); polymer_buffertoplane(w->over.buffer, NULL, 4, w->over.plane, w->over.t, w->over.b, w->over.n);
if (!((wal->nextsector == -1) || (wal->cstat & 32))) polymer_buffertoplane(w->mask.buffer, NULL, 4, w->mask.plane, w->mask.t, w->mask.b, w->mask.n);
polymer_buffertoplane(w->mask.buffer, NULL, 4, w->mask.plane, w->mask.t, w->mask.b, w->mask.n);
if ((pr_vbos > 0)) if ((pr_vbos > 0))
{ {
@ -2152,12 +2189,12 @@ static void polymer_drawwall(int16_t sectnum, int16_t wallnum)
if ((w->underover & 1) && !(w->underover & 4)) if ((w->underover & 1) && !(w->underover & 4))
{ {
polymer_drawplane(sectnum, wallnum, &w->wall, 0); polymer_drawplane(&w->wall);
} }
if ((w->underover & 2) && !(w->underover & 8)) if ((w->underover & 2) && !(w->underover & 8))
{ {
polymer_drawplane(sectnum, wallnum, &w->over, 0); polymer_drawplane(&w->over);
} }
if ((sector[sectnum].ceilingstat & 1) && if ((sector[sectnum].ceilingstat & 1) &&
@ -2219,7 +2256,7 @@ static void polymer_buffertoplane(GLfloat* buffer, GLushort* indices, in
plane[0] /= norm; plane[0] /= norm;
plane[1] /= norm; plane[1] /= norm;
plane[2] /= norm; plane[2] /= norm;
plane[3] = (plane[0] * buffer[0] + plane[1] * buffer[1] + plane[2] * buffer[2]); plane[3] = -(plane[0] * buffer[0] + plane[1] * buffer[1] + plane[2] * buffer[2]);
// calculate T and B // calculate T and B
r = 1.0 / (vec1[3] * vec2[4] - vec2[3] * vec1[4]); r = 1.0 / (vec1[3] * vec2[4] - vec2[3] * vec1[4]);
@ -2702,7 +2739,7 @@ static void polymer_drawmdsprite(spritetype *tspr)
lpos[1] = -prlights[i].z / 16.0f; lpos[1] = -prlights[i].z / 16.0f;
lpos[2] = -prlights[i].x; lpos[2] = -prlights[i].x;
polymer_transformpoint(lpos, tlpos, rootmodelviewmatrix); polymer_transformpoint(lpos, tlpos, curmodelviewmatrix);
vec[0] = tlpos[0] - tspos[0]; vec[0] = tlpos[0] - tspos[0];
vec[0] *= vec[0]; vec[0] *= vec[0];
@ -2891,6 +2928,8 @@ static void polymer_getscratchmaterial(_prmaterial* material)
material->diffusemodulation[1] = material->diffusemodulation[1] =
material->diffusemodulation[2] = material->diffusemodulation[2] =
material->diffusemodulation[3] = 1.0f; material->diffusemodulation[3] = 1.0f;
// PR_BIT_DIFFUSE_MIRROR_MAP
material->mirrormap = 0;
// PR_BIT_DIFFUSE_GLOW_MAP // PR_BIT_DIFFUSE_GLOW_MAP
material->glowmap = 0; material->glowmap = 0;
} }
@ -3010,6 +3049,10 @@ static int32_t polymer_bindmaterial(_prmaterial material, char* lights, int
// PR_BIT_DIFFUSE_MODULATION // PR_BIT_DIFFUSE_MODULATION
programbits |= prprogrambits[PR_BIT_DIFFUSE_MODULATION].bit; programbits |= prprogrambits[PR_BIT_DIFFUSE_MODULATION].bit;
// PR_BIT_DIFFUSE_MIRROR_MAP
if (!curlight && material.mirrormap)
programbits |= prprogrambits[PR_BIT_DIFFUSE_MIRROR_MAP].bit;
// PR_BIT_DIFFUSE_GLOW_MAP // PR_BIT_DIFFUSE_GLOW_MAP
if (!curlight && material.glowmap) if (!curlight && material.glowmap)
programbits |= prprogrambits[PR_BIT_DIFFUSE_GLOW_MAP].bit; programbits |= prprogrambits[PR_BIT_DIFFUSE_GLOW_MAP].bit;
@ -3102,6 +3145,17 @@ static int32_t polymer_bindmaterial(_prmaterial material, char* lights, int
material.diffusemodulation[3]); material.diffusemodulation[3]);
} }
// PR_BIT_DIFFUSE_MIRROR_MAP
if (programbits & prprogrambits[PR_BIT_DIFFUSE_MIRROR_MAP].bit)
{
bglActiveTextureARB(texunit + GL_TEXTURE0_ARB);
bglBindTexture(GL_TEXTURE_RECTANGLE, material.mirrormap);
bglUniform1iARB(prprograms[programbits].uniform_mirrorMap, texunit);
texunit++;
}
// PR_BIT_DIFFUSE_GLOW_MAP // PR_BIT_DIFFUSE_GLOW_MAP
if (programbits & prprogrambits[PR_BIT_DIFFUSE_GLOW_MAP].bit) if (programbits & prprogrambits[PR_BIT_DIFFUSE_GLOW_MAP].bit)
{ {
@ -3124,7 +3178,7 @@ static int32_t polymer_bindmaterial(_prmaterial material, char* lights, int
inpos[1] = -prlights[lights[curlight]].z / 16.0f; inpos[1] = -prlights[lights[curlight]].z / 16.0f;
inpos[2] = -prlights[lights[curlight]].x; inpos[2] = -prlights[lights[curlight]].x;
polymer_transformpoint(inpos, pos, rootmodelviewmatrix); polymer_transformpoint(inpos, pos, curmodelviewmatrix);
range[0] = prlights[lights[curlight]].faderange / 1000.0f; range[0] = prlights[lights[curlight]].faderange / 1000.0f;
range[1] = prlights[lights[curlight]].range / 1000.0f; range[1] = prlights[lights[curlight]].range / 1000.0f;
@ -3270,6 +3324,12 @@ static void polymer_compileprogram(int32_t programbits)
prprograms[programbits].uniform_detailScale = bglGetUniformLocationARB(program, "detailScale"); prprograms[programbits].uniform_detailScale = bglGetUniformLocationARB(program, "detailScale");
} }
// PR_BIT_DIFFUSE_MIRROR_MAP
if (programbits & prprogrambits[PR_BIT_DIFFUSE_MIRROR_MAP].bit)
{
prprograms[programbits].uniform_mirrorMap = bglGetUniformLocationARB(program, "mirrorMap");
}
// PR_BIT_DIFFUSE_GLOW_MAP // PR_BIT_DIFFUSE_GLOW_MAP
if (programbits & prprogrambits[PR_BIT_DIFFUSE_GLOW_MAP].bit) if (programbits & prprogrambits[PR_BIT_DIFFUSE_GLOW_MAP].bit)
{ {
@ -3381,4 +3441,53 @@ static void polymer_culllight(char lightindex)
} }
} }
// RENDER TARGETS
static void polymer_initrendertargets(int32_t count)
{
int32_t i;
prrts = calloc(count, sizeof(_prrt));
i = 0;
while (i < count)
{
bglGenTextures(1, &prrts[i].color);
bglBindTexture(GL_TEXTURE_RECTANGLE, prrts[i].color);
bglCopyTexImage2D(GL_TEXTURE_RECTANGLE, 0, GL_RGBA, 0, 0, xdim, ydim, 0);
bglTexParameteri(GL_TEXTURE_RECTANGLE, GL_TEXTURE_MIN_FILTER, GL_NEAREST);
bglTexParameteri(GL_TEXTURE_RECTANGLE, GL_TEXTURE_MAG_FILTER, GL_NEAREST);
bglTexParameteri(GL_TEXTURE_RECTANGLE, GL_TEXTURE_WRAP_S, GL_CLAMP);
bglTexParameteri(GL_TEXTURE_RECTANGLE, GL_TEXTURE_WRAP_T, GL_CLAMP);
bglGenTextures(1, &prrts[i].z);
bglBindTexture(GL_TEXTURE_RECTANGLE, prrts[i].z);
bglCopyTexImage2D(GL_TEXTURE_RECTANGLE, 0, GL_DEPTH_COMPONENT, 0, 0, xdim, ydim, 0);
bglTexParameteri(GL_TEXTURE_RECTANGLE, GL_TEXTURE_MIN_FILTER, GL_NEAREST);
bglTexParameteri(GL_TEXTURE_RECTANGLE, GL_TEXTURE_MAG_FILTER, GL_NEAREST);
bglTexParameteri(GL_TEXTURE_RECTANGLE, GL_TEXTURE_WRAP_S, GL_CLAMP);
bglTexParameteri(GL_TEXTURE_RECTANGLE, GL_TEXTURE_WRAP_T, GL_CLAMP);
bglTexParameteri(GL_TEXTURE_RECTANGLE, GL_TEXTURE_COMPARE_MODE_ARB, GL_COMPARE_R_TO_TEXTURE_ARB);
bglTexParameteri(GL_TEXTURE_RECTANGLE, GL_TEXTURE_COMPARE_FUNC_ARB, GL_GREATER);
bglTexParameteri(GL_TEXTURE_RECTANGLE, GL_DEPTH_TEXTURE_MODE_ARB, GL_ALPHA);
bglGenFramebuffersEXT(1, &prrts[i].fbo);
bglBindFramebufferEXT(GL_FRAMEBUFFER_EXT, prrts[i].fbo);
bglFramebufferTexture2DEXT(GL_FRAMEBUFFER_EXT, GL_COLOR_ATTACHMENT0_EXT, GL_TEXTURE_RECTANGLE, prrts[i].color, 0);
bglFramebufferTexture2DEXT(GL_FRAMEBUFFER_EXT, GL_DEPTH_ATTACHMENT_EXT, GL_TEXTURE_RECTANGLE, prrts[i].z, 0);
if (bglCheckFramebufferStatusEXT(GL_FRAMEBUFFER_EXT) != GL_FRAMEBUFFER_COMPLETE_EXT)
{
OSD_Printf("FBO #%d initialization failed.\n", i);
}
bglBindTexture(GL_TEXTURE_RECTANGLE, 0);
bglBindFramebufferEXT(GL_FRAMEBUFFER_EXT, 0);
i++;
}
}
#endif #endif

View file

@ -1358,6 +1358,8 @@ void showframe(int32_t w)
bglVertex2i(-1, 1); bglVertex2i(-1, 1);
bglEnd(); bglEnd();
bglDisable(GL_BLEND);
bglMatrixMode(GL_MODELVIEW); bglMatrixMode(GL_MODELVIEW);
bglPopMatrix(); bglPopMatrix();
bglMatrixMode(GL_PROJECTION); bglMatrixMode(GL_PROJECTION);

View file

@ -2509,6 +2509,8 @@ void showframe(int32_t w)
bglVertex2i(-1, 1); bglVertex2i(-1, 1);
bglEnd(); bglEnd();
bglDisable(GL_BLEND);
bglMatrixMode(GL_MODELVIEW); bglMatrixMode(GL_MODELVIEW);
bglPopMatrix(); bglPopMatrix();
bglMatrixMode(GL_PROJECTION); bglMatrixMode(GL_PROJECTION);