From b50b229c1dc5e4df31b93a08eedf2215aa869fb7 Mon Sep 17 00:00:00 2001 From: plagman Date: Thu, 27 Nov 2008 22:26:46 +0000 Subject: [PATCH] Detail map material bit. git-svn-id: https://svn.eduke32.com/eduke32@1168 1a8010ca-5511-0410-912e-c29ae57300e0 --- polymer/eduke32/build/include/polymer.h | 61 ++++++----- polymer/eduke32/build/include/polymost.h | 1 + polymer/eduke32/build/src/hightile.c | 2 +- polymer/eduke32/build/src/polymer.c | 123 ++++++++++++++++++++--- 4 files changed, 147 insertions(+), 40 deletions(-) diff --git a/polymer/eduke32/build/include/polymer.h b/polymer/eduke32/build/include/polymer.h index d50f4f3df..8d1e1079a 100644 --- a/polymer/eduke32/build/include/polymer.h +++ b/polymer/eduke32/build/include/polymer.h @@ -43,6 +43,15 @@ extern int pr_gpusmoothing; extern int glerror; // MATERIAL +typedef enum { + PR_BIT_ANIM_INTERPOLATION, + PR_BIT_DIFFUSE_MAP, + PR_BIT_DIFFUSE_DETAIL_MAP, + PR_BIT_DIFFUSE_MODULATION, + PR_BIT_DEFAULT, // must be just before last + PR_BIT_COUNT // must be last +} prbittype; + typedef struct s_prmaterial { // PR_BIT_ANIM_INTERPOLATION GLfloat frameprogress; @@ -50,11 +59,37 @@ typedef struct s_prmaterial { GLsizei nextframedatastride; // PR_BIT_DIFFUSE_MAP GLuint diffusemap; - GLfloat diffusescalex, diffusescaley; + GLfloat diffusescale[2]; + // PR_BIT_DIFFUSE_DETAIL_MAP + GLuint detailmap; + GLfloat detailscale[2]; // PR_BIT_DIFFUSE_MODULATION GLfloat diffusemodulation[4]; } _prmaterial; +typedef struct s_prrograminfo { + GLhandleARB handle; + // PR_BIT_ANIM_INTERPOLATION + GLint attrib_nextFrameData; + GLint uniform_frameProgress; + // PR_BIT_DIFFUSE_MAP + GLint uniform_diffuseMap; + GLint uniform_diffuseScale; + // PR_BIT_DIFFUSE_DETAIL_MAP + GLint uniform_detailMap; + GLint uniform_detailScale; +} _prprograminfo; + +#define PR_INFO_LOG_BUFFER_SIZE 512 + +typedef struct s_prprogrambit { + int bit; + char* vert_def; + char* vert_prog; + char* frag_def; + char* frag_prog; +} _prprogrambit; + // BUILD DATA typedef struct s_prplane { // geometry @@ -135,30 +170,6 @@ typedef struct s_prlight { } _prlight; // PROGRAMS -#define PR_INFO_LOG_BUFFER_SIZE 512 - -typedef enum { - PR_BIT_ANIM_INTERPOLATION, - PR_BIT_DIFFUSE_MAP, - PR_BIT_DIFFUSE_MODULATION, - PR_BIT_DEFAULT, // must be just before last - PR_BIT_COUNT // must be last -} prbittype; - -typedef struct s_prprogrambit { - int bit; - char* vert_def; - char* vert_prog; - char* frag_def; - char* frag_prog; -} _prprogrambit; - -typedef struct s_prrograminfo { - GLhandleARB handle; - // PR_BIT_ANIM_INTERPOLATION - GLint attrib_nextFrameData; - GLint uniform_frameProgress; -} _prprograminfo; // CONTROL extern int updatesectors; diff --git a/polymer/eduke32/build/include/polymost.h b/polymer/eduke32/build/include/polymost.h index 30e858bba..e5574e35d 100644 --- a/polymer/eduke32/build/include/polymost.h +++ b/polymer/eduke32/build/include/polymost.h @@ -34,6 +34,7 @@ typedef struct pthtyp_t char *palmap;int size; } pthtyp; +hicreplctyp * hicfindsubst(int picnum, int palnum, int skybox); pthtyp * gltexcache (int dapicnum, int dapalnum, int dameth); extern palette_t hictinting[MAXPALOOKUPS]; diff --git a/polymer/eduke32/build/src/hightile.c b/polymer/eduke32/build/src/hightile.c index 153a4a926..a69f6901c 100644 --- a/polymer/eduke32/build/src/hightile.c +++ b/polymer/eduke32/build/src/hightile.c @@ -28,7 +28,7 @@ static char hicfirstinit = 0; // // find the index into hicreplc[] which contains the replacement tile particulars // -static hicreplctyp * hicfindsubst(int picnum, int palnum, int skybox) +hicreplctyp * hicfindsubst(int picnum, int palnum, int skybox) { hicreplctyp *hr; diff --git a/polymer/eduke32/build/src/polymer.c b/polymer/eduke32/build/src/polymer.c index bd5ea08c4..805477395 100644 --- a/polymer/eduke32/build/src/polymer.c +++ b/polymer/eduke32/build/src/polymer.c @@ -12,7 +12,7 @@ int pr_verbosity = 1; // 0: silent, 1: errors and one-times, 2 int pr_wireframe = 0; int pr_vbos = 2; int pr_mirrordepth = 1; -int pr_gpusmoothing = 0; +int pr_gpusmoothing = 1; int glerror; @@ -147,9 +147,10 @@ _prprogrambit prprogrambits[PR_BIT_COUNT] = { { 1 << PR_BIT_DIFFUSE_MAP, // vert_def - "", + "uniform vec2 diffuseScale;\n" + "\n", // vert_prog - "gl_TexCoord[0] = gl_TextureMatrix[0] * gl_MultiTexCoord0;\n" + "gl_TexCoord[0] = vec4(diffuseScale, 1.0, 1.0) * gl_MultiTexCoord0;\n" "\n", // frag_def "uniform sampler2D diffuseMap;\n" @@ -158,6 +159,22 @@ _prprogrambit prprogrambits[PR_BIT_COUNT] = { " result *= texture2D(diffuseMap, gl_TexCoord[0].st);\n" "\n", }, + { + 1 << PR_BIT_DIFFUSE_DETAIL_MAP, + // vert_def + "uniform vec2 detailScale;\n" + "\n", + // vert_prog + "gl_TexCoord[1] = vec4(detailScale, 1.0, 1.0) * gl_MultiTexCoord0;\n" + "\n", + // frag_def + "uniform sampler2D detailMap;\n" + "\n", + // frag_prog + " result *= texture2D(detailMap, gl_TexCoord[1].st);\n" + " result.rgb *= 2.0;\n" + "\n", + }, { 1 << PR_BIT_DIFFUSE_MODULATION, // vert_def @@ -610,10 +627,10 @@ void polymer_drawsprite(int snum) } if ((tspr->cstat & 4) || (((tspr->cstat>>4) & 3) == 2)) - spriteplane.material.diffusescalex = -spriteplane.material.diffusescalex; + spriteplane.material.diffusescale[0] = -spriteplane.material.diffusescale[0]; if (tspr->cstat & 8) - spriteplane.material.diffusescaley = -spriteplane.material.diffusescaley; + spriteplane.material.diffusescale[1] = -spriteplane.material.diffusescale[1]; if ((tspr->cstat & 64) && (((tspr->cstat>>4) & 3) == 1)) bglEnable(GL_CULL_FACE); @@ -2221,18 +2238,22 @@ static void polymer_drawskybox(short tilenum) static void polymer_drawmdsprite(spritetype *tspr) { md3model* m; + mdskinmap_t* sk; + md3xyzn_t *v0, *v1; + md3surf_t *s; + char lpal; float spos[3]; float ang; float scale; int surfi; GLfloat* color; - md3xyzn_t *v0, *v1; - md3surf_t *s; int materialbits; m = (md3model*)models[tile2model[Ptile2tile(tspr->picnum,sprite[tspr->owner].pal)].modelid]; updateanimation((md2model *)m,tspr); + lpal = (tspr->owner >= MAXSPRITES) ? tspr->pal : sprite[tspr->owner].pal; + if ((pr_vbos > 1) && (m->indices == NULL)) polymer_loadmodelvbos(m); @@ -2322,6 +2343,15 @@ static void polymer_drawmdsprite(spritetype *tspr) if (!mdspritematerial.diffusemap) continue; + mdspritematerial.detailmap = + mdloadskin((md2model *)m,tile2model[Ptile2tile(tspr->picnum,lpal)].skinnum,DETAILPAL,surfi); + + for (sk = m->skinmap; sk; sk = sk->next) + if ((int)sk->palette == DETAILPAL && + sk->skinnum == tile2model[Ptile2tile(tspr->picnum,lpal)].skinnum && + sk->surfnum == surfi) + mdspritematerial.detailscale[0] = mdspritematerial.detailscale[1] = sk->param; + if (pr_vbos > 1) { bglBindBufferARB(GL_ARRAY_BUFFER_ARB, m->texcoords[surfi]); @@ -2416,7 +2446,10 @@ static void polymer_getscratchmaterial(_prmaterial* material) material->nextframedatastride = 0; // PR_BIT_DIFFUSE_MAP material->diffusemap = 0; - material->diffusescalex = material->diffusescaley = 1.0f; + material->diffusescale[0] = material->diffusescale[1] = 1.0f; + // PR_BIT_DIFFUSE_DETAIL_MAP + material->detailmap = 0; + material->detailscale[0] = material->detailscale[1] = 1.0f; // PR_BIT_DIFFUSE_MODULATION material->diffusemodulation[0] = material->diffusemodulation[1] = @@ -2427,12 +2460,15 @@ static void polymer_getscratchmaterial(_prmaterial* material) static void polymer_getbuildmaterial(_prmaterial* material, short tilenum, char pal, signed char shade) { pthtyp* pth; + pthtyp* detailpth; polymer_getscratchmaterial(material); + // PR_BIT_DIFFUSE_MAP if (!waloff[tilenum]) loadtile(tilenum); + pth = NULL; pth = gltexcache(tilenum, pal, 0); if (pth) @@ -2440,10 +2476,33 @@ static void polymer_getbuildmaterial(_prmaterial* material, short tilenu if (pth->hicr) { - material->diffusescalex = pth->hicr->xscale; - material->diffusescaley = pth->hicr->yscale; + material->diffusescale[0] = pth->hicr->xscale; + material->diffusescale[1] = pth->hicr->yscale; } + // PR_BIT_DIFFUSE_DETAIL_MAP + if (r_detailmapping && hicfindsubst(tilenum, DETAILPAL, 0)) + { + detailpth = NULL; + detailpth = gltexcache(tilenum, DETAILPAL, 0); + + if (detailpth && (detailpth->hicr->palnum == DETAILPAL)) + { + material->detailmap = detailpth->glpic; + + material->detailscale[0] = detailpth->hicr->xscale; + material->detailscale[1] = detailpth->hicr->yscale; + + // scale by the diffuse map scale if there's one defined + if (pth->hicr) + { + material->detailscale[0] *= material->diffusescale[0]; + material->detailscale[1] *= material->diffusescale[1]; + } + } + } + + // PR_BIT_DIFFUSE_MODULATION material->diffusemodulation[0] = material->diffusemodulation[1] = material->diffusemodulation[2] = @@ -2460,6 +2519,7 @@ static void polymer_getbuildmaterial(_prmaterial* material, short tilenu static int polymer_bindmaterial(_prmaterial material) { int programbits; + int texunit; programbits = prprogrambits[PR_BIT_DEFAULT].bit; @@ -2473,6 +2533,10 @@ static int polymer_bindmaterial(_prmaterial material) if (material.diffusemap) programbits |= prprogrambits[PR_BIT_DIFFUSE_MAP].bit; + // PR_BIT_DIFFUSE_DETAIL_MAP + if (material.detailmap) + programbits |= prprogrambits[PR_BIT_DIFFUSE_DETAIL_MAP].bit; + // PR_BIT_DIFFUSE_MODULATION if ((material.diffusemodulation[0] != 1.0f) || (material.diffusemodulation[1] != 1.0f) || (material.diffusemodulation[2] != 1.0f) || (material.diffusemodulation[3] != 1.0f)) @@ -2486,6 +2550,8 @@ static int polymer_bindmaterial(_prmaterial material) // --------- bit setup + texunit = 0; + // PR_BIT_ANIM_INTERPOLATION if (programbits & prprogrambits[PR_BIT_ANIM_INTERPOLATION].bit) { @@ -2501,12 +2567,25 @@ static int polymer_bindmaterial(_prmaterial material) // PR_BIT_DIFFUSE_MAP if (programbits & prprogrambits[PR_BIT_DIFFUSE_MAP].bit) { + bglActiveTextureARB(texunit + GL_TEXTURE0_ARB); bglBindTexture(GL_TEXTURE_2D, material.diffusemap); - bglMatrixMode(GL_TEXTURE); - bglLoadIdentity(); - bglScalef(material.diffusescalex, material.diffusescaley, 1.0f); - bglMatrixMode(GL_MODELVIEW); + bglUniform1iARB(prprograms[programbits].uniform_diffuseMap, texunit); + bglUniform2fvARB(prprograms[programbits].uniform_diffuseScale, 1, material.diffusescale); + + texunit++; + } + + // PR_BIT_DIFFUSE_DETAIL_MAP + if (programbits & prprogrambits[PR_BIT_DIFFUSE_DETAIL_MAP].bit) + { + bglActiveTextureARB(texunit + GL_TEXTURE0_ARB); + bglBindTexture(GL_TEXTURE_2D, material.detailmap); + + bglUniform1iARB(prprograms[programbits].uniform_detailMap, texunit); + bglUniform2fvARB(prprograms[programbits].uniform_detailScale, 1, material.detailscale); + + texunit++; } // PR_BIT_DIFFUSE_MODULATION @@ -2518,6 +2597,8 @@ static int polymer_bindmaterial(_prmaterial material) material.diffusemodulation[3]); } + bglActiveTextureARB(GL_TEXTURE0_ARB); + return (programbits); } @@ -2607,6 +2688,20 @@ static void polymer_compileprogram(int programbits) prprograms[programbits].attrib_nextFrameData = bglGetAttribLocationARB(program, "nextFrameData"); prprograms[programbits].uniform_frameProgress = bglGetUniformLocationARB(program, "frameProgress"); } + + // PR_BIT_DIFFUSE_MAP + if (programbits & prprogrambits[PR_BIT_DIFFUSE_MAP].bit) + { + prprograms[programbits].uniform_diffuseMap = bglGetUniformLocationARB(program, "diffuseMap"); + prprograms[programbits].uniform_diffuseScale = bglGetUniformLocationARB(program, "diffuseScale"); + } + + // PR_BIT_DIFFUSE_DETAIL_MAP + if (programbits & prprogrambits[PR_BIT_DIFFUSE_DETAIL_MAP].bit) + { + prprograms[programbits].uniform_detailMap = bglGetUniformLocationARB(program, "detailMap"); + prprograms[programbits].uniform_detailScale = bglGetUniformLocationARB(program, "detailScale"); + } } #endif