shithub: choc

Download patch

ref: 87185424769c6c2dd8207f0b63dc787f98011496
parent: 546efd64b71ff3935e2068f2e0dbf950e7a7dd03
author: James Haley <[email protected]>
date: Wed Sep 1 02:48:16 EDT 2010

Started work on status bar, including loading and drawing some of the
background graphics. Added ST_DrawExternal routine and corresponding
call logic in D_Display for drawing popups and other bits that are
outside the normal statbar. Moved automap mapname widget up 7 pixels.
Needs verification via screenshots.

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

--- a/src/strife/d_main.c
+++ b/src/strife/d_main.c
@@ -178,6 +178,7 @@
 //
 // haleyjd 08/23/10: [STRIFE]:
 // * Changes to eliminate intermission and change timing of screenwipe
+// * 9/01/10: Added ST_DrawExternal and popupactivestate static variable
 //
 gamestate_t     wipegamestate = GS_DEMOSCREEN;
 extern  boolean setsizeneeded;
@@ -189,6 +190,7 @@
     static  boolean             viewactivestate = false;
     static  boolean             menuactivestate = false;
     static  boolean             inhelpscreensstate = false;
+    static  boolean             popupactivestate = false; // [STRIFE]
     static  boolean             fullscreen = false;
     static  gamestate_t         oldgamestate = -1;
     static  int                 borderdrawcount;
@@ -267,16 +269,13 @@
     if (gamestate == GS_LEVEL && gametic)
     {
         HU_Drawer ();
-        // STRIFE-TODO: ST_DrawMore, unknown variable dword_861C8
-        /*
-        if(ST_DrawMore()) 
-            dword_861C8 = 1;
-        else if(dword_861C8)
+        if(ST_DrawExternal()) 
+            popupactivestate = true;
+        else if(popupactivestate)
         {
-            dword_861C8 = 0;
+            popupactivestate = false;
             menuactivestate = 1;
         }
-        */
     }
 
     // clean up border stuff
@@ -296,8 +295,7 @@
         if (menuactive || menuactivestate || !viewactivestate)
         {
             borderdrawcount = 3;
-            // STRIFE-FIXME / TODO: Unknown variable
-            // dword_861C8 = 0; 
+            popupactivestate = false;
         }
         if (borderdrawcount)
         {
--- a/src/strife/hu_stuff.c
+++ b/src/strife/hu_stuff.c
@@ -54,7 +54,9 @@
 #define HU_TITLE	(mapnames[gamemap-1])
 #define HU_TITLEHEIGHT	1
 #define HU_TITLEX	0
-#define HU_TITLEY	(167 - SHORT(hu_font[0]->height))
+
+// haleyjd 09/01/10: [STRIFE] 167 -> 160 to move up level name
+#define HU_TITLEY	(160 - SHORT(hu_font[0]->height))
 
 #define HU_INPUTTOGGLE	't'
 #define HU_INPUTX	HU_MSGX
--- a/src/strife/r_draw.c
+++ b/src/strife/r_draw.c
@@ -50,6 +50,7 @@
 #define MAXHEIGHT			832
 
 // status bar height at bottom of screen
+// haleyjd 08/31/10: Verified unmodified.
 #define SBARHEIGHT		32
 
 //
--- a/src/strife/st_stuff.c
+++ b/src/strife/st_stuff.c
@@ -72,64 +72,18 @@
 
 // Palette indices.
 // For damage/bonus red-/gold-shifts
-#define STARTREDPALS		1
-#define STARTBONUSPALS		9
-#define NUMREDPALS			8
-#define NUMBONUSPALS		4
+#define STARTREDPALS            1
+#define STARTBONUSPALS          9
+#define NUMREDPALS              8
+#define NUMBONUSPALS            4
 // Radiation suit, green shift.
-#define RADIATIONPAL		13
+#define RADIATIONPAL            13
 
-// N/256*100% probability
-//  that the normal face state will change
-#define ST_FACEPROBABILITY		96
-
-// For Responder
-#define ST_TOGGLECHAT		KEY_ENTER
-
 // Location of status bar
-#define ST_X				0
-#define ST_X2				104
+#define ST_X                    0
 
-#define ST_FX  			143
-#define ST_FY  			169
+#define ST_FX                   143
 
-// Should be set to patch width
-//  for tall numbers later on
-#define ST_TALLNUMWIDTH		(tallnum[0]->width)
-
-// Number of status faces.
-#define ST_NUMPAINFACES		5
-#define ST_NUMSTRAIGHTFACES	3
-#define ST_NUMTURNFACES		2
-#define ST_NUMSPECIALFACES		3
-
-#define ST_FACESTRIDE \
-          (ST_NUMSTRAIGHTFACES+ST_NUMTURNFACES+ST_NUMSPECIALFACES)
-
-#define ST_NUMEXTRAFACES		2
-
-#define ST_NUMFACES \
-          (ST_FACESTRIDE*ST_NUMPAINFACES+ST_NUMEXTRAFACES)
-
-#define ST_TURNOFFSET		(ST_NUMSTRAIGHTFACES)
-#define ST_OUCHOFFSET		(ST_TURNOFFSET + ST_NUMTURNFACES)
-#define ST_EVILGRINOFFSET		(ST_OUCHOFFSET + 1)
-#define ST_RAMPAGEOFFSET		(ST_EVILGRINOFFSET + 1)
-#define ST_GODFACE			(ST_NUMPAINFACES*ST_FACESTRIDE)
-#define ST_DEADFACE			(ST_GODFACE+1)
-
-#define ST_FACESX			143
-#define ST_FACESY			168
-
-#define ST_EVILGRINCOUNT		(2*TICRATE)
-#define ST_STRAIGHTFACECOUNT	(TICRATE/2)
-#define ST_TURNCOUNT		(1*TICRATE)
-#define ST_OUCHCOUNT		(1*TICRATE)
-#define ST_RAMPAGEDELAY		(2*TICRATE)
-
-#define ST_MUCHPAIN			20
-
-
 // Location and size of statistics,
 //  justified according to widget type.
 // Problem is, within which space? STbar? Screen?
@@ -241,79 +195,67 @@
 #define ST_DETHX			109
 #define ST_DETHY			191
 
-//Incoming messages window location
-//UNUSED
-// #define ST_MSGTEXTX	   (viewwindowx)
-// #define ST_MSGTEXTY	   (viewwindowy+viewheight-18)
-#define ST_MSGTEXTX			0
-#define ST_MSGTEXTY			0
 // Dimensions given in characters.
 #define ST_MSGWIDTH			52
-// Or shall I say, in lines?
-#define ST_MSGHEIGHT		1
 
-#define ST_OUTTEXTX			0
-#define ST_OUTTEXTY			6
-
-// Width, in characters again.
-#define ST_OUTWIDTH			52 
- // Height, in lines. 
-#define ST_OUTHEIGHT		1
-
-#define ST_MAPTITLEX \
-    (SCREENWIDTH - ST_MAPWIDTH * ST_CHATFONTWIDTH)
-
-#define ST_MAPTITLEY		0
-#define ST_MAPHEIGHT		1
-
 // graphics are drawn to a backing screen and blitted to the real screen
 byte                   *st_backing_screen;
 	    
 // main player in game
-static player_t*	plyr; 
+static player_t*        plyr; 
 
 // ST_Start() has just been called
-static boolean		st_firsttime;
+static boolean          st_firsttime;
 
 // lump number for PLAYPAL
-static int		lu_palette;
+static int              lu_palette;
 
 // used for timing
-static unsigned int	st_clock;
+static unsigned int     st_clock;
 
 // used for making messages go away
-static int		st_msgcounter=0;
+static int              st_msgcounter=0;
 
 // used when in chat 
-static st_chatstateenum_t	st_chatstate;
+static st_chatstateenum_t   st_chatstate;
 
 // whether in automap or first-person
-static st_stateenum_t	st_gamestate;
+static st_stateenum_t   st_gamestate;
 
 // whether left-side main status bar is active
-static boolean		st_statusbaron;
+static boolean          st_statusbaron;
 
 // whether status bar chat is active
-static boolean		st_chat;
+static boolean          st_chat;
 
 // value of st_chat before message popped up
-static boolean		st_oldchat;
+static boolean          st_oldchat;
 
 // whether chat window has the cursor on
-static boolean		st_cursoron;
+static boolean          st_cursoron;
 
 // !deathmatch
-static boolean		st_notdeathmatch; 
+static boolean          st_notdeathmatch; 
 
 // !deathmatch && st_statusbaron
-static boolean		st_armson;
+static boolean          st_armson;
 
 // !deathmatch
-static boolean		st_fragson; 
+static boolean          st_fragson; 
 
-// main bar left
-static patch_t*		sbar;
+// haleyjd 09/01/10: [STRIFE]
+// Whether or not a popup is currently displayed
+static boolean          st_displaypopup;
 
+// 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
+
 // 0-9, tall numbers
 static patch_t*		tallnum[10];
 
@@ -327,7 +269,8 @@
 static patch_t*		keys[NUMCARDS]; 
 
 // face status patches
-static patch_t*		faces[ST_NUMFACES];
+// haleyjd 08/31/10: [STRIFE] Removed faces
+//static patch_t*		faces[ST_NUMFACES];
 
 // face background
 static patch_t*		faceback;
@@ -380,8 +323,8 @@
 // used for evil grin
 static boolean	oldweaponsowned[NUMWEAPONS]; 
 
- // count until face changes
-static int	st_facecount = 0;
+// count until face changes
+//static int	st_facecount = 0;
 
 // current face index, used by w_faces
 static int	st_faceindex = 0;
@@ -390,7 +333,7 @@
 static int	keyboxes[3]; 
 
 // a random number per tick
-static int	st_randomnumber;  
+static int	st_randomnumber;
 
 cheatseq_t cheat_mus = CHEAT("idmus", 2);
 cheatseq_t cheat_god = CHEAT("iddqd", 0);
@@ -422,21 +365,21 @@
 
 void ST_refreshBackground(void)
 {
-
     if (st_statusbaron)
     {
         V_UseBuffer(st_backing_screen);
 
-	V_DrawPatch(ST_X, 0, sbar);
+        V_DrawPatch(ST_X, 0, invback);
 
-	if (netgame)
-	    V_DrawPatch(ST_FX, 0, faceback);
-
+        // haleyjd 09/01/10: STRIFE-TODO: status bar stuff
+        /*
+        if (netgame)
+            V_DrawPatch(ST_FX, 0, faceback);
+        */
         V_RestoreBuffer();
 
-	V_CopyRect(ST_X, 0, st_backing_screen, ST_WIDTH, ST_HEIGHT, ST_X, ST_Y);
+        V_CopyRect(ST_X, 0, st_backing_screen, ST_WIDTH, ST_HEIGHT, ST_X, ST_Y);
     }
-
 }
 
 
@@ -662,24 +605,13 @@
 }
 
 
-
+/*
 int ST_calcPainOffset(void)
 {
-    int		health;
-    static int	lastcalc;
-    static int	oldhealth = -1;
-    
-    health = plyr->health > 100 ? 100 : plyr->health;
-
-    if (health != oldhealth)
-    {
-	lastcalc = ST_FACESTRIDE * (((100 - health) * ST_NUMPAINFACES) / 101);
-	oldhealth = health;
-    }
-    return lastcalc;
+    // haleyjd 08/31/10: [STRIFE] Removed.
 }
+*/
 
-
 //
 // This is a not-very-pretty routine which handles
 //  the face states and their timing.
@@ -686,177 +618,12 @@
 // the precedence of expressions is:
 //  dead > evil grin > turned head > straight ahead
 //
+/*
 void ST_updateFaceWidget(void)
 {
-    int		i;
-    angle_t	badguyangle;
-    angle_t	diffang;
-    static int	lastattackdown = -1;
-    static int	priority = 0;
-    boolean	doevilgrin;
-
-    if (priority < 10)
-    {
-	// dead
-	if (!plyr->health)
-	{
-	    priority = 9;
-	    st_faceindex = ST_DEADFACE;
-	    st_facecount = 1;
-	}
-    }
-
-    if (priority < 9)
-    {
-	if (plyr->bonuscount)
-	{
-	    // picking up bonus
-	    doevilgrin = false;
-
-	    for (i=0;i<NUMWEAPONS;i++)
-	    {
-		if (oldweaponsowned[i] != plyr->weaponowned[i])
-		{
-		    doevilgrin = true;
-		    oldweaponsowned[i] = plyr->weaponowned[i];
-		}
-	    }
-	    if (doevilgrin) 
-	    {
-		// evil grin if just picked up weapon
-		priority = 8;
-		st_facecount = ST_EVILGRINCOUNT;
-		st_faceindex = ST_calcPainOffset() + ST_EVILGRINOFFSET;
-	    }
-	}
-
-    }
-  
-    if (priority < 8)
-    {
-	if (plyr->damagecount
-	    && plyr->attacker
-	    && plyr->attacker != plyr->mo)
-	{
-	    // being attacked
-	    priority = 7;
-	    
-	    if (plyr->health - st_oldhealth > ST_MUCHPAIN)
-	    {
-		st_facecount = ST_TURNCOUNT;
-		st_faceindex = ST_calcPainOffset() + ST_OUCHOFFSET;
-	    }
-	    else
-	    {
-		badguyangle = R_PointToAngle2(plyr->mo->x,
-					      plyr->mo->y,
-					      plyr->attacker->x,
-					      plyr->attacker->y);
-		
-		if (badguyangle > plyr->mo->angle)
-		{
-		    // whether right or left
-		    diffang = badguyangle - plyr->mo->angle;
-		    i = diffang > ANG180; 
-		}
-		else
-		{
-		    // whether left or right
-		    diffang = plyr->mo->angle - badguyangle;
-		    i = diffang <= ANG180; 
-		} // confusing, aint it?
-
-		
-		st_facecount = ST_TURNCOUNT;
-		st_faceindex = ST_calcPainOffset();
-		
-		if (diffang < ANG45)
-		{
-		    // head-on    
-		    st_faceindex += ST_RAMPAGEOFFSET;
-		}
-		else if (i)
-		{
-		    // turn face right
-		    st_faceindex += ST_TURNOFFSET;
-		}
-		else
-		{
-		    // turn face left
-		    st_faceindex += ST_TURNOFFSET+1;
-		}
-	    }
-	}
-    }
-  
-    if (priority < 7)
-    {
-	// getting hurt because of your own damn stupidity
-	if (plyr->damagecount)
-	{
-	    if (plyr->health - st_oldhealth > ST_MUCHPAIN)
-	    {
-		priority = 7;
-		st_facecount = ST_TURNCOUNT;
-		st_faceindex = ST_calcPainOffset() + ST_OUCHOFFSET;
-	    }
-	    else
-	    {
-		priority = 6;
-		st_facecount = ST_TURNCOUNT;
-		st_faceindex = ST_calcPainOffset() + ST_RAMPAGEOFFSET;
-	    }
-
-	}
-
-    }
-  
-    if (priority < 6)
-    {
-	// rapid firing
-	if (plyr->attackdown)
-	{
-	    if (lastattackdown==-1)
-		lastattackdown = ST_RAMPAGEDELAY;
-	    else if (!--lastattackdown)
-	    {
-		priority = 5;
-		st_faceindex = ST_calcPainOffset() + ST_RAMPAGEOFFSET;
-		st_facecount = 1;
-		lastattackdown = 1;
-	    }
-	}
-	else
-	    lastattackdown = -1;
-
-    }
-  
-    if (priority < 5)
-    {
-	// invulnerability
-	if ((plyr->cheats & CF_GODMODE)
-	    || plyr->powers[pw_invulnerability])
-	{
-	    priority = 4;
-
-	    st_faceindex = ST_GODFACE;
-	    st_facecount = 1;
-
-	}
-
-    }
-
-    // look left or look right if the facecount has timed out
-    if (!st_facecount)
-    {
-	st_faceindex = ST_calcPainOffset() + (st_randomnumber % 3);
-	st_facecount = ST_STRAIGHTFACECOUNT;
-	priority = 0;
-    }
-
-    st_facecount--;
-
+    // haleyjd 08/31/10: [STRIFE] Removed.
 }
+*/
 
 void ST_updateWidgets(void)
 {
@@ -896,8 +663,10 @@
     }
 
     // refresh everything if this is him coming back to life
-    ST_updateFaceWidget();
 
+    // haleyjd 08/31/10: [STRIFE] No face widget
+    //ST_updateFaceWidget();
+
     // used by the w_armsbg widget
     st_notdeathmatch = !deathmatch;
     
@@ -1036,21 +805,21 @@
 
 void ST_doRefresh(void)
 {
-
     st_firsttime = false;
 
     // draw status bar background to off-screen buff
     ST_refreshBackground();
 
+    // haleyjd 09/01/10: STRIFE-TODO: widgets!
     // and refresh all widgets
-    ST_drawWidgets(true);
-
+    //ST_drawWidgets(true);
 }
 
 void ST_diffDraw(void)
 {
+    // haleyjd 09/01/10: STRIFE-TODO: widgets!
     // update all widgets
-    ST_drawWidgets(false);
+    //ST_drawWidgets(false);
 }
 
 void ST_Drawer (boolean fullscreen, boolean refresh)
@@ -1061,15 +830,50 @@
     // Do red-/gold-shifts from damage/items
     ST_doPaletteStuff();
 
-    // haleyjd 08/31/10: STRIFE-TODO: disabled statbar drawing
-    /*
+    // haleyjd 09/01/10: STRIFE-TODO: work out statbar details
+
     // If just after ST_Start(), refresh all
     if (st_firsttime) ST_doRefresh();
     // Otherwise, update as little as possible
     else ST_diffDraw();
-    */
 }
 
+//
+// ST_DrawExternal
+//
+// haleyjd 09/01/10: [STRIFE] New function.
+// * Draws external portions of the status bar such the top bar and popups.
+//
+boolean ST_DrawExternal(void)
+{
+    if (st_statusbaron)
+    {
+        V_DrawPatchDirect(0, 160, invtop);
+        // STRIFE-TODO:
+        // STlib_drawNum2(&stru_DC750); // still unknown!
+        // STlib_drawNum2(&w_ready);
+    }
+    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]);
+    }
+
+    if(!st_displaypopup)
+        return false;
+
+    // STRIFE-TODO: Shitloads more stuff:
+    // * showobjective shit
+    // * keys/frags popup
+    // * weapons/ammo/stats popup
+    // * etc etc etc
+
+    return true;
+}
+
 typedef void (*load_callback_t)(char *lumpname, patch_t **variable); 
 
 // Iterates through all graphics to be loaded or unloaded, along with
@@ -1124,44 +928,20 @@
     }
 
     // face backgrounds for different color players
-    sprintf(namebuf, DEH_String("STFB%d"), consoleplayer);
-    callback(namebuf, &faceback);
+    // haleyjd 08/31/10: [STRIFE] No face - STRIFE-TODO: but there are similar 
+    // color patches, which appear behind the armor in deathmatch...
 
+    */
+    // haleyjd 09/01/10: [STRIFE] sbar -> invback
     // status bar background bits
-    callback(DEH_String("STBAR"), &sbar);
+    callback(DEH_String("INVBACK"),  &invback);
+    callback(DEH_String("INVTOP"),   &invtop);
+    callback(DEH_String("INVPOP"),   &invpop);
+    callback(DEH_String("INVPOP2"),  &invpop2);
+    callback(DEH_String("INVPBAK"),  &invpbak);
+    callback(DEH_String("INVPBAK2"), &invpbak2);
 
-    // face states
-    facenum = 0;
-    for (i=0; i<ST_NUMPAINFACES; i++)
-    {
-	for (j=0; j<ST_NUMSTRAIGHTFACES; j++)
-	{
-	    sprintf(namebuf, DEH_String("STFST%d%d"), i, j);
-            callback(namebuf, &faces[facenum]);
-            ++facenum;
-	}
-	sprintf(namebuf, DEH_String("STFTR%d0"), i);	// turn right
-        callback(namebuf, &faces[facenum]);
-        ++facenum;
-	sprintf(namebuf, DEH_String("STFTL%d0"), i);	// turn left
-        callback(namebuf, &faces[facenum]);
-        ++facenum;
-	sprintf(namebuf, DEH_String("STFOUCH%d"), i);	// ouch!
-        callback(namebuf, &faces[facenum]);
-        ++facenum;
-	sprintf(namebuf, DEH_String("STFEVL%d"), i);	// evil grin ;)
-        callback(namebuf, &faces[facenum]);
-        ++facenum;
-	sprintf(namebuf, DEH_String("STFKILL%d"), i);	// pissed off
-        callback(namebuf, &faces[facenum]);
-        ++facenum;
-    }
-
-    callback(DEH_String("STFGOD0"), &faces[facenum]);
-    ++facenum;
-    callback(DEH_String("STFDEAD0"), &faces[facenum]);
-    ++facenum;
-    */
+    // haleyjd 08/31/10: [STRIFE] No face.
 }
 
 static void ST_loadCallback(char *lumpname, patch_t **variable)
@@ -1283,12 +1063,7 @@
 		  ST_FRAGSWIDTH);
 
     // faces
-    STlib_initMultIcon(&w_faces,
-		       ST_FACESX,
-		       ST_FACESY,
-		       faces,
-		       &st_faceindex,
-		       &st_statusbaron);
+    // haleyjd 08/31/10: [STRIFE] No face.
 
     // armor percentage - should be colored later
     STlib_initPercent(&w_armor,
@@ -1393,14 +1168,12 @@
 
 void ST_Start (void)
 {
-
     if (!st_stopped)
-	ST_Stop();
+        ST_Stop();
 
     ST_initData();
     ST_createWidgets();
     st_stopped = false;
-
 }
 
 void ST_Stop (void)
--- a/src/strife/st_stuff.h
+++ b/src/strife/st_stuff.h
@@ -53,6 +53,11 @@
 // Called by main loop.
 void ST_Drawer (boolean fullscreen, boolean refresh);
 
+// haleyjd 09/01/10: [STRIFE] New function.
+// Called by main loop to draw external status bar bits.
+// Returns true if a popup is drawing.
+boolean ST_DrawExternal(void);
+
 // Called when the console player is spawned on each level.
 void ST_Start (void);