shithub: choc

Download patch

ref: d48b48bd9a0657b81af7769dbf364dcac69eb783
parent: ffb95c420a3037021f352fa35268a9750bed37f5
author: James Haley <[email protected]>
date: Sun Sep 19 17:46:22 EDT 2010

Functional inventory status bar cursor and item rendering. Fix for
P_GiveInventoryItem to return proper value at end of function.

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

--- a/src/strife/p_dialog.c
+++ b/src/strife/p_dialog.c
@@ -686,7 +686,7 @@
     else
         ok = false;
 
-    return true;
+    return ok;
 }
 
 //
--- a/src/strife/st_stuff.c
+++ b/src/strife/st_stuff.c
@@ -57,6 +57,7 @@
 
 // Needs access to LFB.
 #include "v_video.h"
+#include "i_swap.h"
 
 // State.
 #include "doomstat.h"
@@ -64,6 +65,7 @@
 // Data.
 #include "dstrings.h"
 #include "sounds.h"
+#include "m_controls.h"
 
 //
 // STATUS BAR DATA
@@ -82,8 +84,6 @@
 // Location of status bar
 #define ST_X                    0
 
-#define ST_FX                   143
-
 // Location and size of statistics,
 //  justified according to widget type.
 // Problem is, within which space? STbar? Screen?
@@ -210,8 +210,8 @@
 // * Removed more faces, keyboxes, st_randomnumber
 
 // graphics are drawn to a backing screen and blitted to the real screen
-byte                   *st_backing_screen;
-	    
+//byte                   *st_backing_screen;  - [STRIFE]: Unused.
+
 // main player in game
 static player_t*        plyr; 
 
@@ -233,12 +233,14 @@
 
 // haleyjd 09/01/10: [STRIFE] sbar -> invback
 // main inventory background and other bits
-static patch_t*         invback;  // main bar
-static patch_t*         invtop;   // top bit
-static patch_t*         invpop;   // popup frame with text
-static patch_t*         invpop2;  // plain popup frame
-static patch_t*         invpbak;  // popup background w/details
-static patch_t*         invpbak2; // plain popup background
+static patch_t*         invback;   // main bar
+static patch_t*         stback;    // multiplayer background
+static patch_t*         invtop;    // top bit
+static patch_t*         invpop;    // popup frame with text
+static patch_t*         invpop2;   // plain popup frame
+static patch_t*         invpbak;   // popup background w/details
+static patch_t*         invpbak2;  // plain popup background
+static patch_t*         invcursor; // cursor
 
 // haleyjd 09/01/10: [STRIFE] Replaced tallnum, shortnum w/inv fonts
 // 0-9, green numbers
@@ -289,6 +291,9 @@
 
 //cheatseq_t cheat_choppers = CHEAT("idchoppers", 0); [STRIFE] no such thing
 
+// Forward declarations:
+void ST_drawNumFontY(int x, int y, int num);
+void ST_drawNumFontY2(int x, int y, int num);
 
 //
 // STATUS BAR CODE
@@ -299,21 +304,67 @@
 {
     if (st_statusbaron)
     {
-        V_UseBuffer(st_backing_screen);
+        int firstinventory, icon_x, num_x, i, numdrawn;
 
-        V_DrawPatch(ST_X, 0, invback);
+        // haleyjd 09/19/10: No backscreen caching in Strife.
+        //V_UseBuffer(st_backing_screen);
 
-        // haleyjd 09/01/10: STRIFE-TODO: status bar stuff
-        /*
-        if (netgame)
-            V_DrawPatch(ST_FX, 0, faceback);
-        */
-        V_RestoreBuffer();
+        // TODO: only sometimes drawing?
 
-        V_CopyRect(ST_X, 0, st_backing_screen, ST_WIDTH, ST_HEIGHT, ST_X, ST_Y);
+        plyr->st_update = false;
+
+        // draw main status bar
+        V_DrawPatch(ST_X, ST_Y, invback);
+
+        // draw multiplayer armor backdrop if netgame
+        if(netgame)
+            V_DrawPatch(ST_X, 173, stback);
+
+        if(plyr->inventorycursor >= 6)
+            firstinventory = plyr->inventorycursor - 5;
+        else
+            firstinventory = 0;
+
+        // Draw cursor.
+        if(plyr->numinventory)
+        {
+            V_DrawPatch(35 * (plyr->inventorycursor - firstinventory) + 42,
+                        180, invcursor);
+        }
+
+        // Draw inventory bar
+        for(num_x = 68, icon_x = 48, i = firstinventory, numdrawn = 0; 
+            num_x < 278; 
+            num_x += 35, icon_x += 35, i++, numdrawn++)
+        {
+            int lumpnum;
+            patch_t *patch;
+            char iconname[8];
+
+            if(plyr->numinventory <= numdrawn)
+                break;
+            
+            DEH_snprintf(iconname, sizeof(iconname), "I_%s",
+                         DEH_String(sprnames[plyr->inventory[i].sprite]));
+
+            lumpnum = W_CheckNumForName(iconname);
+            if(lumpnum == -1)
+                patch = W_CacheLumpName(DEH_String("STCFN063"), PU_CACHE);
+            else
+                patch = W_CacheLumpNum(lumpnum, PU_STATIC);
+
+            V_DrawPatch(icon_x, 182, patch);
+            ST_drawNumFontY(num_x, 191, plyr->inventory[i].amount);
+        }
+
+        // haleyjd 09/19/10: nope, not in Strife.
+        //V_RestoreBuffer();
+        //V_CopyRect(ST_X, 0, st_backing_screen, ST_WIDTH, ST_HEIGHT, ST_X, ST_Y);
     }
 }
 
+// [STRIFE]
+static char st_msgbuf[52];
 
 // Respond to keyboard input events,
 //  intercept cheats.
@@ -347,6 +398,47 @@
     if(ev->type != ev_keydown)
         return false;
 
+    // keydown events
+    if(ev->data2 == key_invquery) // inventory query
+    {
+        inventory_t *inv = &(plyr->inventory[plyr->inventorycursor]);
+        if(inv->amount)
+        {
+            DEH_snprintf(st_msgbuf, sizeof(st_msgbuf), "%d %s",
+                         inv->amount, 
+                         DEH_String(mobjinfo[inv->type].name));
+            plyr->message = st_msgbuf;
+        }
+    }
+
+    // TODO: popup stuff here
+    
+    if(ev->data2 == key_invleft) // inventory move left
+    {
+        if(plyr->inventorycursor > 0)
+            plyr->inventorycursor--;
+        return true;
+    }
+    else if(ev->data2 == key_invright)
+    {
+        if(plyr->inventorycursor < plyr->numinventory - 1)
+            plyr->inventorycursor++;
+        return true;
+    }
+    else if(ev->data2 == key_invhome)
+    {
+        plyr->inventorycursor = 0;
+        return true;
+    }
+    else if(ev->data2 == key_invend)
+    {
+        if(plyr->numinventory)
+            plyr->inventorycursor = plyr->numinventory - 1;
+        else 
+            plyr->inventorycursor = 0;
+        return true;
+    }
+
     //
     // [STRIFE] Cheats which are allowed in netgames/demos:
     //
@@ -735,6 +827,47 @@
 }
 */
 
+//
+// ST_drawNumFontY
+//
+// haleyjd 09/19/10: [STRIFE] New function
+// Draws a small yellow number for inventory etc.
+//
+void ST_drawNumFontY(int x, int y, int num)
+{
+    if(!num)
+        V_DrawPatch(x, y, invfonty[0]);
+    
+    while(num)
+    {
+        V_DrawPatch(x, y, invfonty[num % 10]);
+        x -= SHORT(invfonty[0]->width) + 1;
+        num /= 10;
+    }
+}
+
+//
+// ST_drawNumFontY2
+//
+// haleyjd 09/19/10: [STRIFE] New function
+// As above, but turns negative numbers into zero.
+//
+void ST_drawNumFontY2(int x, int y, int num)
+{
+    if(!num)
+        V_DrawPatch(x, y, invfonty[0]);
+
+    if(num < 0)
+        num = 0;
+
+    while(num)
+    {
+        V_DrawPatchDirect(x, y, invfonty[num % 10]);
+        x -= SHORT(invfonty[0]->width) + 1;
+        num /= 10;
+    }
+}
+
 void ST_doRefresh(void)
 {
     st_firsttime = false;
@@ -759,9 +892,9 @@
     // haleyjd 09/01/10: STRIFE-TODO: work out statbar details
 
     // If just after ST_Start(), refresh all
-    if (st_firsttime) ST_doRefresh();
+    /*if (st_firsttime)*/ ST_doRefresh();
     // Otherwise, update as little as possible
-    else ST_diffDraw();
+    /*else*/ ST_diffDraw();
 }
 
 //
@@ -780,11 +913,12 @@
     }
     else
     {
-        // STRIFE-TODO:
-        // ST_drawNumFontY2(15, 194, plyr->health);
-        // v5 = weaponinfo[plyr->readyweapon].ammo;
-        // if (v5 != am_noammo)
-        //     ST_drawNumFontY2(310, 194, plyr->ammo[v5]);
+        ammotype_t ammo;
+
+        ST_drawNumFontY2(15, 194, plyr->health);
+        ammo = weaponinfo[plyr->readyweapon].ammo;
+        if (ammo != am_noammo)
+            ST_drawNumFontY2(310, 194, plyr->ammo[ammo]);
     }
 
     if(!st_displaypopup)
@@ -822,8 +956,12 @@
         callback(namebuf, &invfonty[i]);
     }
 
-    // haleyjd 08/31/10: [STRIFE] 
-    // * No face - STRIFE-TODO: but there are similar color patches, which appear behind the armor in deathmatch...
+    // haleyjd 09/19/10: [STRIFE] 
+    // * No face, but there is this patch, which appears behind the armor
+    DEH_snprintf(namebuf, 9, "STBACK0%d", consoleplayer + 1);
+    if(netgame)
+        callback(namebuf, &stback);
+    
     // 09/01/10:
     // * Removed all unused DOOM stuff (arms, numbers, %, etc).
 
@@ -835,6 +973,7 @@
     callback(DEH_String("INVPOP2"),  &invpop2);
     callback(DEH_String("INVPBAK"),  &invpbak);
     callback(DEH_String("INVPBAK2"), &invpbak2);
+    callback(DEH_String("INVCURS"),  &invcursor);
 }
 
 static void ST_loadCallback(char *lumpname, patch_t **variable)
@@ -1003,7 +1142,7 @@
 void ST_Stop (void)
 {
     if (st_stopped)
-	return;
+        return;
 
     I_SetPalette (W_CacheLumpNum (lu_palette, PU_CACHE));
 
@@ -1013,6 +1152,8 @@
 void ST_Init (void)
 {
     ST_loadData();
-    st_backing_screen = (byte *) Z_Malloc(ST_WIDTH * ST_HEIGHT, PU_STATIC, 0);
+
+    // haleyjd 09/19/10: This is not used by Strife. More memory for voices!
+    //st_backing_screen = (byte *) Z_Malloc(ST_WIDTH * ST_HEIGHT, PU_STATIC, 0);
 }