You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
147 lines
3.1 KiB
147 lines
3.1 KiB
//HEADER_GOES_HERE |
|
|
|
#include "../types.h" |
|
|
|
static unsigned char plr_msg_slot; |
|
_plrmsg plr_msgs[PMSG_COUNT]; |
|
|
|
const char text_color_from_player_num[MAX_PLRS + 1] = { COL_WHITE, COL_WHITE, COL_WHITE, COL_WHITE, COL_GOLD }; |
|
|
|
void __fastcall plrmsg_delay(BOOL delay) |
|
{ |
|
int i; |
|
_plrmsg *pMsg; |
|
static DWORD plrmsg_ticks; |
|
|
|
if (delay) { |
|
plrmsg_ticks = -GetTickCount(); |
|
return; |
|
} |
|
|
|
plrmsg_ticks += GetTickCount(); |
|
pMsg = plr_msgs; |
|
for (i = 0; i < PMSG_COUNT; i++, pMsg++) |
|
pMsg->time += plrmsg_ticks; |
|
} |
|
|
|
char *__fastcall ErrorPlrMsg(const char *pszMsg) |
|
{ |
|
char *result; |
|
_plrmsg *pMsg = &plr_msgs[plr_msg_slot]; |
|
plr_msg_slot = (plr_msg_slot + 1) & (PMSG_COUNT - 1); |
|
pMsg->player = MAX_PLRS; |
|
pMsg->time = GetTickCount(); |
|
result = strncpy(pMsg->str, pszMsg, sizeof(pMsg->str)); |
|
pMsg->str[sizeof(pMsg->str) - 1] = '\0'; |
|
return result; |
|
} |
|
|
|
size_t EventPlrMsg(const char *pszFmt, ...) |
|
{ |
|
_plrmsg *pMsg; |
|
va_list va; |
|
|
|
va_start(va, pszFmt); |
|
pMsg = &plr_msgs[plr_msg_slot]; |
|
plr_msg_slot = (plr_msg_slot + 1) & (PMSG_COUNT - 1); |
|
pMsg->player = MAX_PLRS; |
|
pMsg->time = GetTickCount(); |
|
vsprintf(pMsg->str, pszFmt, va); |
|
va_end(va); |
|
return strlen(pMsg->str); |
|
} |
|
|
|
void __fastcall SendPlrMsg(int pnum, const char *pszStr) |
|
{ |
|
_plrmsg *pMsg = &plr_msgs[plr_msg_slot]; |
|
plr_msg_slot = (plr_msg_slot + 1) & (PMSG_COUNT - 1); |
|
pMsg->player = pnum; |
|
pMsg->time = GetTickCount(); |
|
strlen(plr[pnum]._pName); /* these are used in debug */ |
|
strlen(pszStr); |
|
sprintf(pMsg->str, "%s (lvl %d): %s", plr[pnum]._pName, plr[pnum]._pLevel, pszStr); |
|
} |
|
|
|
void __cdecl ClearPlrMsg() |
|
{ |
|
int i; |
|
_plrmsg *pMsg = plr_msgs; |
|
DWORD tick = GetTickCount(); |
|
|
|
for (i = 0; i < PMSG_COUNT; i++, pMsg++) { |
|
if ((int)(tick - pMsg->time) > 10000) |
|
pMsg->str[0] = '\0'; |
|
} |
|
} |
|
|
|
void __cdecl InitPlrMsg() |
|
{ |
|
memset(plr_msgs, 0, sizeof(plr_msgs)); |
|
plr_msg_slot = 0; |
|
} |
|
|
|
void __cdecl DrawPlrMsg() |
|
{ |
|
int i; |
|
int x = 74; |
|
int y = 230; |
|
int width = 620; |
|
_plrmsg *pMsg; |
|
|
|
if (chrflag || questlog) { |
|
if (invflag || sbookflag) |
|
return; |
|
x = 394; |
|
width = 300; |
|
} else if (invflag || sbookflag) |
|
width = 300; |
|
|
|
pMsg = plr_msgs; |
|
for (i = 0; i < 8; i++) { |
|
if (pMsg->str[0]) |
|
PrintPlrMsg(x, y, width, pMsg->str, text_color_from_player_num[pMsg->player]); |
|
pMsg++; |
|
y += 35; |
|
} |
|
} |
|
|
|
void __fastcall PrintPlrMsg(unsigned int x, unsigned int y, unsigned int width, const char *str, unsigned char col) |
|
{ |
|
int line = 0; |
|
|
|
while (*str) { |
|
unsigned char c; |
|
int screen = screen_y_times_768[y] + x; |
|
const char *sstr = str; |
|
unsigned int len = 0; |
|
const char *endstr = sstr; |
|
|
|
while (1) { |
|
if (*sstr) { |
|
c = fontidx[(unsigned char)*sstr++]; |
|
c = fontframe[c]; |
|
len += fontkern[c] + 1; |
|
if (!c) // allow wordwrap on blank glyph |
|
endstr = sstr; |
|
else if (len >= width) |
|
break; |
|
} else { |
|
endstr = sstr; |
|
break; |
|
} |
|
} |
|
|
|
while (str < endstr) { |
|
c = fontidx[(unsigned char)*str++]; |
|
c = fontframe[c]; |
|
if (c) |
|
CPrintString(screen, c, col); |
|
screen += fontkern[c] + 1; |
|
} |
|
|
|
y += 10; |
|
line++; |
|
if (line == 3) |
|
break; |
|
} |
|
}
|
|
|