diff options
author | James Haley | 2010-09-19 03:39:59 +0000 |
---|---|---|
committer | James Haley | 2010-09-19 03:39:59 +0000 |
commit | 9e82bacdd27648d9494b8d1e13c3c7e7245ece8f (patch) | |
tree | d6a4a51cec11c7f8e8706dd2dbb58f29af067e52 | |
parent | 0c880455f09096938c08fd232bc417c87d388f8a (diff) | |
download | chocolate-doom-9e82bacdd27648d9494b8d1e13c3c7e7245ece8f.tar.gz chocolate-doom-9e82bacdd27648d9494b8d1e13c3c7e7245ece8f.tar.bz2 chocolate-doom-9e82bacdd27648d9494b8d1e13c3c7e7245ece8f.zip |
Massive work on the HUD. Multiline messages now work properly and are
wrapped at or near the screen boundary.
Subversion-branch: /branches/strife-branch
Subversion-revision: 2113
-rw-r--r-- | src/m_controls.c | 3 | ||||
-rw-r--r-- | src/strife/d_main.c | 2 | ||||
-rw-r--r-- | src/strife/d_main.h | 1 | ||||
-rw-r--r-- | src/strife/hu_lib.c | 367 | ||||
-rw-r--r-- | src/strife/hu_stuff.c | 591 | ||||
-rw-r--r-- | src/strife/hu_stuff.h | 21 |
6 files changed, 628 insertions, 357 deletions
diff --git a/src/m_controls.c b/src/m_controls.c index b3d5dc21..409f26bf 100644 --- a/src/m_controls.c +++ b/src/m_controls.c @@ -256,6 +256,9 @@ void M_BindHexenControls(void) void M_BindStrifeControls(void) { + // These are shared with all games, but have different defaults: + key_message_refresh = '/'; + // These keys are shared with Heretic/Hexen but have different defaults: key_jump = 'a'; key_lookup = KEY_PGUP; diff --git a/src/strife/d_main.c b/src/strife/d_main.c index 0555ca56..76eb5112 100644 --- a/src/strife/d_main.c +++ b/src/strife/d_main.c @@ -1225,7 +1225,7 @@ static void D_Endoom(void) // haleyjd 08/28/10: Clip patches to the framebuffer without errors. // Returns false if V_DrawPatch should return without drawing. // -static boolean D_PatchClipCallback(patch_t *patch, int x, int y) +boolean D_PatchClipCallback(patch_t *patch, int x, int y) { // note that offsets were already accounted for in V_DrawPatch return (x >= 0 && y >= 0 diff --git a/src/strife/d_main.h b/src/strife/d_main.h index a9272401..d2d9ee13 100644 --- a/src/strife/d_main.h +++ b/src/strife/d_main.h @@ -58,6 +58,5 @@ extern boolean isdemoversion; // haleyjd [STRIFE] extern boolean stonecold; // villsa [STRIFE] extern boolean workparm; // villsa [STRIFE] - #endif diff --git a/src/strife/hu_lib.c b/src/strife/hu_lib.c index c7c62d06..dee1dbea 100644 --- a/src/strife/hu_lib.c +++ b/src/strife/hu_lib.c @@ -35,16 +35,82 @@ #include "hu_lib.h" #include "r_local.h" #include "r_draw.h" +#include "hu_stuff.h" // [STRIFE] // boolean : whether the screen is always erased #define noterased viewwindowx extern boolean automapactive; // in AM_map.c +extern boolean D_PatchClipCallback(patch_t *patch, int x, int y); // [STRIFE] + +extern patch_t* yfont[HU_FONTSIZE]; // haleyjd 09/18/10: [STRIFE] + +// +// HUlib_drawYellowText +// +// haleyjd 09/18/10: [STRIFE] New function. +// +void HUlib_drawYellowText(int x, int y, char *text) +{ + int start_x = x; + char *rover = text; + char c; + + while((c = *rover++)) + { + if(c == '\n') + { + x = start_x; + y += 12; + } + else if(c == '_' || c != ' ' || x != start_x) + { + c = toupper(c) - HU_FONTSTART; + + if(c >= 0 && c < HU_FONTSIZE) + { + patch_t *patch = yfont[c]; + int width = SHORT(patch->width); + + if(x + width <= (SCREENWIDTH - 20)) + { + // haleyjd: STRIFE-TODO: bit different than the exe... for now + if(!D_PatchClipCallback(patch, x + SHORT(patch->leftoffset), + y + SHORT(patch->topoffset))) + return; + V_DrawPatchDirect(x, y, patch); + x = x + width; + } + else + { + x = start_x; + --rover; + y += 12; + } + } + else + { + x += 4; + } + } + } +} + +// +// HUlib_init +// +// [STRIFE] Verified unmodified. +// void HUlib_init(void) { } +// +// HUlib_clearTextLine +// +// [STRIFE] Verified unmodified. +// void HUlib_clearTextLine(hu_textline_t* t) { t->len = 0; @@ -52,13 +118,18 @@ void HUlib_clearTextLine(hu_textline_t* t) t->needsupdate = true; } +// +// HUlib_initTextLine +// +// [STRIFE] Verified unmodified +// void HUlib_initTextLine -( hu_textline_t* t, - int x, - int y, - patch_t** f, - int sc ) +( hu_textline_t* t, + int x, + int y, + patch_t** f, + int sc ) { t->x = x; t->y = y; @@ -67,125 +138,142 @@ HUlib_initTextLine HUlib_clearTextLine(t); } +// +// HUlib_addCharToTextLine +// +// [STRIFE] Verified unmodified. +// boolean HUlib_addCharToTextLine -( hu_textline_t* t, - char ch ) +( hu_textline_t* t, + char ch ) { - if (t->len == HU_MAXLINELENGTH) - return false; + return false; else { - t->l[t->len++] = ch; - t->l[t->len] = 0; - t->needsupdate = 4; - return true; + t->l[t->len++] = ch; + t->l[t->len] = 0; + t->needsupdate = 4; + return true; } - } +// +// HUlib_delCharFromTextLine +// +// [STRIFE] Verified unmodified. +// boolean HUlib_delCharFromTextLine(hu_textline_t* t) { - if (!t->len) return false; else { - t->l[--t->len] = 0; - t->needsupdate = 4; - return true; + t->l[--t->len] = 0; + t->needsupdate = 4; + return true; } - } +// +// HUlib_drawTextLine +// +// haleyjd 09/18/10: [STRIFE] Modified to not draw underscores in text. +// void HUlib_drawTextLine -( hu_textline_t* l, - boolean drawcursor ) +( hu_textline_t* l, + boolean drawcursor ) { - - int i; - int w; - int x; - unsigned char c; + int i; + int w; + int x; + unsigned char c; // draw the new stuff x = l->x; - for (i=0;i<l->len;i++) + + for(i = 0; i < l->len; i++) { - c = toupper(l->l[i]); - if (c != ' ' - && c >= l->sc - && c <= '_') - { - w = SHORT(l->f[c - l->sc]->width); - if (x+w > SCREENWIDTH) - break; - V_DrawPatchDirect(x, l->y, l->f[c - l->sc]); - x += w; - } - else - { - x += 4; - if (x >= SCREENWIDTH) - break; - } + c = toupper(l->l[i]); + if (c != ' ' && c >= l->sc && c < '_') // [STRIFE]: Underscores excluded + { + w = SHORT(l->f[c - l->sc]->width); + if (x+w > SCREENWIDTH) + break; + V_DrawPatchDirect(x, l->y, l->f[c - l->sc]); + x += w; + } + else + { + x += 4; + if (x >= SCREENWIDTH) + break; + } } // draw the cursor if requested if (drawcursor - && x + SHORT(l->f['_' - l->sc]->width) <= SCREENWIDTH) + && x + SHORT(l->f['_' - l->sc]->width) <= SCREENWIDTH) { - V_DrawPatchDirect(x, l->y, l->f['_' - l->sc]); + V_DrawPatchDirect(x, l->y, l->f['_' - l->sc]); } } - +// +// HUlib_eraseTextLine +// // sorta called by HU_Erase and just better darn get things straight +// +// [STRIFE] Verified unmodified. +// void HUlib_eraseTextLine(hu_textline_t* l) { - int lh; - int y; - int yoffset; - static boolean lastautomapactive = true; + int lh; + int y; + int yoffset; + static boolean lastautomapactive = true; // Only erases when NOT in automap and the screen is reduced, // and the text must either need updating or refreshing // (because of a recent change back from the automap) if (!automapactive && - viewwindowx && l->needsupdate) + viewwindowx && l->needsupdate) { - lh = SHORT(l->f[0]->height) + 1; - for (y=l->y,yoffset=y*SCREENWIDTH ; y<l->y+lh ; y++,yoffset+=SCREENWIDTH) - { - if (y < viewwindowy || y >= viewwindowy + viewheight) - R_VideoErase(yoffset, SCREENWIDTH); // erase entire line - else - { - R_VideoErase(yoffset, viewwindowx); // erase left border - R_VideoErase(yoffset + viewwindowx + viewwidth, viewwindowx); - // erase right border - } - } + lh = SHORT(l->f[0]->height) + 1; + for (y=l->y,yoffset=y*SCREENWIDTH ; y<l->y+lh ; y++,yoffset+=SCREENWIDTH) + { + if (y < viewwindowy || y >= viewwindowy + viewheight) + R_VideoErase(yoffset, SCREENWIDTH); // erase entire line + else + { + R_VideoErase(yoffset, viewwindowx); // erase left border + R_VideoErase(yoffset + viewwindowx + viewwidth, viewwindowx); + // erase right border + } + } } lastautomapactive = automapactive; if (l->needsupdate) l->needsupdate--; - } +// +// HUlib_initSText +// +// [STRIFE] Verified unmodified. +// void HUlib_initSText -( hu_stext_t* s, - int x, - int y, - int h, - patch_t** font, - int startchar, - boolean* on ) +( hu_stext_t* s, + int x, + int y, + int h, + patch_t** font, + int startchar, + boolean* on ) { - int i; s->h = h; @@ -193,28 +281,37 @@ HUlib_initSText s->laston = true; s->cl = 0; for (i=0;i<h;i++) - HUlib_initTextLine(&s->l[i], - x, y - i*(SHORT(font[0]->height)+1), - font, startchar); - + { + HUlib_initTextLine(&s->l[i], + x, y - i*(SHORT(font[0]->height)+1), + font, startchar); + } } +// +// HUlib_addLineToSText +// +// [STRIFE] Verified unmodified. +// void HUlib_addLineToSText(hu_stext_t* s) { - int i; // add a clear line if (++s->cl == s->h) - s->cl = 0; + s->cl = 0; HUlib_clearTextLine(&s->l[s->cl]); // everything needs updating for (i=0 ; i<s->h ; i++) - s->l[i].needsupdate = 4; - + s->l[i].needsupdate = 4; } +// +// HUlib_addMessageToSText +// +// [STRIFE] Verified unmodified. +// void HUlib_addMessageToSText ( hu_stext_t* s, @@ -223,59 +320,71 @@ HUlib_addMessageToSText { HUlib_addLineToSText(s); if (prefix) - while (*prefix) - HUlib_addCharToTextLine(&s->l[s->cl], *(prefix++)); + while (*prefix) + HUlib_addCharToTextLine(&s->l[s->cl], *(prefix++)); while (*msg) - HUlib_addCharToTextLine(&s->l[s->cl], *(msg++)); + HUlib_addCharToTextLine(&s->l[s->cl], *(msg++)); } +// +// HUlib_drawSText +// +// [STRIFE] Verified unmodified. +// void HUlib_drawSText(hu_stext_t* s) { int i, idx; hu_textline_t *l; if (!*s->on) - return; // if not on, don't draw + return; // if not on, don't draw // draw everything for (i=0 ; i<s->h ; i++) { - idx = s->cl - i; - if (idx < 0) - idx += s->h; // handle queue of lines - - l = &s->l[idx]; - - // need a decision made here on whether to skip the draw - HUlib_drawTextLine(l, false); // no cursor, please - } + idx = s->cl - i; + if (idx < 0) + idx += s->h; // handle queue of lines + + l = &s->l[idx]; + // need a decision made here on whether to skip the draw + HUlib_drawTextLine(l, false); // no cursor, please + } } +// +// HUlib_eraseSText +// +// [STRIFE] Verified unmodified. +// void HUlib_eraseSText(hu_stext_t* s) { - int i; for (i=0 ; i<s->h ; i++) { - if (s->laston && !*s->on) - s->l[i].needsupdate = 4; - HUlib_eraseTextLine(&s->l[i]); + if (s->laston && !*s->on) + s->l[i].needsupdate = 4; + HUlib_eraseTextLine(&s->l[i]); } s->laston = *s->on; - } +// +// HUlib_initIText +// +// [STRIFE] Verified unmodified. +// void HUlib_initIText -( hu_itext_t* it, - int x, - int y, - patch_t** font, - int startchar, - boolean* on ) +( hu_itext_t* it, + int x, + int y, + patch_t** font, + int startchar, + boolean* on ) { it->lm = 0; // default left margin is start of text it->on = on; @@ -285,37 +394,46 @@ HUlib_initIText // The following deletion routines adhere to the left margin restriction +// [STRIFE] Verified unmodified. void HUlib_delCharFromIText(hu_itext_t* it) { if (it->l.len != it->lm) - HUlib_delCharFromTextLine(&it->l); + HUlib_delCharFromTextLine(&it->l); } +// [STRIFE] Verified unmodified. void HUlib_eraseLineFromIText(hu_itext_t* it) { while (it->lm != it->l.len) - HUlib_delCharFromTextLine(&it->l); + HUlib_delCharFromTextLine(&it->l); } // Resets left margin as well +// [STRIFE] Verified unmodified. void HUlib_resetIText(hu_itext_t* it) { it->lm = 0; HUlib_clearTextLine(&it->l); } +// +// HUlib_addPrefixToIText +// +// [STRIFE] Verified unmodified. +// void HUlib_addPrefixToIText -( hu_itext_t* it, - char* str ) +( hu_itext_t* it, + char* str ) { while (*str) - HUlib_addCharToTextLine(&it->l, *(str++)); + HUlib_addCharToTextLine(&it->l, *(str++)); it->lm = it->l.len; } // wrapper function for handling general keyed input. // returns true if it ate the key +// [STRIFE] Verified unmodified. boolean HUlib_keyInIText ( hu_itext_t* it, @@ -324,33 +442,38 @@ HUlib_keyInIText ch = toupper(ch); if (ch >= ' ' && ch <= '_') - HUlib_addCharToTextLine(&it->l, (char) ch); - else - if (ch == KEY_BACKSPACE) - HUlib_delCharFromIText(it); - else - if (ch != KEY_ENTER) - return false; // did not eat key + HUlib_addCharToTextLine(&it->l, (char) ch); + else if (ch == KEY_BACKSPACE) + HUlib_delCharFromIText(it); + else if (ch != KEY_ENTER) + return false; // did not eat key return true; // ate the key - } +// +// HUlib_drawIText +// +// [STRIFE] Verified unmodified. +// void HUlib_drawIText(hu_itext_t* it) { - hu_textline_t *l = &it->l; if (!*it->on) - return; + return; HUlib_drawTextLine(l, true); // draw the line w/ cursor - } +// +// HUlib_eraseIText +// +// [STRIFE] Verified unmodified. +// void HUlib_eraseIText(hu_itext_t* it) { if (it->laston && !*it->on) - it->l.needsupdate = 4; + it->l.needsupdate = 4; HUlib_eraseTextLine(&it->l); it->laston = *it->on; } diff --git a/src/strife/hu_stuff.c b/src/strife/hu_stuff.c index 605c7b71..22d7b4f7 100644 --- a/src/strife/hu_stuff.c +++ b/src/strife/hu_stuff.c @@ -51,20 +51,18 @@ // // Locally used constants, shortcuts. // -#define HU_TITLE (mapnames[gamemap-1]) -#define HU_TITLEHEIGHT 1 -#define HU_TITLEX 0 +#define HU_TITLE (mapnames[gamemap-1]) +#define HU_TITLEHEIGHT 1 +#define HU_TITLEX 0 // 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 -#define HU_INPUTY (HU_MSGY + HU_MSGHEIGHT*(SHORT(hu_font[0]->height) +1)) -#define HU_INPUTWIDTH 64 -#define HU_INPUTHEIGHT 1 - +#define HU_TITLEY (160 - SHORT(hu_font[0]->height)) +#define HU_INPUTTOGGLE 't' +#define HU_INPUTX HU_MSGX +#define HU_INPUTY (HU_MSGY + HU_MSGHEIGHT*(SHORT(hu_font[0]->height) +1)) +#define HU_INPUTWIDTH 64 +#define HU_INPUTHEIGHT 1 char *chat_macros[10] = { @@ -81,7 +79,7 @@ char *chat_macros[10] = }; // villsa [STRIFE] -char* pnameprefixes[][16] = +char pnameprefixes[8][16] = { "1: ", "2: ", @@ -101,27 +99,30 @@ char* player_names[] = HUSTR_PLRRED }; -char chat_char; // remove later. -static player_t* plr; -patch_t* hu_font[HU_FONTSIZE]; -static hu_textline_t w_title; -boolean chat_on; -static hu_itext_t w_chat; -static boolean always_off = false; -static char chat_dest[MAXPLAYERS]; -static hu_itext_t w_inputbuffer[MAXPLAYERS]; +char chat_char; // remove later. +static player_t* plr; +patch_t* hu_font[HU_FONTSIZE]; +patch_t* yfont[HU_FONTSIZE]; // haleyjd 09/18/10: [STRIFE] +static hu_textline_t w_title; +boolean chat_on; +static hu_itext_t w_chat; +static boolean always_off = false; +static char chat_dest[MAXPLAYERS]; +static hu_itext_t w_inputbuffer[MAXPLAYERS]; + +static boolean message_on; +boolean message_dontfuckwithme; +static boolean message_nottobefuckedwith; -static boolean message_on; -boolean message_dontfuckwithme; -static boolean message_nottobefuckedwith; +static hu_stext_t w_message; +static int message_counter; -static hu_stext_t w_message; -static int message_counter; +extern int showMessages; +extern boolean automapactive; -extern int showMessages; -extern boolean automapactive; +static boolean headsupactive = false; -static boolean headsupactive = false; +static char * nickname; // haleyjd 09/18/10: [STRIFE] // // Builtin map names. @@ -180,9 +181,14 @@ char *mapnames[] = HUSTR_34 }; +// +// HU_Init +// +// haleyjd 09/18/10: [STRIFE] +// * Modified to load yfont along with hu_font. +// void HU_Init(void) { - int i; int j; char buffer[9]; @@ -191,25 +197,38 @@ void HU_Init(void) j = HU_FONTSTART; for (i=0;i<HU_FONTSIZE;i++) { - DEH_snprintf(buffer, 9, "STCFN%.3d", j++); - hu_font[i] = (patch_t *) W_CacheLumpName(buffer, PU_STATIC); - } + DEH_snprintf(buffer, 9, "STCFN%.3d", j++); + hu_font[i] = (patch_t *) W_CacheLumpName(buffer, PU_STATIC); + // haleyjd 09/18/10: load yfont as well; and yes, this is exactly + // how Rogue did it :P + buffer[2] = 'B'; + yfont[i] = (patch_t *) W_CacheLumpName(buffer, PU_STATIC); + } } +// +// HU_Stop +// +// [STRIFE] Verified unmodified. +// void HU_Stop(void) { headsupactive = false; } +// +// HU_Start +// +// haleyjd 09/18/10: [STRIFE] Added a hack for nickname at the end. +// void HU_Start(void) { - - int i; - char* s; + int i; + char* s; if (headsupactive) - HU_Stop(); + HU_Stop(); plr = &players[consoleplayer]; message_on = false; @@ -219,16 +238,15 @@ void HU_Start(void) // create the message widget HUlib_initSText(&w_message, - HU_MSGX, HU_MSGY, HU_MSGHEIGHT, - hu_font, - HU_FONTSTART, &message_on); + HU_MSGX, HU_MSGY, HU_MSGHEIGHT, + hu_font, + HU_FONTSTART, &message_on); // create the map title widget HUlib_initTextLine(&w_title, - HU_TITLEX, HU_TITLEY, - hu_font, - HU_FONTSTART); - + HU_TITLEX, HU_TITLEY, + hu_font, + HU_FONTSTART); // haleyjd 08/31/10: [STRIFE] Get proper map name. s = HU_TITLE; @@ -239,112 +257,223 @@ void HU_Start(void) s = DEH_String(s); while (*s) - HUlib_addCharToTextLine(&w_title, *(s++)); + HUlib_addCharToTextLine(&w_title, *(s++)); // create the chat widget HUlib_initIText(&w_chat, - HU_INPUTX, HU_INPUTY, - hu_font, - HU_FONTSTART, &chat_on); + HU_INPUTX, HU_INPUTY, + hu_font, + HU_FONTSTART, &chat_on); // create the inputbuffer widgets for (i=0 ; i<MAXPLAYERS ; i++) - HUlib_initIText(&w_inputbuffer[i], 0, 0, 0, 0, &always_off); + HUlib_initIText(&w_inputbuffer[i], 0, 0, 0, 0, &always_off); headsupactive = true; + // haleyjd 09/18/10: [STRIFE] nickname weirdness. + + // STRIFE-TODO: This shit crashes the game. + /* + if(nickname != pnameprefixes[consoleplayer]) + { + if(*nickname) + { + DEH_printf("have one\n"); + nickname = pnameprefixes[consoleplayer]; + } + } + */ } +// +// HU_Drawer +// +// [STRIFE] Verified unmodified. +// void HU_Drawer(void) { - HUlib_drawSText(&w_message); HUlib_drawIText(&w_chat); if (automapactive) - HUlib_drawTextLine(&w_title, false); - + HUlib_drawTextLine(&w_title, false); } +// +// HU_Erase +// +// [STRIFE] Verified unmodified. +// void HU_Erase(void) { - HUlib_eraseSText(&w_message); HUlib_eraseIText(&w_chat); HUlib_eraseTextLine(&w_title); +} +// +// HU_addMessage +// +// haleyjd 09/18/10: [STRIFE] New function +// See if you can tell whether or not I had trouble with this :P +// Looks to be extremely buggy, hackish, and error-prone. +// +// <Markov> This is definitely not the best that Rogue had to offer. Markov. +// +// Fastcall Registers: edx ebx +// Temp Registers: esi edi +void HU_addMessage(char *prefix, char *message) +{ + char c; // eax + int width = 0; // edx + char *rover1; // ebx (in first loop) + char *rover2; // ecx (in second loop) + char *bufptr; // ebx (in second loop) + char buffer[HU_MAXLINELENGTH+2]; // esp+52h + + // Loop 1: Total up width of prefix. + rover1 = prefix; + if(rover1) + { + while((c = *rover1)) + { + c = toupper(c) - HU_FONTSTART; + ++rover1; + + if(c < 0 || c >= HU_FONTSIZE) + width += 4; + else + width += SHORT(hu_font[c]->width); + } + } + + // Loop 2: Copy as much of message into buffer as will fit on screen + bufptr = buffer; + rover2 = message; + while((c = *rover2)) + { + if((c == ' ' || c == '-') && width > 285) + break; + + *bufptr = c; + ++bufptr; // BUG: No check for overflow. + ++rover2; + c = toupper(c); + + if(c == ' ' || c < '!' || c >= '_') + width += 4; + else + { + c -= HU_FONTSTART; + width += SHORT(hu_font[c]->width); + } + } + + // Too big to fit? + // BUG: doesn't consider by how much it's over. + if(width > 320) + { + // backup a char... hell if I know why. + --bufptr; + --rover2; + } + + // rover2 is not at the end? + if((c = *rover2)) + { + // if not ON a space... + if(c != ' ') + { + // back up both pointers til one is found. + // BUG: no check against LHS of buffer. Hurr! + while(*bufptr != ' ') + { + --bufptr; + --rover2; + } + } + } + + *bufptr = '\0'; + + // Add two message lines. + HUlib_addMessageToSText(&w_message, prefix, buffer); + HUlib_addMessageToSText(&w_message, NULL, rover2); } +// +// HU_Ticker +// +// haleyjd 09/18/10: [STRIFE] Changes to split up message into two lines, +// and support for player names (STRIFE-TODO: unfinished!) +// void HU_Ticker(void) { - int i, rc; char c; + //char *prefix; STRIFE-TODO // tick down message counter if message is up if (message_counter && !--message_counter) { - message_on = false; - message_nottobefuckedwith = false; + message_on = false; + message_nottobefuckedwith = false; } if (showMessages || message_dontfuckwithme) { - - // display message if necessary - if ((plr->message && !message_nottobefuckedwith) - || (plr->message && message_dontfuckwithme)) - { - HUlib_addMessageToSText(&w_message, 0, plr->message); - plr->message = 0; - message_on = true; - message_counter = HU_MSGTIMEOUT; - message_nottobefuckedwith = message_dontfuckwithme; - message_dontfuckwithme = 0; - } - + // display message if necessary + if ((plr->message && !message_nottobefuckedwith) + || (plr->message && message_dontfuckwithme)) + { + //HUlib_addMessageToSText(&w_message, 0, plr->message); + HU_addMessage(NULL, plr->message); // haleyjd [STRIFE] + plr->message = 0; + message_on = true; + message_counter = HU_MSGTIMEOUT; + message_nottobefuckedwith = message_dontfuckwithme; + message_dontfuckwithme = 0; + } } // else message_on = false; // check for incoming chat characters if (netgame) { - for (i=0 ; i<MAXPLAYERS; i++) - { - if (!playeringame[i]) - continue; - if (i != consoleplayer - && (c = players[i].cmd.chatchar)) - { - if (c <= HU_BROADCAST) - chat_dest[i] = c; - else - { - rc = HUlib_keyInIText(&w_inputbuffer[i], c); - if (rc && c == KEY_ENTER) - { - if (w_inputbuffer[i].l.len - && (chat_dest[i] == consoleplayer+1 - || chat_dest[i] == HU_BROADCAST)) - { - HUlib_addMessageToSText(&w_message, - DEH_String(player_names[i]), - w_inputbuffer[i].l.l); - - message_nottobefuckedwith = true; - message_on = true; - message_counter = HU_MSGTIMEOUT; - if ( gamemode == commercial ) - S_StartSound(0, sfx_radio); - else - S_StartSound(0, sfx_swish); // villsa [STRIFE] TODO - fix sounds - } - HUlib_resetIText(&w_inputbuffer[i]); - } - } - players[i].cmd.chatchar = 0; - } - } + for (i=0 ; i<MAXPLAYERS; i++) + { + if (!playeringame[i]) + continue; + if (i != consoleplayer + && (c = players[i].cmd.chatchar)) + { + if (c <= HU_BROADCAST) + chat_dest[i] = c; + else + { + rc = HUlib_keyInIText(&w_inputbuffer[i], c); + if (rc && c == KEY_ENTER) + { + if (w_inputbuffer[i].l.len + && (chat_dest[i] == consoleplayer+1 + || chat_dest[i] == HU_BROADCAST)) + { + // STRIFE-TODO: there is interaction with the player + // name prefixes array here... + HU_addMessage(DEH_String(player_names[i]), + w_inputbuffer[i].l.l); + + message_nottobefuckedwith = true; + message_on = true; + message_counter = HU_MSGTIMEOUT; + S_StartSound(0, sfx_radio); + } + HUlib_resetIText(&w_inputbuffer[i]); + } + } + players[i].cmd.chatchar = 0; + } + } } - } #define QUEUESIZE 128 @@ -353,165 +482,181 @@ static char chatchars[QUEUESIZE]; static int head = 0; static int tail = 0; - +// +// HU_queueChatChar +// +// haleyjd 09/18/10: [STRIFE] +// * No message is given if a chat queue overflow occurs. +// void HU_queueChatChar(char c) { - if (((head + 1) & (QUEUESIZE-1)) == tail) - { - plr->message = DEH_String(HUSTR_MSGU); - } - else + chatchars[head] = c; + if (((head + 1) & (QUEUESIZE-1)) != tail) { - chatchars[head] = c; - head = (head + 1) & (QUEUESIZE-1); + head = (head + 1) & (QUEUESIZE-1); } } +// +// HU_dequeueChatChar +// +// [STRIFE] Verified unmodified. +// char HU_dequeueChatChar(void) { char c; if (head != tail) { - c = chatchars[tail]; - tail = (tail + 1) & (QUEUESIZE-1); + c = chatchars[tail]; + tail = (tail + 1) & (QUEUESIZE-1); } else { - c = 0; + c = 0; } return c; } +// +// HU_Responder +// +// haleyjd 09/18/10: [STRIFE] +// * Mostly unmodified, except: +// - The default value of key_message_refresh is changed. That is handled +// elsewhere in Choco, however. +// - There is support for setting the player name through the chat +// mechanism. This is a STRIFE-TODO. +// boolean HU_Responder(event_t *ev) { - - static char lastmessage[HU_MAXLINELENGTH+1]; - char* macromessage; - boolean eatkey = false; - static boolean shiftdown = false; - static boolean altdown = false; - unsigned char c; - int i; - int numplayers; + static char lastmessage[HU_MAXLINELENGTH+1]; + char* macromessage; + boolean eatkey = false; + static boolean shiftdown = false; + static boolean altdown = false; + unsigned char c; + int i; + int numplayers; - static int num_nobrainers = 0; + static int num_nobrainers = 0; numplayers = 0; for (i=0 ; i<MAXPLAYERS ; i++) - numplayers += playeringame[i]; + numplayers += playeringame[i]; if (ev->data1 == KEY_RSHIFT) { - shiftdown = ev->type == ev_keydown; - return false; + shiftdown = ev->type == ev_keydown; + return false; } else if (ev->data1 == KEY_RALT || ev->data1 == KEY_LALT) { - altdown = ev->type == ev_keydown; - return false; + altdown = ev->type == ev_keydown; + return false; } if (ev->type != ev_keydown) - return false; + return false; if (!chat_on) { - if (ev->data1 == key_message_refresh) - { - message_on = true; - message_counter = HU_MSGTIMEOUT; - eatkey = true; - } - else if (netgame && ev->data2 == key_multi_msg) - { - eatkey = chat_on = true; - HUlib_resetIText(&w_chat); - HU_queueChatChar(HU_BROADCAST); - } - else if (netgame && numplayers > 2) - { - for (i=0; i<MAXPLAYERS ; i++) - { - if (ev->data2 == key_multi_msgplayer[i]) - { - if (playeringame[i] && i!=consoleplayer) - { - eatkey = chat_on = true; - HUlib_resetIText(&w_chat); - HU_queueChatChar(i+1); - break; - } - else if (i == consoleplayer) - { - num_nobrainers++; - if (num_nobrainers < 3) - plr->message = DEH_String(HUSTR_TALKTOSELF1); - else if (num_nobrainers < 6) - plr->message = DEH_String(HUSTR_TALKTOSELF2); - else if (num_nobrainers < 9) - plr->message = DEH_String(HUSTR_TALKTOSELF3); - else if (num_nobrainers < 32) - plr->message = DEH_String(HUSTR_TALKTOSELF4); - else - plr->message = DEH_String(HUSTR_TALKTOSELF5); - } - } - } - } + if (ev->data1 == key_message_refresh) + { + message_on = true; + message_counter = HU_MSGTIMEOUT; + eatkey = true; + } + else if (netgame && ev->data2 == key_multi_msg) + { + eatkey = chat_on = true; + HUlib_resetIText(&w_chat); + HU_queueChatChar(HU_BROADCAST); + } + else if (netgame && numplayers > 2) + { + // STRIFE-TODO: support for setting player names + + for (i=0; i<MAXPLAYERS ; i++) + { + if (ev->data2 == key_multi_msgplayer[i]) + { + if (playeringame[i] && i!=consoleplayer) + { + eatkey = chat_on = true; + HUlib_resetIText(&w_chat); + HU_queueChatChar(i+1); + break; + } + else if (i == consoleplayer) + { + num_nobrainers++; + if (num_nobrainers < 3) + plr->message = DEH_String(HUSTR_TALKTOSELF1); + else if (num_nobrainers < 6) + plr->message = DEH_String(HUSTR_TALKTOSELF2); + else if (num_nobrainers < 9) + plr->message = DEH_String(HUSTR_TALKTOSELF3); + else if (num_nobrainers < 32) + plr->message = DEH_String(HUSTR_TALKTOSELF4); + else + plr->message = DEH_String(HUSTR_TALKTOSELF5); + } + } + } + } } else { - c = ev->data2; - // send a macro - if (altdown) - { - c = c - '0'; - if (c > 9) - return false; - // fprintf(stderr, "got here\n"); - macromessage = chat_macros[c]; - - // kill last message with a '\n' - HU_queueChatChar(KEY_ENTER); // DEBUG!!! - - // send the macro message - while (*macromessage) - HU_queueChatChar(*macromessage++); - HU_queueChatChar(KEY_ENTER); - - // leave chat mode and notify that it was sent - chat_on = false; - strcpy(lastmessage, chat_macros[c]); - plr->message = lastmessage; - eatkey = true; - } - else - { - eatkey = HUlib_keyInIText(&w_chat, c); - if (eatkey) - { - // static unsigned char buf[20]; // DEBUG - HU_queueChatChar(c); - - // sprintf(buf, "KEY: %d => %d", ev->data1, c); - // plr->message = buf; - } - if (c == KEY_ENTER) - { - chat_on = false; - if (w_chat.l.len) - { - strcpy(lastmessage, w_chat.l.l); - plr->message = lastmessage; - } - } - else if (c == KEY_ESCAPE) - chat_on = false; - } + c = ev->data2; + // send a macro + if (altdown) + { + c = c - '0'; + if (c > 9) + return false; + // fprintf(stderr, "got here\n"); + macromessage = chat_macros[c]; + + // kill last message with a '\n' + HU_queueChatChar(KEY_ENTER); // DEBUG!!! + + // send the macro message + while (*macromessage) + HU_queueChatChar(*macromessage++); + HU_queueChatChar(KEY_ENTER); + + // leave chat mode and notify that it was sent + chat_on = false; + strcpy(lastmessage, chat_macros[c]); + plr->message = lastmessage; + eatkey = true; + } + else + { + eatkey = HUlib_keyInIText(&w_chat, c); + if (eatkey) + { + // static unsigned char buf[20]; // DEBUG + HU_queueChatChar(c); + + // sprintf(buf, "KEY: %d => %d", ev->data1, c); + // plr->message = buf; + } + if (c == KEY_ENTER) + { + chat_on = false; + if (w_chat.l.len) + { + strcpy(lastmessage, w_chat.l.l); + plr->message = lastmessage; + } + } + else if (c == KEY_ESCAPE) + chat_on = false; + } } return eatkey; - } diff --git a/src/strife/hu_stuff.h b/src/strife/hu_stuff.h index f5a0e53b..6986a143 100644 --- a/src/strife/hu_stuff.h +++ b/src/strife/hu_stuff.h @@ -31,20 +31,21 @@ // // Globally visible constants. // -#define HU_FONTSTART '!' // the first font characters -#define HU_FONTEND '_' // the last font characters +#define HU_FONTSTART '!' // the first font characters +#define HU_FONTEND '_' // the last font characters // Calculate # of glyphs in font. -#define HU_FONTSIZE (HU_FONTEND - HU_FONTSTART + 1) +#define HU_FONTSIZE (HU_FONTEND - HU_FONTSTART + 1) -#define HU_BROADCAST 5 +#define HU_BROADCAST 9 // haleyjd [STRIFE] Changed 5 -> 9 -#define HU_MSGX 0 -#define HU_MSGY 0 -#define HU_MSGWIDTH 64 // in characters -#define HU_MSGHEIGHT 1 // in lines +#define HU_MSGX 0 +#define HU_MSGY (SHORT(hu_font[0]->height) + 1) // [STRIFE]: DOOM bug fix +#define HU_MSGWIDTH 64 // in characters +#define HU_MSGHEIGHT 2 // in lines + +#define HU_MSGTIMEOUT (8*TICRATE) // haleyjd [STRIFE] Doubled message timeout -#define HU_MSGTIMEOUT (4*TICRATE) // // HEADS UP TEXT @@ -61,7 +62,7 @@ char HU_dequeueChatChar(void); void HU_Erase(void); extern char *chat_macros[10]; -extern char* pnameprefixes[][16]; // villsa [STRIFE] +extern char pnameprefixes[8][16]; // villsa [STRIFE] // haleyjd [STRIFE] externalized: extern char *mapnames[]; |