shithub: choc

Download patch

ref: fee277eb0a3bfee3000a6f2adb610ab0b274a917
parent: 2f326ebddc4f4de18909b557fa69fe74ac849e82
author: Samuel Villareal <svkaiser@gmail.com>
date: Mon Sep 27 01:48:13 EDT 2010

+ V_DrawXlaPatch added
+ xlatab lump loading handled in v_video.c
+ Pop up menus added in st_stuff (not completed still)

Subversion-branch: /branches/strife-branch
Subversion-revision: 2143

--- a/src/strife/hu_lib.h
+++ b/src/strife/hu_lib.h
@@ -117,7 +117,10 @@
 void	HUlib_drawTextLine(hu_textline_t *l, boolean drawcursor);
 
 // erases text line
-void	HUlib_eraseTextLine(hu_textline_t *l); 
+void	HUlib_eraseTextLine(hu_textline_t *l);
+
+// villsa [STRIFE]
+void HUlib_drawYellowText(int x, int y, char *text);
 
 
 //
--- a/src/strife/r_draw.c
+++ b/src/strife/r_draw.c
@@ -435,7 +435,7 @@
 
 // haleyjd 08/26/10: [STRIFE] - Rogue's translucency lookup table
 // This is functionally equivalent to Raven's TINTTAB and BOOM's TRANMAPs.
-byte *xlatab;
+extern byte *xlatab;
 
 //
 // R_InitTranslationTables
@@ -465,7 +465,9 @@
     // just set the 2nd memset call's length to 0 bytes... Terrible. Since none
     // of this accomplishes anything, and isn't strictly portable, all we need
     // to do is this:
-    xlatab = W_CacheLumpName("XLATAB", PU_STATIC);
+
+    // villsa [STRIFE] 09/26/10: load table through this function instead
+    V_LoadXlaTable();
 
     // villsa [STRIFE] allocate a larger size for translation tables
     translationtables = Z_Malloc (256*8, PU_STATIC, 0);
--- a/src/strife/st_stuff.c
+++ b/src/strife/st_stuff.c
@@ -53,6 +53,7 @@
 
 #include "am_map.h"
 #include "m_cheat.h"
+#include "m_menu.h" // villsa [STRIFE]
 
 #include "s_sound.h"
 
@@ -229,10 +230,28 @@
 // whether left-side main status bar is active
 static boolean          st_statusbaron;
 
+// villsa [STRIFE]
+static boolean          st_dosizedisplay = false;
+
 // haleyjd 09/01/10: [STRIFE]
 // Whether or not a popup is currently displayed
-static boolean          st_displaypopup;
+static boolean          st_displaypopup = false;
 
+// villsa [STRIFE]
+// Whether or not show popup objective screen
+static boolean          st_showobjective = false;
+
+// villsa [STRIFE]
+static boolean          st_showinvpop = false;
+
+// villsa [STRIFE]
+static boolean          st_showkeys = false;
+
+// villsa [STRIFE] TODO - identify variables
+static boolean          dword_88604 = false;
+static int              dword_88484 = 1;
+static int              dword_88490 = 0;
+
 // haleyjd 09/19/10: [STRIFE] Cached player data
 static int              st_lastcursorpos;
 static int              st_lastammo;
@@ -321,6 +340,7 @@
 
 //cheatseq_t cheat_choppers = CHEAT("idchoppers", 0); [STRIFE] no such thing
 
+void M_SizeDisplay(int choice); // villsa [STRIFE]
 
 //
 // STATUS BAR CODE
@@ -328,12 +348,8 @@
 void ST_Stop(void);
 
 
-// [STRIFE] Unused.
-/*
-void ST_refreshBackground(void)
-{
-}
-*/
+// villsa [STRIFE]
+static int st_popupdisplaytics = 0;
 
 // [STRIFE]
 static char st_msgbuf[52];
@@ -340,27 +356,66 @@
 
 // Respond to keyboard input events,
 //  intercept cheats.
-boolean
-ST_Responder (event_t* ev)
+boolean ST_Responder(event_t* ev)
 {
-    int         i;
+    int i;
 
     // Filter automap on/off.
-    if (ev->type == ev_keyup
-        && ((ev->data1 & 0xffff0000) == AM_MSGHEADER))
+    if(ev->type == ev_keyup)
     {
-        switch(ev->data1)
+        if((ev->data1 & 0xffff0000) == AM_MSGHEADER)
         {
-        case AM_MSGENTERED:
-            st_gamestate = AutomapState;
-            st_firsttime = true;
-            break;
+            switch(ev->data1)
+            {
+            case AM_MSGENTERED:
+                st_gamestate = AutomapState;
+                st_firsttime = true;
+                break;
 
-        case AM_MSGEXITED:
-            //	fprintf(stderr, "AM exited\n");
-            st_gamestate = FirstPersonState;
-            break;
+            case AM_MSGEXITED:
+                st_gamestate = FirstPersonState;
+                break;
+            }
+
+            return false;
         }
+
+        // villsa [STRIFE]
+        if(ev->data2 != key_invpop &&
+            ev->data2 != key_mission &&
+            ev->data2 != key_invkey)
+            return false;
+
+        // villsa [STRIFE]
+        if(ev->data2 == key_invpop)
+            st_showinvpop = false;
+        else
+        {
+            if(ev->data2 == key_mission)
+                st_showobjective = false;
+            else
+            {
+                if(ev->data2 == key_invkey)
+                {
+                    st_showkeys = 0;
+                    dword_88604 = 0;
+                }
+            }
+        }
+
+        if(!st_showkeys && !st_showobjective && !st_showinvpop)
+        {
+             if(!st_popupdisplaytics)
+             {
+                 st_displaypopup = st_popupdisplaytics;
+                 if(st_dosizedisplay)
+                     M_SizeDisplay(true);
+
+                 st_dosizedisplay = false;
+             }
+        }
+
+        return true;
     }
 
     // STRIFE-TODO: this is branched on for handling key ups/key downs
@@ -383,7 +438,70 @@
         }
     }
 
-    // TODO: popup stuff here
+    // villsa [STRIFE]
+    if(ev->data2 == key_invpop || ev->data2 == key_invkey || ev->data2 == key_mission)
+    {
+        if(ev->data2 == key_invkey)
+        {
+            st_showobjective = false;
+            st_showinvpop = false;
+
+            if(!dword_88604)
+            {
+                dword_88604 = true;
+                if(++dword_88484 > 2)
+                {
+                    st_popupdisplaytics = 0;
+                    st_showkeys = false;
+                    st_displaypopup = false;
+                    dword_88484 = -1;
+                    return true;
+                }
+            }
+
+            if(netgame)
+                st_popupdisplaytics = 20;
+            else
+                st_popupdisplaytics = 50;
+
+            st_showkeys = true;
+        }
+        else
+        {
+            if(ev->data2 != key_mission || netgame)
+            {
+                if(ev->data2 ==  key_invpop)
+                {
+                    dword_88484 = -1;
+                    st_popupdisplaytics = false;
+                    st_showkeys = false;
+                    st_showobjective = false;
+                    st_showinvpop = true;
+                }
+            }
+            else
+            {
+                st_showkeys = netgame ? true : false;
+                st_showinvpop = netgame ? true : false;
+                dword_88484 = -1;
+
+                // villsa [STRIFE] TODO - verify this logic
+                st_popupdisplaytics = ev->data2 ^ key_mission;
+
+                st_showobjective = true;
+            }
+        }
+
+        if(st_showkeys || st_showobjective || st_showinvpop)
+        {
+            st_displaypopup = true;
+            if(viewheight == SCREENHEIGHT)
+            {
+                M_SizeDisplay(false);
+                st_dosizedisplay = true;
+            }
+        }
+    }
     
     if(ev->data2 == key_invleft) // inventory move left
     {
@@ -757,22 +875,25 @@
     /*
     v2 = dword_88490-- == 1; // no clue yet...
     if(v2)
-        dword_DC7F4 = dword_DC7F0;
-    v1 = st_popupdisplaytics;
+        dword_DC7F4 = dword_DC7F0;*/
+
     if(st_popupdisplaytics)
     {
+        int tics = st_popupdisplaytics;
+
         --st_popupdisplaytics;
-        if(v1 == 1)
+        if(tics == 1)
         {
             st_displaypopup = false;
             st_showkeys = false;
             dword_88484 = -1;     // unknown var
+
             if(st_dosizedisplay)
-                M_SizeDisplay();  // mondo hack?
+                M_SizeDisplay(true);  // mondo hack?
+
             st_dosizedisplay = false;
         }
     }
-    */
 
     // haleyjd 09/01/10: [STRIFE] Keys are handled on a popup
     // haleyjd 08/31/10: [STRIFE] No face widget
@@ -1078,6 +1199,28 @@
 }
 
 //
+// ST_drawTime
+//
+// villsa [STRIFE] New function.
+// Draws game time on pop up screen
+//
+static void ST_drawTime(int x, int y, int time)
+{
+    int hours;
+    int minutes;
+    int seconds;
+    char string[16];
+
+    hours = time / 3600;
+    minutes = time / 60;
+    seconds = time % 60;
+
+
+    DEH_snprintf(string, 16, "%02d:%02d:%02d", hours, minutes, seconds);
+    HUlib_drawYellowText(x, y, string);
+}
+
+//
 // ST_DrawExternal
 //
 // haleyjd 09/01/10: [STRIFE] New function.
@@ -1085,7 +1228,9 @@
 //
 boolean ST_DrawExternal(void)
 {
-    if (st_statusbaron)
+    int i;
+
+    if(st_statusbaron)
     {
         V_DrawPatchDirect(0, 160, invtop);
         STlib_drawNumPositive(&w_health);
@@ -1104,11 +1249,60 @@
     if(!st_displaypopup)
         return false;
 
-    // STRIFE-TODO: Shitloads more stuff:
-    // * showobjective shit
-    // * keys/frags popup
-    // * weapons/ammo/stats popup
-    // * etc etc etc
+    // villsa [STRIFE] added 09/26/10
+    if(st_showobjective)
+    {
+        V_DrawXlaPatch(0, 56, invpbak2);
+        V_DrawPatchDirect(0, 56, invpop2);
+        M_DialogDimMsg(24, 74, mission_objective, 1);
+        HUlib_drawYellowText(24, 74, mission_objective);
+        ST_drawTime(210, 64, leveltime / TICRATE);
+    }
+    else
+    {
+        int keys = 0;
+
+        // villsa [STRIFE] TODO
+        /*if(st_showkeys || st_popupdisplaytics)
+            return ST_drawKeysPopup();*/
+
+        V_DrawXlaPatch(0, 56, invpbak);
+        V_DrawPatchDirect(0, 56, invpop);
+
+        for(i = 0; i < NUMCARDS; i++)
+        {
+            if(plyr->cards[i])
+                keys++;
+        }
+
+        ST_drawNumFontY2(261, 132, keys);
+
+         if(plyr->weaponowned[wp_elecbow])
+             V_DrawPatchDirect(38, 86, W_CacheLumpName("CBOWA0", PU_CACHE));
+
+         if(plyr->weaponowned[wp_rifle])
+             V_DrawPatchDirect(40, 107, W_CacheLumpName("RIFLA0", PU_CACHE));
+
+         if(plyr->weaponowned[wp_missile])
+             V_DrawPatchDirect(39, 131, W_CacheLumpName("MMSLA0", PU_CACHE));
+
+         if(plyr->weaponowned[wp_hegrenade])
+             V_DrawPatchDirect(78, 87, W_CacheLumpName("GRNDA0", PU_CACHE));
+
+         if(plyr->weaponowned[wp_flame])
+             V_DrawPatchDirect(80, 117, W_CacheLumpName("FLAMA0", PU_CACHE));
+
+         if(plyr->weaponowned[wp_mauler])
+             V_DrawPatchDirect(75, 142, W_CacheLumpName("TRPDA0", PU_CACHE));
+
+         // STRIFE TODO DRAW AMMO PICS
+
+         ST_drawNumFontY2(261, 84, plyr->accuracy);
+         ST_drawNumFontY2(261, 108, plyr->stamina);
+
+         if(plyr->powers[pw_communicator])
+             V_DrawPatchDirect(280, 130, W_CacheLumpName(DEH_String("I_COMM"), PU_CACHE));
+    }
 
     return true;
 }
--- a/src/v_video.c
+++ b/src/v_video.c
@@ -48,6 +48,9 @@
 
 byte *tinttable = NULL;
 
+// villsa [STRIFE] Blending table used for Strife
+byte *xlatab = NULL;
+
 // The screen buffer that the v_video.c code draws to.
 
 static byte *dest_screen = NULL;
@@ -316,6 +319,55 @@
 }
 
 //
+// V_DrawXlaPatch
+//
+// villsa [STRIFE] Masks a column based translucent masked pic to the screen.
+//
+
+void V_DrawXlaPatch(int x, int y, patch_t * patch)
+{
+    int count, col;
+    column_t *column;
+    byte *desttop, *dest, *source;
+    int w;
+
+    y -= SHORT(patch->topoffset);
+    x -= SHORT(patch->leftoffset);
+
+    if(patchclip_callback)
+    {
+        if(!patchclip_callback(patch, x, y))
+            return;
+    }
+
+    col = 0;
+    desttop = dest_screen + y * SCREENWIDTH + x;
+
+    w = SHORT(patch->width);
+    for(; col < w; x++, col++, desttop++)
+    {
+        column = (column_t *) ((byte *) patch + LONG(patch->columnofs[col]));
+
+        // step through the posts in a column
+
+        while(column->topdelta != 0xff)
+        {
+            source = (byte *) column + 3;
+            dest = desttop + column->topdelta * SCREENWIDTH;
+            count = column->length;
+
+            while(count--)
+            {
+                *dest = xlatab[*dest + ((*source) << 8)];
+                source++;
+                dest += SCREENWIDTH;
+            }
+            column = (column_t *) ((byte *) column + column->length + 4);
+        }
+    }
+}
+
+//
 // V_DrawAltTLPatch
 //
 // Masks a column based translucent masked pic to the screen.
@@ -428,6 +480,17 @@
 void V_LoadTintTable(void)
 {
     tinttable = W_CacheLumpName("TINTTAB", PU_STATIC);
+}
+
+//
+// V_LoadXlaTable
+//
+// villsa [STRIFE] Load xla table from XLATAB lump.
+//
+
+void V_LoadXlaTable(void)
+{
+    xlatab = W_CacheLumpName("XLATAB", PU_STATIC);
 }
 
 //
--- a/src/v_video.h
+++ b/src/v_video.h
@@ -67,7 +67,7 @@
 void V_DrawTLPatch(int x, int y, patch_t *patch);
 void V_DrawAltTLPatch(int x, int y, patch_t * patch);
 void V_DrawShadowedPatch(int x, int y, patch_t *patch);
-
+void V_DrawXlaPatch(int x, int y, patch_t * patch);     // villsa [STRIFE]
 void V_DrawPatchDirect(int x, int y, patch_t *patch);
 
 // Draw a linear block of pixels into the view buffer.
@@ -98,6 +98,12 @@
 // lump.
 
 void V_LoadTintTable(void);
+
+// villsa [STRIFE]
+// Load the lookup table for translucency calculations from the XLATAB
+// lump.
+
+void V_LoadXlaTable(void);
 
 #endif