mirror of
https://github.com/ZDoom/raze-gles.git
synced 2024-12-25 11:10:47 +00:00
Polymer: add preliminary support for batching draws.
git-svn-id: https://svn.eduke32.com/eduke32@5296 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
6a6d120d8e
commit
e237dbafea
3 changed files with 185 additions and 20 deletions
|
@ -35,6 +35,7 @@ extern int32_t pr_billboardingmode;
|
||||||
extern int32_t pr_verbosity;
|
extern int32_t pr_verbosity;
|
||||||
extern int32_t pr_wireframe;
|
extern int32_t pr_wireframe;
|
||||||
extern int32_t pr_vbos;
|
extern int32_t pr_vbos;
|
||||||
|
extern int32_t pr_buckets;
|
||||||
extern int32_t pr_gpusmoothing;
|
extern int32_t pr_gpusmoothing;
|
||||||
extern int32_t pr_overrideparallax;
|
extern int32_t pr_overrideparallax;
|
||||||
extern float pr_parallaxscale;
|
extern float pr_parallaxscale;
|
||||||
|
@ -189,6 +190,22 @@ typedef struct s_prprogrambit {
|
||||||
const char* frag_prog;
|
const char* frag_prog;
|
||||||
} _prprogrambit;
|
} _prprogrambit;
|
||||||
|
|
||||||
|
typedef struct s_prbucket {
|
||||||
|
// index
|
||||||
|
int16_t tilenum;
|
||||||
|
char pal;
|
||||||
|
|
||||||
|
_prmaterial material;
|
||||||
|
int32_t invalidmaterial;
|
||||||
|
|
||||||
|
// geom indices
|
||||||
|
GLuint* indices;
|
||||||
|
uint32_t count;
|
||||||
|
uint32_t buffersize;
|
||||||
|
|
||||||
|
struct s_prbucket* next;
|
||||||
|
} _prbucket;
|
||||||
|
|
||||||
#include "prlights.h"
|
#include "prlights.h"
|
||||||
|
|
||||||
// RENDER TARGETS
|
// RENDER TARGETS
|
||||||
|
@ -219,7 +236,8 @@ typedef struct s_prplane {
|
||||||
_prvert* buffer;
|
_prvert* buffer;
|
||||||
int32_t vertcount;
|
int32_t vertcount;
|
||||||
GLuint vbo;
|
GLuint vbo;
|
||||||
int32_t mapvbo_vertoffset;
|
uint32_t mapvbo_vertoffset;
|
||||||
|
_prbucket* bucket;
|
||||||
// attributes
|
// attributes
|
||||||
GLfloat tbn[3][3];
|
GLfloat tbn[3][3];
|
||||||
GLfloat plane[4];
|
GLfloat plane[4];
|
||||||
|
@ -373,6 +391,9 @@ static inline int32_t polymer_eligible_for_artmap(int32_t tilenum, const pthtyp
|
||||||
|
|
||||||
// CORE
|
// CORE
|
||||||
static void polymer_displayrooms(int16_t sectnum);
|
static void polymer_displayrooms(int16_t sectnum);
|
||||||
|
static void polymer_emptybuckets(void);
|
||||||
|
static _prbucket* polymer_findbucket(int16_t tilenum, char pal);
|
||||||
|
static void polymer_bucketplane(_prplane* plane);
|
||||||
static void polymer_drawplane(_prplane* plane);
|
static void polymer_drawplane(_prplane* plane);
|
||||||
static inline void polymer_inb4mirror(_prvert* buffer, GLfloat* plane);
|
static inline void polymer_inb4mirror(_prvert* buffer, GLfloat* plane);
|
||||||
static void polymer_animatesprites(void);
|
static void polymer_animatesprites(void);
|
||||||
|
@ -411,7 +432,7 @@ static void polymer_drawmdsprite(tspritetype *tspr);
|
||||||
static void polymer_loadmodelvbos(md3model_t* m);
|
static void polymer_loadmodelvbos(md3model_t* m);
|
||||||
// MATERIALS
|
// MATERIALS
|
||||||
static void polymer_getscratchmaterial(_prmaterial* material);
|
static void polymer_getscratchmaterial(_prmaterial* material);
|
||||||
static void polymer_getbuildmaterial(_prmaterial* material, int16_t tilenum, char pal, int8_t shade, int8_t vis, int32_t cmeth);
|
static _prbucket* polymer_getbuildmaterial(_prmaterial* material, int16_t tilenum, char pal, int8_t shade, int8_t vis, int32_t cmeth);
|
||||||
static int32_t polymer_bindmaterial(const _prmaterial *material, int16_t* lights, int lightcount);
|
static int32_t polymer_bindmaterial(const _prmaterial *material, int16_t* lights, int lightcount);
|
||||||
static void polymer_unbindmaterial(int32_t programbits);
|
static void polymer_unbindmaterial(int32_t programbits);
|
||||||
static void polymer_compileprogram(int32_t programbits);
|
static void polymer_compileprogram(int32_t programbits);
|
||||||
|
|
|
@ -26,6 +26,7 @@ int32_t pr_billboardingmode = 1;
|
||||||
int32_t pr_verbosity = 1; // 0: silent, 1: errors and one-times, 2: multiple-times, 3: flood
|
int32_t pr_verbosity = 1; // 0: silent, 1: errors and one-times, 2: multiple-times, 3: flood
|
||||||
int32_t pr_wireframe = 0;
|
int32_t pr_wireframe = 0;
|
||||||
int32_t pr_vbos = 2;
|
int32_t pr_vbos = 2;
|
||||||
|
int32_t pr_buckets = 0;
|
||||||
int32_t pr_gpusmoothing = 1;
|
int32_t pr_gpusmoothing = 1;
|
||||||
int32_t pr_overrideparallax = 0;
|
int32_t pr_overrideparallax = 0;
|
||||||
float pr_parallaxscale = 0.1f;
|
float pr_parallaxscale = 0.1f;
|
||||||
|
@ -73,6 +74,9 @@ const GLsizeiptrARB proneplanesize = sizeof(_prvert) * 4;
|
||||||
const GLintptrARB prwalldatasize = sizeof(_prvert)* 4 * 3; // wall, over and mask planes for every wall
|
const GLintptrARB prwalldatasize = sizeof(_prvert)* 4 * 3; // wall, over and mask planes for every wall
|
||||||
GLintptrARB prwalldataoffset;
|
GLintptrARB prwalldataoffset;
|
||||||
|
|
||||||
|
_prbucket *prbuckethead;
|
||||||
|
int32_t prcanbucket;
|
||||||
|
|
||||||
static const _prvert vertsprite[4] =
|
static const _prvert vertsprite[4] =
|
||||||
{
|
{
|
||||||
{
|
{
|
||||||
|
@ -1016,7 +1020,7 @@ void polymer_loadboard(void)
|
||||||
|
|
||||||
bglGenBuffersARB(1, &prmapvbo);
|
bglGenBuffersARB(1, &prmapvbo);
|
||||||
bglBindBufferARB(GL_ARRAY_BUFFER_ARB, prmapvbo);
|
bglBindBufferARB(GL_ARRAY_BUFFER_ARB, prmapvbo);
|
||||||
bglBufferDataARB(GL_ARRAY_BUFFER_ARB, prwalldataoffset + numwalls * prwalldatasize, NULL, mapvbousage);
|
bglBufferDataARB(GL_ARRAY_BUFFER_ARB, prwalldataoffset + (numwalls * prwalldatasize), NULL, mapvbousage);
|
||||||
bglBindBufferARB(GL_ARRAY_BUFFER_ARB, 0);
|
bglBindBufferARB(GL_ARRAY_BUFFER_ARB, 0);
|
||||||
|
|
||||||
i = 0;
|
i = 0;
|
||||||
|
@ -1169,6 +1173,8 @@ void polymer_drawrooms(int32_t daposx, int32_t daposy, int32_t da
|
||||||
(daposz > cursectflorz) ||
|
(daposz > cursectflorz) ||
|
||||||
(daposz < cursectceilz))
|
(daposz < cursectceilz))
|
||||||
{
|
{
|
||||||
|
prcanbucket = 1;
|
||||||
|
|
||||||
if (!editstatus && pr_verbosity>=1)
|
if (!editstatus && pr_verbosity>=1)
|
||||||
{
|
{
|
||||||
if ((unsigned)dacursectnum < (unsigned)numsectors)
|
if ((unsigned)dacursectnum < (unsigned)numsectors)
|
||||||
|
@ -1194,6 +1200,9 @@ void polymer_drawrooms(int32_t daposx, int32_t daposy, int32_t da
|
||||||
polymer_drawwall(sectorofwall(i), i);
|
polymer_drawwall(sectorofwall(i), i);
|
||||||
i--;
|
i--;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
polymer_emptybuckets();
|
||||||
|
|
||||||
viewangle = daang;
|
viewangle = daang;
|
||||||
enddrawing();
|
enddrawing();
|
||||||
return;
|
return;
|
||||||
|
@ -1789,6 +1798,8 @@ static void polymer_displayrooms(const int16_t dacursectnum)
|
||||||
// depth-only occlusion testing pass
|
// depth-only occlusion testing pass
|
||||||
// overridematerial = 0;
|
// overridematerial = 0;
|
||||||
|
|
||||||
|
prcanbucket = 1;
|
||||||
|
|
||||||
while (front != back)
|
while (front != back)
|
||||||
{
|
{
|
||||||
sec = (tsectortype *)§or[sectorqueue[front]];
|
sec = (tsectortype *)§or[sectorqueue[front]];
|
||||||
|
@ -1978,6 +1989,8 @@ static void polymer_displayrooms(const int16_t dacursectnum)
|
||||||
front++;
|
front++;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
polymer_emptybuckets();
|
||||||
|
|
||||||
// do the actual shaded drawing
|
// do the actual shaded drawing
|
||||||
// overridematerial = 0xFFFFFFFF;
|
// overridematerial = 0xFFFFFFFF;
|
||||||
|
|
||||||
|
@ -2102,6 +2115,116 @@ static void polymer_displayrooms(const int16_t dacursectnum)
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void polymer_emptybuckets(void)
|
||||||
|
{
|
||||||
|
_prbucket *bucket = prbuckethead;
|
||||||
|
|
||||||
|
bglBindBufferARB(GL_ARRAY_BUFFER_ARB, prmapvbo);
|
||||||
|
bglVertexPointer(3, GL_FLOAT, sizeof(_prvert), NULL);
|
||||||
|
bglTexCoordPointer(2, GL_FLOAT, sizeof(_prvert), (GLvoid *)(3 * sizeof(GLfloat)));
|
||||||
|
|
||||||
|
while (bucket != NULL)
|
||||||
|
{
|
||||||
|
if (bucket->count == 0)
|
||||||
|
{
|
||||||
|
bucket = bucket->next;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
int32_t materialbits = polymer_bindmaterial(&bucket->material, NULL, 0);
|
||||||
|
|
||||||
|
bglDrawElements(GL_TRIANGLES, bucket->count, GL_UNSIGNED_INT, bucket->indices);
|
||||||
|
|
||||||
|
polymer_unbindmaterial(materialbits);
|
||||||
|
|
||||||
|
bucket->count = 0;
|
||||||
|
|
||||||
|
bucket = bucket->next;
|
||||||
|
}
|
||||||
|
|
||||||
|
bglBindBufferARB(GL_ARRAY_BUFFER_ARB, 0);
|
||||||
|
|
||||||
|
prcanbucket = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static _prbucket* polymer_findbucket(int16_t tilenum, char pal)
|
||||||
|
{
|
||||||
|
_prbucket *bucketptr = prbuckethead;
|
||||||
|
|
||||||
|
// find bucket
|
||||||
|
while (bucketptr != NULL)
|
||||||
|
{
|
||||||
|
if (bucketptr->tilenum == tilenum && bucketptr->pal == pal)
|
||||||
|
break;
|
||||||
|
|
||||||
|
bucketptr = bucketptr->next;
|
||||||
|
}
|
||||||
|
|
||||||
|
// no buckets or no bucket found, create one
|
||||||
|
if (bucketptr == NULL)
|
||||||
|
{
|
||||||
|
bucketptr = (_prbucket *)Xmalloc(sizeof (_prbucket));
|
||||||
|
|
||||||
|
// insert, since most likely to use same pattern next frame
|
||||||
|
// will need to reorder by MRU first every once in a while
|
||||||
|
// or move to hashing lookup
|
||||||
|
bucketptr->next = prbuckethead;
|
||||||
|
prbuckethead = bucketptr;
|
||||||
|
|
||||||
|
bucketptr->tilenum = tilenum;
|
||||||
|
bucketptr->pal = pal;
|
||||||
|
|
||||||
|
bucketptr->invalidmaterial = 1;
|
||||||
|
|
||||||
|
bucketptr->count = 0;
|
||||||
|
bucketptr->buffersize = 1024;
|
||||||
|
bucketptr->indices = (GLuint *)Xmalloc(bucketptr->buffersize * sizeof(GLuint));
|
||||||
|
}
|
||||||
|
|
||||||
|
return bucketptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void polymer_bucketplane(_prplane* plane)
|
||||||
|
{
|
||||||
|
_prbucket *bucketptr = plane->bucket;
|
||||||
|
uint32_t neededindicecount;
|
||||||
|
uint32_t i;
|
||||||
|
|
||||||
|
// we don't keep buffers for quads
|
||||||
|
neededindicecount = (plane->indicescount == 0) ? 6 : plane->indicescount;
|
||||||
|
|
||||||
|
// ensure size
|
||||||
|
while (bucketptr->count + neededindicecount >= bucketptr->buffersize)
|
||||||
|
{
|
||||||
|
bucketptr->buffersize *= 2;
|
||||||
|
bucketptr->indices = (GLuint *)Xrealloc(bucketptr->indices, bucketptr->buffersize * sizeof(GLuint));
|
||||||
|
}
|
||||||
|
|
||||||
|
// queue indices
|
||||||
|
i = 0;
|
||||||
|
|
||||||
|
if (plane->indicescount > 0)
|
||||||
|
{
|
||||||
|
while (i < plane->indicescount)
|
||||||
|
{
|
||||||
|
bucketptr->indices[bucketptr->count] = plane->indices[i] + plane->mapvbo_vertoffset;
|
||||||
|
bucketptr->count++;
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
static const uint32_t quadindices[6] = { 0, 1, 2, 0, 2, 3 };
|
||||||
|
|
||||||
|
while (i < 6)
|
||||||
|
{
|
||||||
|
bucketptr->indices[bucketptr->count] = quadindices[i] + plane->mapvbo_vertoffset;
|
||||||
|
bucketptr->count++;
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
static void polymer_drawplane(_prplane* plane)
|
static void polymer_drawplane(_prplane* plane)
|
||||||
{
|
{
|
||||||
int32_t materialbits;
|
int32_t materialbits;
|
||||||
|
@ -2148,6 +2271,12 @@ static void polymer_drawplane(_prplane* plane)
|
||||||
// bglEnd();
|
// bglEnd();
|
||||||
// bglEnable(GL_TEXTURE_2D);
|
// bglEnable(GL_TEXTURE_2D);
|
||||||
|
|
||||||
|
if (pr_buckets && pr_vbos > 0 && prcanbucket && plane->bucket)
|
||||||
|
{
|
||||||
|
polymer_bucketplane(plane);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
bglNormal3f((float)(plane->plane[0]), (float)(plane->plane[1]), (float)(plane->plane[2]));
|
bglNormal3f((float)(plane->plane[0]), (float)(plane->plane[1]), (float)(plane->plane[2]));
|
||||||
|
|
||||||
GLuint planevbo;
|
GLuint planevbo;
|
||||||
|
@ -2156,7 +2285,7 @@ static void polymer_drawplane(_prplane* plane)
|
||||||
if (plane->mapvbo_vertoffset != -1)
|
if (plane->mapvbo_vertoffset != -1)
|
||||||
{
|
{
|
||||||
planevbo = prmapvbo;
|
planevbo = prmapvbo;
|
||||||
geomfbooffset = plane->mapvbo_vertoffset;
|
geomfbooffset = plane->mapvbo_vertoffset * sizeof(_prvert);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -2587,7 +2716,10 @@ attributes:
|
||||||
bglBufferSubDataARB(GL_ARRAY_BUFFER_ARB, 0, sec->wallnum * sizeof(GLfloat)* 5, s->ceil.buffer);
|
bglBufferSubDataARB(GL_ARRAY_BUFFER_ARB, 0, sec->wallnum * sizeof(GLfloat)* 5, s->ceil.buffer);
|
||||||
*/
|
*/
|
||||||
|
|
||||||
GLintptrARB sector_offset = sec->wallptr * 2 * sizeof(_prvert);
|
s->floor.mapvbo_vertoffset = sec->wallptr * 2;
|
||||||
|
s->ceil.mapvbo_vertoffset = s->floor.mapvbo_vertoffset + sec->wallnum;
|
||||||
|
|
||||||
|
GLintptrARB sector_offset = s->floor.mapvbo_vertoffset * sizeof(_prvert);
|
||||||
GLsizeiptrARB cur_sector_size = sec->wallnum * sizeof(_prvert);
|
GLsizeiptrARB cur_sector_size = sec->wallnum * sizeof(_prvert);
|
||||||
bglBindBufferARB(GL_ARRAY_BUFFER_ARB, prmapvbo);
|
bglBindBufferARB(GL_ARRAY_BUFFER_ARB, prmapvbo);
|
||||||
// floor
|
// floor
|
||||||
|
@ -2595,9 +2727,6 @@ attributes:
|
||||||
// ceiling
|
// ceiling
|
||||||
bglBufferSubDataARB(GL_ARRAY_BUFFER_ARB, sector_offset + cur_sector_size, cur_sector_size, s->ceil.buffer);
|
bglBufferSubDataARB(GL_ARRAY_BUFFER_ARB, sector_offset + cur_sector_size, cur_sector_size, s->ceil.buffer);
|
||||||
bglBindBufferARB(GL_ARRAY_BUFFER_ARB, 0);
|
bglBindBufferARB(GL_ARRAY_BUFFER_ARB, 0);
|
||||||
|
|
||||||
s->floor.mapvbo_vertoffset = sector_offset;
|
|
||||||
s->ceil.mapvbo_vertoffset = sector_offset + cur_sector_size;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -2613,7 +2742,7 @@ attributes:
|
||||||
!Bmemcmp(&s->ceilingstat, &sec->ceilingstat, offsetof(sectortype, visibility) - offsetof(sectortype, ceilingstat)))
|
!Bmemcmp(&s->ceilingstat, &sec->ceilingstat, offsetof(sectortype, visibility) - offsetof(sectortype, ceilingstat)))
|
||||||
goto finish;
|
goto finish;
|
||||||
|
|
||||||
polymer_getbuildmaterial(&s->floor.material, floorpicnum, sec->floorpal, sec->floorshade, sec->visibility, 0);
|
s->floor.bucket = polymer_getbuildmaterial(&s->floor.material, floorpicnum, sec->floorpal, sec->floorshade, sec->visibility, 0);
|
||||||
|
|
||||||
if (sec->floorstat & 256) {
|
if (sec->floorstat & 256) {
|
||||||
if (sec->floorstat & 128) {
|
if (sec->floorstat & 128) {
|
||||||
|
@ -2623,7 +2752,7 @@ attributes:
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
polymer_getbuildmaterial(&s->ceil.material, ceilingpicnum, sec->ceilingpal, sec->ceilingshade, sec->visibility, 0);
|
s->ceil.bucket = polymer_getbuildmaterial(&s->ceil.material, ceilingpicnum, sec->ceilingpal, sec->ceilingshade, sec->visibility, 0);
|
||||||
|
|
||||||
if (sec->ceilingstat & 256) {
|
if (sec->ceilingstat & 256) {
|
||||||
if (sec->ceilingstat & 128) {
|
if (sec->ceilingstat & 128) {
|
||||||
|
@ -3046,7 +3175,7 @@ static void polymer_updatewall(int16_t wallnum)
|
||||||
else
|
else
|
||||||
curpicnum = walloverpicnum;
|
curpicnum = walloverpicnum;
|
||||||
|
|
||||||
polymer_getbuildmaterial(&w->wall.material, curpicnum, wal->pal, wal->shade, sec->visibility, DAMETH_WALL);
|
w->wall.bucket = polymer_getbuildmaterial(&w->wall.material, curpicnum, wal->pal, wal->shade, sec->visibility, DAMETH_WALL);
|
||||||
|
|
||||||
if (wal->cstat & 4)
|
if (wal->cstat & 4)
|
||||||
yref = sec->floorz;
|
yref = sec->floorz;
|
||||||
|
@ -3116,7 +3245,7 @@ static void polymer_updatewall(int16_t wallnum)
|
||||||
curxpanning = wall[refwall].xpanning;
|
curxpanning = wall[refwall].xpanning;
|
||||||
curypanning = wall[refwall].ypanning;
|
curypanning = wall[refwall].ypanning;
|
||||||
|
|
||||||
polymer_getbuildmaterial(&w->wall.material, curpicnum, curpal, curshade, sec->visibility, DAMETH_WALL);
|
w->wall.bucket = polymer_getbuildmaterial(&w->wall.material, curpicnum, curpal, curshade, sec->visibility, DAMETH_WALL);
|
||||||
|
|
||||||
if (!(wall[refwall].cstat&4))
|
if (!(wall[refwall].cstat&4))
|
||||||
yref = nsec->floorz;
|
yref = nsec->floorz;
|
||||||
|
@ -3183,12 +3312,12 @@ static void polymer_updatewall(int16_t wallnum)
|
||||||
else
|
else
|
||||||
curpicnum = wallpicnum;
|
curpicnum = wallpicnum;
|
||||||
|
|
||||||
polymer_getbuildmaterial(&w->over.material, curpicnum, wal->pal, wal->shade, sec->visibility, DAMETH_WALL);
|
w->over.bucket = polymer_getbuildmaterial(&w->over.material, curpicnum, wal->pal, wal->shade, sec->visibility, DAMETH_WALL);
|
||||||
|
|
||||||
if ((wal->cstat & 16) || (wal->cstat & 32))
|
if ((wal->cstat & 16) || (wal->cstat & 32))
|
||||||
{
|
{
|
||||||
// mask
|
// mask
|
||||||
polymer_getbuildmaterial(&w->mask.material, walloverpicnum, wal->pal, wal->shade, sec->visibility, DAMETH_WALL);
|
w->mask.bucket = polymer_getbuildmaterial(&w->mask.material, walloverpicnum, wal->pal, wal->shade, sec->visibility, DAMETH_WALL);
|
||||||
|
|
||||||
if (wal->cstat & 128)
|
if (wal->cstat & 128)
|
||||||
{
|
{
|
||||||
|
@ -3326,9 +3455,9 @@ static void polymer_updatewall(int16_t wallnum)
|
||||||
//bglBufferSubDataARB(GL_ARRAY_BUFFER_ARB, 4 * sizeof(GLfloat)* 5, 4 * sizeof(GLfloat)* 3, w->cap);
|
//bglBufferSubDataARB(GL_ARRAY_BUFFER_ARB, 4 * sizeof(GLfloat)* 5, 4 * sizeof(GLfloat)* 3, w->cap);
|
||||||
bglBindBufferARB(GL_ARRAY_BUFFER_ARB, 0);
|
bglBindBufferARB(GL_ARRAY_BUFFER_ARB, 0);
|
||||||
|
|
||||||
w->wall.mapvbo_vertoffset = thiswalloffset;
|
w->wall.mapvbo_vertoffset = thiswalloffset / sizeof(_prvert);
|
||||||
w->over.mapvbo_vertoffset = thisoveroffset;
|
w->over.mapvbo_vertoffset = thisoveroffset / sizeof(_prvert);
|
||||||
w->mask.mapvbo_vertoffset = thismaskoffset;
|
w->mask.mapvbo_vertoffset = thismaskoffset / sizeof(_prvert);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -4650,10 +4779,14 @@ static void polymer_getscratchmaterial(_prmaterial* material)
|
||||||
material->mdspritespace = GL_FALSE;
|
material->mdspritespace = GL_FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void polymer_getbuildmaterial(_prmaterial* material, int16_t tilenum, char pal, int8_t shade, int8_t vis, int32_t cmeth)
|
static _prbucket* polymer_getbuildmaterial(_prmaterial* material, int16_t tilenum, char pal, int8_t shade, int8_t vis, int32_t cmeth)
|
||||||
{
|
{
|
||||||
pthtyp* pth;
|
pthtyp* pth;
|
||||||
int32_t usinghighpal = 0;
|
int32_t usinghighpal = 0;
|
||||||
|
_prbucket* bucketptr;
|
||||||
|
|
||||||
|
// find corresponding bucket; XXX key that with pr_buckets later, need to be tied to restartvid
|
||||||
|
bucketptr = polymer_findbucket(tilenum, pal);
|
||||||
|
|
||||||
polymer_getscratchmaterial(material);
|
polymer_getscratchmaterial(material);
|
||||||
|
|
||||||
|
@ -4760,7 +4893,8 @@ static void polymer_getbuildmaterial(_prmaterial* material, int16_t tile
|
||||||
material->shadeoffset = shade;
|
material->shadeoffset = shade;
|
||||||
material->visibility = ((uint8_t)(vis+16) / 16.0f);
|
material->visibility = ((uint8_t)(vis+16) / 16.0f);
|
||||||
|
|
||||||
return;
|
// all the stuff below is mutually exclusive with artmapping
|
||||||
|
goto done;
|
||||||
}
|
}
|
||||||
|
|
||||||
// PR_BIT_HIGHPALOOKUP_MAP
|
// PR_BIT_HIGHPALOOKUP_MAP
|
||||||
|
@ -4837,6 +4971,15 @@ static void polymer_getbuildmaterial(_prmaterial* material, int16_t tile
|
||||||
material->normalbias[0] = pth->hicr->specpower;
|
material->normalbias[0] = pth->hicr->specpower;
|
||||||
material->normalbias[1] = pth->hicr->specfactor;
|
material->normalbias[1] = pth->hicr->specfactor;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
done:
|
||||||
|
if (bucketptr->invalidmaterial != 0)
|
||||||
|
{
|
||||||
|
bucketptr->material = *material;
|
||||||
|
bucketptr->invalidmaterial = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
return bucketptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int32_t polymer_bindmaterial(const _prmaterial *material, int16_t* lights, int matlightcount)
|
static int32_t polymer_bindmaterial(const _prmaterial *material, int16_t* lights, int matlightcount)
|
||||||
|
|
|
@ -5704,7 +5704,8 @@ void polymost_initosdfuncs(void)
|
||||||
{ "r_pr_verbosity", "verbosity level of the polymer renderer", (void *) &pr_verbosity, CVAR_INT, 0, 3 },
|
{ "r_pr_verbosity", "verbosity level of the polymer renderer", (void *) &pr_verbosity, CVAR_INT, 0, 3 },
|
||||||
{ "r_pr_wireframe", "toggles wireframe mode", (void *) &pr_wireframe, CVAR_INT | CVAR_NOSAVE, 0, 1 },
|
{ "r_pr_wireframe", "toggles wireframe mode", (void *) &pr_wireframe, CVAR_INT | CVAR_NOSAVE, 0, 1 },
|
||||||
{ "r_pr_vbos", "contols Vertex Buffer Object usage. 0: no VBOs. 1: VBOs for map data. 2: VBOs for model data.", (void *) &pr_vbos, CVAR_INT | CVAR_RESTARTVID, 0, 2 },
|
{ "r_pr_vbos", "contols Vertex Buffer Object usage. 0: no VBOs. 1: VBOs for map data. 2: VBOs for model data.", (void *) &pr_vbos, CVAR_INT | CVAR_RESTARTVID, 0, 2 },
|
||||||
{ "r_pr_gpusmoothing", "toggles model animation interpolation", (void *) &pr_gpusmoothing, CVAR_INT, 0, 1 },
|
{ "r_pr_buckets", "controls batching of primitives. 0: no batching. 1: buckets of materials.", (void *)&pr_buckets, CVAR_BOOL | CVAR_NOSAVE, 0, 1 },
|
||||||
|
{ "r_pr_gpusmoothing", "toggles model animation interpolation", (void *)&pr_gpusmoothing, CVAR_INT, 0, 1 },
|
||||||
{ "r_pr_overrideparallax", "overrides parallax mapping scale and bias values with values from the pr_parallaxscale and pr_parallaxbias cvars; use it to fine-tune DEF tokens", (void *) &pr_overrideparallax, CVAR_BOOL | CVAR_NOSAVE, 0, 1 },
|
{ "r_pr_overrideparallax", "overrides parallax mapping scale and bias values with values from the pr_parallaxscale and pr_parallaxbias cvars; use it to fine-tune DEF tokens", (void *) &pr_overrideparallax, CVAR_BOOL | CVAR_NOSAVE, 0, 1 },
|
||||||
{ "r_pr_parallaxscale", "overriden parallax mapping offset scale", (void *) &pr_parallaxscale, CVAR_FLOAT | CVAR_NOSAVE, -10, 10 },
|
{ "r_pr_parallaxscale", "overriden parallax mapping offset scale", (void *) &pr_parallaxscale, CVAR_FLOAT | CVAR_NOSAVE, -10, 10 },
|
||||||
{ "r_pr_parallaxbias", "overriden parallax mapping offset bias", (void *) &pr_parallaxbias, CVAR_FLOAT | CVAR_NOSAVE, -10, 10 },
|
{ "r_pr_parallaxbias", "overriden parallax mapping offset bias", (void *) &pr_parallaxbias, CVAR_FLOAT | CVAR_NOSAVE, -10, 10 },
|
||||||
|
|
Loading…
Reference in a new issue