summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/strife/p_mobj.h3
-rw-r--r--src/strife/r_draw.c97
-rw-r--r--src/strife/r_things.c5
3 files changed, 88 insertions, 17 deletions
diff --git a/src/strife/p_mobj.h b/src/strife/p_mobj.h
index fcf963b2..38c04075 100644
--- a/src/strife/p_mobj.h
+++ b/src/strife/p_mobj.h
@@ -235,7 +235,8 @@ typedef enum
MF_TRANSLATION = 0xc000000,
// Hmm ???.
- MF_TRANSSHIFT = 26
+ // villsa [STRIFE] change from 26 to 28
+ MF_TRANSSHIFT = 28
} mobjflag_t;
diff --git a/src/strife/r_draw.c b/src/strife/r_draw.c
index e0dc9da8..9d0882d9 100644
--- a/src/strife/r_draw.c
+++ b/src/strife/r_draw.c
@@ -546,7 +546,8 @@ byte *xlatab;
//
void R_InitTranslationTables (void)
{
- int i;
+ int i;
+ int j;
// [STRIFE] Load xlatab. Here's how Rogue did it:
// v7 = W_CacheLumpName("XLATAB", PU_CACHE); // note potential cache bug...
@@ -563,24 +564,92 @@ void R_InitTranslationTables (void)
// to do is this:
xlatab = W_CacheLumpName("XLATAB", PU_STATIC);
- translationtables = Z_Malloc (256*3, PU_STATIC, 0);
+ // villsa [STRIFE] allocate a larger size for translation tables
+ translationtables = Z_Malloc (256*8, PU_STATIC, 0);
- // STRIFE-TODO: Strife has many more (and more varied) translations
- // translate just the 16 green colors
- for (i=0 ; i<256 ; i++)
+ // villsa [STRIFE] setup all translation tables
+ for(i = 0, j = -6; i < 256; i++, j++)
{
- if (i >= 0x70 && i<= 0x7f)
+ if(i >= 0x80 && i<= 0x8f)
{
- // map green ramp to gray, brown, red
- translationtables[i] = 0x60 + (i&0xf);
- translationtables [i+256] = 0x40 + (i&0xf);
- translationtables [i+512] = 0x20 + (i&0xf);
+ translationtables [i ] = (i & 0xf) + 64;
+ translationtables [i+ 256] = (i & 0xf) - 80;
+ translationtables [i+2*256] = (i & 0xf) + 16;
+ translationtables [i+3*256] = (i & 0xf) + 48;
+ translationtables [i+4*256] = (i & 0xf) + 80;
+ translationtables [i+5*256] = (i & 0xf) + 96;
+ translationtables [i+6*256] = (i & 0xf) - 112;
}
- else
+
+ else if(i >= 0x50 && i<= 0x5f)
+ {
+ translationtables [i ] = i;
+ translationtables [i+ 256] = i;
+ translationtables [i+2*256] = i;
+ translationtables [i+3*256] = i;
+ translationtables [i+4*256] = (i & 0xf) + -128;
+ translationtables [i+5*256] = (i & 0xf) + 16;
+ translationtables [i+6*256] = (i & 0xf) + 64;
+ }
+ else if(i >= 0xd0 && i<= 0xdf)
+ {
+ translationtables [i ] = i;
+ translationtables [i+ 256] = i;
+ translationtables [i+2*256] = i;
+ translationtables [i+3*256] = i;
+ translationtables [i+4*256] = (i & 0xf) - 80;
+ translationtables [i+5*256] = (i & 0xf) + 48;
+ translationtables [i+6*256] = (i & 0xf) + 16;
+ }
+ else if(i >= 0xc0 && i<= 0xcf)
+ {
+ translationtables [i ] = i;
+ translationtables [i+ 256] = i;
+ translationtables [i+2*256] = i;
+ translationtables [i+3*256] = i;
+ translationtables [i+4*256] = (i & 0xf) - 96;
+ translationtables [i+5*256] = (i & 0xf) + 32;
+ translationtables [i+6*256] = (i & 0xf);
+ }
+ else if(i >= 0xf7 && i<= 0xfb)
+ {
+ translationtables [i ] = j;
+ translationtables [i+ 256] = i;
+ translationtables [i+2*256] = i;
+ translationtables [i+3*256] = i;
+ translationtables [i+4*256] = i;
+ translationtables [i+5*256] = i;
+ translationtables [i+6*256] = i;
+ }
+ else if(i >= 0xf1 && i<= 0xf6)
+ {
+ translationtables [i ] = (i & 0xf) - 33;
+ translationtables [i+ 256] = i;
+ translationtables [i+2*256] = i;
+ translationtables [i+3*256] = i;
+ translationtables [i+4*256] = i;
+ translationtables [i+5*256] = i;
+ translationtables [i+6*256] = i;
+ }
+ else if(i >= 0x20 && i<= 0x40)
+ {
+ translationtables [i ] = i;
+ translationtables [i+ 256] = i;
+ translationtables [i+2*256] = (i & 0xf) - 48;
+ translationtables [i+3*256] = (i & 0xf) - 48;
+ translationtables [i+4*256] = i;
+ translationtables [i+5*256] = i;
+ translationtables [i+6*256] = i;
+ }
+ else // Keep all other colors as is.
{
- // Keep all other colors as is.
- translationtables[i] = translationtables[i+256]
- = translationtables[i+512] = i;
+ translationtables[i]=
+ translationtables[i+256]=
+ translationtables[i+2*256]=
+ translationtables[i+3*256]=
+ translationtables[i+4*256]=
+ translationtables[i+5*256]=
+ translationtables[i+6*256]=i;
}
}
}
diff --git a/src/strife/r_things.c b/src/strife/r_things.c
index 90267052..45b71915 100644
--- a/src/strife/r_things.c
+++ b/src/strife/r_things.c
@@ -414,11 +414,12 @@ R_DrawVisSprite
// NULL colormap = shadow draw
colfunc = fuzzcolfunc;
}
- else if (vis->mobjflags & MF_TRANSLATION)
+ // villsa [STRIFE] new translation tables
+ else if (vis->mobjflags & (MF_COLORSWAP1|MF_COLORSWAP2|MF_COLORSWAP3))
{
colfunc = transcolfunc;
dc_translation = translationtables - 256 +
- ( (vis->mobjflags & MF_TRANSLATION) >> (MF_TRANSSHIFT-8) );
+ ((vis->mobjflags & (MF_COLORSWAP1|MF_COLORSWAP2|MF_COLORSWAP3))>>20);
}
dc_iscale = abs(vis->xiscale)>>detailshift;