mirror of
https://git.do.srb2.org/KartKrew/Kart-Public.git
synced 2025-01-27 19:50:51 +00:00
Merge remote-tracking branch 'origin/next' into longdouble
This commit is contained in:
commit
62820bb4bf
35 changed files with 886 additions and 442 deletions
|
@ -36,7 +36,7 @@ jobs:
|
||||||
- v1-SRB2-APT
|
- v1-SRB2-APT
|
||||||
- run:
|
- run:
|
||||||
name: Install SDK
|
name: Install SDK
|
||||||
command: apt-get -qq -y --no-install-recommends install git build-essential nasm libpng12-dev:i386 libsdl2-mixer-dev:i386 libgme-dev:i386 gettext ccache wget gcc-multilib upx
|
command: apt-get -qq -y --no-install-recommends install git build-essential nasm libpng12-dev:i386 libsdl2-mixer-dev:i386 libgme-dev:i386 gettext ccache wget gcc-multilib upx openssh-client
|
||||||
- save_cache:
|
- save_cache:
|
||||||
key: v1-SRB2-APT
|
key: v1-SRB2-APT
|
||||||
paths:
|
paths:
|
||||||
|
|
|
@ -116,6 +116,7 @@ WFLAGS+=-Wfloat-equal
|
||||||
#WFLAGS+=-Wtraditional
|
#WFLAGS+=-Wtraditional
|
||||||
ifdef VCHELP
|
ifdef VCHELP
|
||||||
WFLAGS+=-Wdeclaration-after-statement
|
WFLAGS+=-Wdeclaration-after-statement
|
||||||
|
WFLAGS+=-Wno-error=declaration-after-statement
|
||||||
endif
|
endif
|
||||||
WFLAGS+=-Wundef
|
WFLAGS+=-Wundef
|
||||||
ifndef GCC295
|
ifndef GCC295
|
||||||
|
|
|
@ -93,6 +93,7 @@ static tic_t freezetimeout[MAXNETNODES]; // Until when can this node freeze the
|
||||||
UINT16 pingmeasurecount = 1;
|
UINT16 pingmeasurecount = 1;
|
||||||
UINT32 realpingtable[MAXPLAYERS]; //the base table of ping where an average will be sent to everyone.
|
UINT32 realpingtable[MAXPLAYERS]; //the base table of ping where an average will be sent to everyone.
|
||||||
UINT32 playerpingtable[MAXPLAYERS]; //table of player latency values.
|
UINT32 playerpingtable[MAXPLAYERS]; //table of player latency values.
|
||||||
|
tic_t servermaxping = 800; // server's max ping. Defaults to 800
|
||||||
#endif
|
#endif
|
||||||
SINT8 nodetoplayer[MAXNETNODES];
|
SINT8 nodetoplayer[MAXNETNODES];
|
||||||
SINT8 nodetoplayer2[MAXNETNODES]; // say the numplayer for this node if any (splitscreen)
|
SINT8 nodetoplayer2[MAXNETNODES]; // say the numplayer for this node if any (splitscreen)
|
||||||
|
@ -648,6 +649,8 @@ static inline void resynch_write_player(resynch_pak *rsp, const size_t i)
|
||||||
|
|
||||||
rsp->jointime = (tic_t)LONG(players[i].jointime);
|
rsp->jointime = (tic_t)LONG(players[i].jointime);
|
||||||
|
|
||||||
|
rsp->splitscreenindex = players[i].splitscreenindex;
|
||||||
|
|
||||||
rsp->hasmo = false;
|
rsp->hasmo = false;
|
||||||
//Transfer important mo information if the player has a body.
|
//Transfer important mo information if the player has a body.
|
||||||
//This lets us resync players even if they are dead.
|
//This lets us resync players even if they are dead.
|
||||||
|
@ -783,6 +786,8 @@ static void resynch_read_player(resynch_pak *rsp)
|
||||||
|
|
||||||
players[i].jointime = (tic_t)LONG(rsp->jointime);
|
players[i].jointime = (tic_t)LONG(rsp->jointime);
|
||||||
|
|
||||||
|
players[i].splitscreenindex = rsp->splitscreenindex;
|
||||||
|
|
||||||
//We get a packet for each player in game.
|
//We get a packet for each player in game.
|
||||||
if (!playeringame[i])
|
if (!playeringame[i])
|
||||||
return;
|
return;
|
||||||
|
@ -2727,7 +2732,10 @@ static void Command_Ban(void)
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if (server) // only the server is allowed to do this right now
|
if (server) // only the server is allowed to do this right now
|
||||||
|
{
|
||||||
Ban_Add(COM_Argv(2));
|
Ban_Add(COM_Argv(2));
|
||||||
|
D_SaveBan(); // save the ban list
|
||||||
|
}
|
||||||
|
|
||||||
if (COM_Argc() == 2)
|
if (COM_Argc() == 2)
|
||||||
{
|
{
|
||||||
|
@ -2758,6 +2766,42 @@ static void Command_Ban(void)
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void Command_BanIP(void)
|
||||||
|
{
|
||||||
|
if (COM_Argc() < 2)
|
||||||
|
{
|
||||||
|
CONS_Printf(M_GetText("banip <ip> <reason>: ban an ip address\n"));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (server) // Only the server can use this, otherwise does nothing.
|
||||||
|
{
|
||||||
|
const char *address = (COM_Argv(1));
|
||||||
|
const char *reason;
|
||||||
|
|
||||||
|
if (COM_Argc() == 2)
|
||||||
|
reason = NULL;
|
||||||
|
else
|
||||||
|
reason = COM_Argv(2);
|
||||||
|
|
||||||
|
|
||||||
|
if (I_SetBanAddress && I_SetBanAddress(address, NULL))
|
||||||
|
{
|
||||||
|
if (reason)
|
||||||
|
CONS_Printf("Banned IP address %s for: %s\n", address, reason);
|
||||||
|
else
|
||||||
|
CONS_Printf("Banned IP address %s\n", address);
|
||||||
|
|
||||||
|
Ban_Add(reason);
|
||||||
|
D_SaveBan();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
static void Command_Kick(void)
|
static void Command_Kick(void)
|
||||||
{
|
{
|
||||||
if (COM_Argc() < 2)
|
if (COM_Argc() < 2)
|
||||||
|
@ -3064,6 +3108,7 @@ void D_ClientServerInit(void)
|
||||||
COM_AddCommand("getplayernum", Command_GetPlayerNum);
|
COM_AddCommand("getplayernum", Command_GetPlayerNum);
|
||||||
COM_AddCommand("kick", Command_Kick);
|
COM_AddCommand("kick", Command_Kick);
|
||||||
COM_AddCommand("ban", Command_Ban);
|
COM_AddCommand("ban", Command_Ban);
|
||||||
|
COM_AddCommand("banip", Command_BanIP);
|
||||||
COM_AddCommand("clearbans", Command_ClearBans);
|
COM_AddCommand("clearbans", Command_ClearBans);
|
||||||
COM_AddCommand("showbanlist", Command_ShowBan);
|
COM_AddCommand("showbanlist", Command_ShowBan);
|
||||||
COM_AddCommand("reloadbans", Command_ReloadBan);
|
COM_AddCommand("reloadbans", Command_ReloadBan);
|
||||||
|
@ -3318,6 +3363,8 @@ static void Got_AddPlayer(UINT8 **p, INT32 playernum)
|
||||||
addedtogame = true;
|
addedtogame = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
players[newplayernum].splitscreenindex = splitscreenplayer;
|
||||||
|
|
||||||
if (netgame)
|
if (netgame)
|
||||||
{
|
{
|
||||||
if (server && cv_showjoinaddress.value)
|
if (server && cv_showjoinaddress.value)
|
||||||
|
@ -4355,10 +4402,12 @@ FILESTAMP
|
||||||
//Update client ping table from the server.
|
//Update client ping table from the server.
|
||||||
if (client)
|
if (client)
|
||||||
{
|
{
|
||||||
INT32 i;
|
UINT8 i;
|
||||||
for (i = 0; i < MAXPLAYERS; i++)
|
for (i = 0; i < MAXPLAYERS; i++)
|
||||||
if (playeringame[i])
|
if (playeringame[i])
|
||||||
playerpingtable[i] = (tic_t)netbuffer->u.pingtable[i];
|
playerpingtable[i] = (tic_t)netbuffer->u.pingtable[i];
|
||||||
|
|
||||||
|
servermaxping = (tic_t)netbuffer->u.pingtable[MAXPLAYERS];
|
||||||
}
|
}
|
||||||
|
|
||||||
break;
|
break;
|
||||||
|
@ -5001,6 +5050,18 @@ void TryRunTics(tic_t realtics)
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef NEWPING
|
#ifdef NEWPING
|
||||||
|
|
||||||
|
/* Ping Update except better:
|
||||||
|
We call this once per second and check for people's pings. If their ping happens to be too high, we increment some timer and kick them out.
|
||||||
|
If they're not lagging, decrement the timer by 1. Of course, reset all of this if they leave.
|
||||||
|
|
||||||
|
Why do we do that? Well, I'm a person with unfortunately sometimes unstable internet and happen to keep getting kicked very unconveniently for very short high spikes. (700+ ms)
|
||||||
|
Because my spikes are so high, the average ping is exponentially higher too (700s really add up...!) which leads me to getting kicked for a short burst of spiking.
|
||||||
|
With this change here, this doesn't happen anymore as it checks if my ping has been CONSISTENTLY bad for long enough before killing me.
|
||||||
|
*/
|
||||||
|
|
||||||
|
static INT32 pingtimeout[MAXPLAYERS];
|
||||||
|
|
||||||
static inline void PingUpdate(void)
|
static inline void PingUpdate(void)
|
||||||
{
|
{
|
||||||
INT32 i;
|
INT32 i;
|
||||||
|
@ -5021,6 +5082,9 @@ static inline void PingUpdate(void)
|
||||||
laggers[i] = true;
|
laggers[i] = true;
|
||||||
numlaggers++;
|
numlaggers++;
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
pingtimeout[i] = 0;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//kick lagging players... unless everyone but the server's ping sucks.
|
//kick lagging players... unless everyone but the server's ping sucks.
|
||||||
|
@ -5031,12 +5095,20 @@ static inline void PingUpdate(void)
|
||||||
{
|
{
|
||||||
if (playeringame[i] && laggers[i])
|
if (playeringame[i] && laggers[i])
|
||||||
{
|
{
|
||||||
XBOXSTATIC char buf[2];
|
pingtimeout[i]++;
|
||||||
|
if (pingtimeout[i] > cv_pingtimeout.value) // ok your net has been bad for too long, you deserve to die.
|
||||||
|
{
|
||||||
|
XBOXSTATIC char buf[2];
|
||||||
|
|
||||||
buf[0] = (char)i;
|
pingtimeout[i] = 0;
|
||||||
buf[1] = KICK_MSG_PING_HIGH;
|
|
||||||
SendNetXCmd(XD_KICK, &buf, 2);
|
buf[0] = (char)i;
|
||||||
|
buf[1] = KICK_MSG_PING_HIGH;
|
||||||
|
SendNetXCmd(XD_KICK, &buf, 2);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
else // you aren't lagging, but you aren't free yet. In case you'll keep spiking, we just make the timer go back down. (Very unstable net must still get kicked).
|
||||||
|
pingtimeout[i] = (pingtimeout[i] == 0 ? 0 : pingtimeout[i]-1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -5051,10 +5123,13 @@ static inline void PingUpdate(void)
|
||||||
realpingtable[i] = 0; //Reset each as we go.
|
realpingtable[i] = 0; //Reset each as we go.
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// send the server's maxping as last element of our ping table. This is useful to let us know when we're about to get kicked.
|
||||||
|
netbuffer->u.pingtable[MAXPLAYERS] = cv_maxping.value;
|
||||||
|
|
||||||
//send out our ping packets
|
//send out our ping packets
|
||||||
for (i = 0; i < MAXNETNODES; i++)
|
for (i = 0; i < MAXNETNODES; i++)
|
||||||
if (nodeingame[i])
|
if (nodeingame[i])
|
||||||
HSendPacket(i, true, 0, sizeof(INT32) * MAXPLAYERS);
|
HSendPacket(i, true, 0, sizeof(INT32) * (MAXPLAYERS+1));
|
||||||
|
|
||||||
pingmeasurecount = 1; //Reset count
|
pingmeasurecount = 1; //Reset count
|
||||||
}
|
}
|
||||||
|
@ -5068,7 +5143,7 @@ static void UpdatePingTable(void)
|
||||||
INT32 i;
|
INT32 i;
|
||||||
if (server)
|
if (server)
|
||||||
{
|
{
|
||||||
if (netgame && !(gametime % 255))
|
if (netgame && !(gametime % 35)) // update once per second.
|
||||||
PingUpdate();
|
PingUpdate();
|
||||||
// update node latency values so we can take an average later.
|
// update node latency values so we can take an average later.
|
||||||
for (i = 0; i < MAXPLAYERS; i++)
|
for (i = 0; i < MAXPLAYERS; i++)
|
||||||
|
|
|
@ -283,6 +283,8 @@ typedef struct
|
||||||
|
|
||||||
tic_t jointime;
|
tic_t jointime;
|
||||||
|
|
||||||
|
UINT8 splitscreenindex;
|
||||||
|
|
||||||
//player->mo stuff
|
//player->mo stuff
|
||||||
UINT8 hasmo; // Boolean
|
UINT8 hasmo; // Boolean
|
||||||
|
|
||||||
|
@ -450,10 +452,10 @@ typedef struct
|
||||||
serverrefuse_pak serverrefuse; // 65025 bytes (somehow I feel like those values are garbage...)
|
serverrefuse_pak serverrefuse; // 65025 bytes (somehow I feel like those values are garbage...)
|
||||||
askinfo_pak askinfo; // 61 bytes
|
askinfo_pak askinfo; // 61 bytes
|
||||||
msaskinfo_pak msaskinfo; // 22 bytes
|
msaskinfo_pak msaskinfo; // 22 bytes
|
||||||
plrinfo playerinfo[MAXPLAYERS]; // 1152 bytes (I'd say 36~38)
|
plrinfo playerinfo[MAXPLAYERS]; // 576 bytes(?)
|
||||||
plrconfig playerconfig[MAXPLAYERS]; // (up to) 896 bytes (welp they ARE)
|
plrconfig playerconfig[MAXPLAYERS]; // (up to) 528 bytes(?)
|
||||||
#ifdef NEWPING
|
#ifdef NEWPING
|
||||||
UINT32 pingtable[MAXPLAYERS]; // 128 bytes
|
UINT32 pingtable[MAXPLAYERS+1]; // 68 bytes
|
||||||
#endif
|
#endif
|
||||||
} u; // This is needed to pack diff packet types data together
|
} u; // This is needed to pack diff packet types data together
|
||||||
} ATTRPACK doomdata_t;
|
} ATTRPACK doomdata_t;
|
||||||
|
@ -519,6 +521,7 @@ extern tic_t jointimeout;
|
||||||
extern UINT16 pingmeasurecount;
|
extern UINT16 pingmeasurecount;
|
||||||
extern UINT32 realpingtable[MAXPLAYERS];
|
extern UINT32 realpingtable[MAXPLAYERS];
|
||||||
extern UINT32 playerpingtable[MAXPLAYERS];
|
extern UINT32 playerpingtable[MAXPLAYERS];
|
||||||
|
extern tic_t servermaxping;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
extern consvar_t
|
extern consvar_t
|
||||||
|
|
|
@ -19,7 +19,7 @@
|
||||||
#define __D_NET__
|
#define __D_NET__
|
||||||
|
|
||||||
// Max computers in a game
|
// Max computers in a game
|
||||||
#define MAXNETNODES 16
|
#define MAXNETNODES (MAXPLAYERS+4)
|
||||||
#define BROADCASTADDR MAXNETNODES
|
#define BROADCASTADDR MAXNETNODES
|
||||||
#define MAXSPLITSCREENPLAYERS 4 // Max number of players on a single computer
|
#define MAXSPLITSCREENPLAYERS 4 // Max number of players on a single computer
|
||||||
#define NETSPLITSCREEN // Kart's splitscreen netgame feature
|
#define NETSPLITSCREEN // Kart's splitscreen netgame feature
|
||||||
|
|
|
@ -378,6 +378,7 @@ consvar_t cv_kartdebughuddrop = {"kartdebughuddrop", "Off", CV_NETVAR|CV_CHEAT|C
|
||||||
|
|
||||||
consvar_t cv_kartdebugcheckpoint = {"kartdebugcheckpoint", "Off", CV_NOSHOWHELP, CV_OnOff, NULL, 0, NULL, NULL, 0, 0, NULL};
|
consvar_t cv_kartdebugcheckpoint = {"kartdebugcheckpoint", "Off", CV_NOSHOWHELP, CV_OnOff, NULL, 0, NULL, NULL, 0, 0, NULL};
|
||||||
consvar_t cv_kartdebugnodes = {"kartdebugnodes", "Off", CV_NOSHOWHELP, CV_OnOff, NULL, 0, NULL, NULL, 0, 0, NULL};
|
consvar_t cv_kartdebugnodes = {"kartdebugnodes", "Off", CV_NOSHOWHELP, CV_OnOff, NULL, 0, NULL, NULL, 0, 0, NULL};
|
||||||
|
consvar_t cv_kartdebugcolorize = {"kartdebugcolorize", "Off", CV_NOSHOWHELP, CV_OnOff, NULL, 0, NULL, NULL, 0, 0, NULL};
|
||||||
|
|
||||||
static CV_PossibleValue_t votetime_cons_t[] = {{10, "MIN"}, {3600, "MAX"}, {0, NULL}};
|
static CV_PossibleValue_t votetime_cons_t[] = {{10, "MIN"}, {3600, "MAX"}, {0, NULL}};
|
||||||
consvar_t cv_votetime = {"votetime", "20", CV_NETVAR, votetime_cons_t, NULL, 0, NULL, NULL, 0, 0, NULL};
|
consvar_t cv_votetime = {"votetime", "20", CV_NETVAR, votetime_cons_t, NULL, 0, NULL, NULL, 0, 0, NULL};
|
||||||
|
@ -435,6 +436,14 @@ consvar_t cv_jointimeout = {"jointimeout", "105", CV_CALL|CV_SAVE, nettimeout_co
|
||||||
#ifdef NEWPING
|
#ifdef NEWPING
|
||||||
static CV_PossibleValue_t maxping_cons_t[] = {{0, "MIN"}, {1000, "MAX"}, {0, NULL}};
|
static CV_PossibleValue_t maxping_cons_t[] = {{0, "MIN"}, {1000, "MAX"}, {0, NULL}};
|
||||||
consvar_t cv_maxping = {"maxping", "800", CV_SAVE, maxping_cons_t, NULL, 0, NULL, NULL, 0, 0, NULL};
|
consvar_t cv_maxping = {"maxping", "800", CV_SAVE, maxping_cons_t, NULL, 0, NULL, NULL, 0, 0, NULL};
|
||||||
|
|
||||||
|
static CV_PossibleValue_t pingtimeout_cons_t[] = {{8, "MIN"}, {120, "MAX"}, {0, NULL}};
|
||||||
|
consvar_t cv_pingtimeout = {"pingtimeout", "10", CV_SAVE, pingtimeout_cons_t, NULL, 0, NULL, NULL, 0, 0, NULL};
|
||||||
|
|
||||||
|
// show your ping on the HUD next to framerate. Defaults to warning only (shows up if your ping is > maxping)
|
||||||
|
static CV_PossibleValue_t showping_cons_t[] = {{0, "Off"}, {1, "Always"}, {2, "Warning"}, {0, NULL}};
|
||||||
|
consvar_t cv_showping = {"showping", "Warning", CV_SAVE, showping_cons_t, NULL, 0, NULL, NULL, 0, 0, NULL};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
// Intermission time Tails 04-19-2002
|
// Intermission time Tails 04-19-2002
|
||||||
static CV_PossibleValue_t inttime_cons_t[] = {{0, "MIN"}, {3600, "MAX"}, {0, NULL}};
|
static CV_PossibleValue_t inttime_cons_t[] = {{0, "MIN"}, {3600, "MAX"}, {0, NULL}};
|
||||||
|
@ -664,6 +673,8 @@ void D_RegisterServerCommands(void)
|
||||||
CV_RegisterVar(&cv_sleep);
|
CV_RegisterVar(&cv_sleep);
|
||||||
#ifdef NEWPING
|
#ifdef NEWPING
|
||||||
CV_RegisterVar(&cv_maxping);
|
CV_RegisterVar(&cv_maxping);
|
||||||
|
CV_RegisterVar(&cv_pingtimeout);
|
||||||
|
CV_RegisterVar(&cv_showping);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef SEENAMES
|
#ifdef SEENAMES
|
||||||
|
|
|
@ -126,7 +126,7 @@ extern consvar_t cv_karteliminatelast;
|
||||||
extern consvar_t cv_votetime;
|
extern consvar_t cv_votetime;
|
||||||
|
|
||||||
extern consvar_t cv_kartdebugitem, cv_kartdebugamount, cv_kartdebugshrink, cv_kartdebugdistribution, cv_kartdebughuddrop;
|
extern consvar_t cv_kartdebugitem, cv_kartdebugamount, cv_kartdebugshrink, cv_kartdebugdistribution, cv_kartdebughuddrop;
|
||||||
extern consvar_t cv_kartdebugcheckpoint, cv_kartdebugnodes;
|
extern consvar_t cv_kartdebugcheckpoint, cv_kartdebugnodes, cv_kartdebugcolorize;
|
||||||
|
|
||||||
extern consvar_t cv_itemfinder;
|
extern consvar_t cv_itemfinder;
|
||||||
|
|
||||||
|
@ -145,6 +145,8 @@ extern consvar_t cv_specialrings, cv_powerstones, cv_matchboxes, cv_competitionb
|
||||||
|
|
||||||
#ifdef NEWPING
|
#ifdef NEWPING
|
||||||
extern consvar_t cv_maxping;
|
extern consvar_t cv_maxping;
|
||||||
|
extern consvar_t cv_pingtimeout;
|
||||||
|
extern consvar_t cv_showping;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
extern consvar_t cv_skipmapcheck;
|
extern consvar_t cv_skipmapcheck;
|
||||||
|
|
|
@ -571,6 +571,8 @@ typedef struct player_s
|
||||||
UINT8 bot;
|
UINT8 bot;
|
||||||
|
|
||||||
tic_t jointime; // Timer when player joins game to change skin/color
|
tic_t jointime; // Timer when player joins game to change skin/color
|
||||||
|
|
||||||
|
UINT8 splitscreenindex;
|
||||||
#ifdef HWRENDER
|
#ifdef HWRENDER
|
||||||
fixed_t fovadd; // adjust FOV for hw rendering
|
fixed_t fovadd; // adjust FOV for hw rendering
|
||||||
#endif
|
#endif
|
||||||
|
|
211
src/dehacked.c
211
src/dehacked.c
|
@ -8134,89 +8134,136 @@ static const char *const ML_LIST[16] = {
|
||||||
// This DOES differ from r_draw's Color_Names, unfortunately.
|
// This DOES differ from r_draw's Color_Names, unfortunately.
|
||||||
// Also includes Super colors
|
// Also includes Super colors
|
||||||
static const char *COLOR_ENUMS[] = { // Rejigged for Kart.
|
static const char *COLOR_ENUMS[] = { // Rejigged for Kart.
|
||||||
"NONE", // 00 // SKINCOLOR_NONE
|
"NONE", // SKINCOLOR_NONE
|
||||||
"WHITE", // 01 // SKINCOLOR_WHITE
|
"WHITE", // SKINCOLOR_WHITE
|
||||||
"SILVER", // 02 // SKINCOLOR_SILVER
|
"SILVER", // SKINCOLOR_SILVER
|
||||||
"GREY", // 03 // SKINCOLOR_GREY
|
"GREY", // SKINCOLOR_GREY
|
||||||
"NICKEL", // 04 // SKINCOLOR_NICKEL
|
"NICKEL", // SKINCOLOR_NICKEL
|
||||||
"BLACK", // 05 // SKINCOLOR_BLACK
|
"BLACK", // SKINCOLOR_BLACK
|
||||||
"SEPIA", // 06 // SKINCOLOR_SEPIA
|
"SEPIA", // SKINCOLOR_SEPIA
|
||||||
"BEIGE", // 07 // SKINCOLOR_BEIGE
|
"BEIGE", // SKINCOLOR_BEIGE
|
||||||
"BROWN", // 08 // SKINCOLOR_BROWN
|
"BROWN", // SKINCOLOR_BROWN
|
||||||
"LEATHER", // 09 // SKINCOLOR_LEATHER
|
"LEATHER", // SKINCOLOR_LEATHER
|
||||||
"SALMON", // 10 // SKINCOLOR_SALMON
|
"SALMON", // SKINCOLOR_SALMON
|
||||||
"PINK", // 11 // SKINCOLOR_PINK
|
"PINK", // SKINCOLOR_PINK
|
||||||
"ROSE", // 12 // SKINCOLOR_ROSE
|
"ROSE", // SKINCOLOR_ROSE
|
||||||
"RUBY", // 13 // SKINCOLOR_RUBY
|
"RUBY", // SKINCOLOR_RUBY
|
||||||
"RASPBERRY", // 14 // SKINCOLOR_RASPBERRY
|
"RASPBERRY", // SKINCOLOR_RASPBERRY
|
||||||
"RED", // 15 // SKINCOLOR_RED
|
"CHERRY", // SKINCOLOR_CHERRY
|
||||||
"CRIMSON", // 16 // SKINCOLOR_CRIMSON
|
"RED", // SKINCOLOR_RED
|
||||||
"KETCHUP", // 17 // SKINCOLOR_KETCHUP
|
"SCARLET", // SKINCOLOR_SCARLET
|
||||||
"DAWN", // 18 // SKINCOLOR_DAWN
|
"CRIMSON", // SKINCOLOR_CRIMSON
|
||||||
"CREAMSICLE", // 19 // SKINCOLOR_CREAMSICLE
|
"NOVA", // SKINCOLOR_NOVA
|
||||||
"ORANGE", // 20 // SKINCOLOR_ORANGE
|
"KETCHUP", // SKINCOLOR_KETCHUP
|
||||||
"PUMPKIN", // 21 // SKINCOLOR_PUMPKIN
|
"DAWN", // SKINCOLOR_DAWN
|
||||||
"ROSEWOOD", // 22 // SKINCOLOR_ROSEWOOD
|
"CREAMSICLE", // SKINCOLOR_CREAMSICLE
|
||||||
"BURGUNDY", // 23 // SKINCOLOR_BURGUNDY
|
"ORANGE", // SKINCOLOR_ORANGE
|
||||||
"TANGERINE", // 24 // SKINCOLOR_TANGERINE
|
"PUMPKIN", // SKINCOLOR_PUMPKIN
|
||||||
"PEACH", // 25 // SKINCOLOR_PEACH
|
"ROSEWOOD", // SKINCOLOR_ROSEWOOD
|
||||||
"CARAMEL", // 26 // SKINCOLOR_CARAMEL
|
"BURGUNDY", // SKINCOLOR_BURGUNDY
|
||||||
"GOLD", // 27 // SKINCOLOR_GOLD
|
"TANGERINE", // SKINCOLOR_TANGERINE
|
||||||
"BRONZE", // 28 // SKINCOLOR_BRONZE
|
"PEACH", // SKINCOLOR_PEACH
|
||||||
"YELLOW", // 29 // SKINCOLOR_YELLOW
|
"CARAMEL", // SKINCOLOR_CARAMEL
|
||||||
"MUSTARD", // 30 // SKINCOLOR_MUSTARD
|
"CREAM", // SKINCOLOR_CREAM
|
||||||
"OLIVE", // 31 // SKINCOLOR_OLIVE
|
"GOLD", // SKINCOLOR_GOLD
|
||||||
"VOMIT", // 32 // SKINCOLOR_VOMIT
|
"BRONZE", // SKINCOLOR_BRONZE
|
||||||
"GARDEN", // 33 // SKINCOLOR_GARDEN
|
"COPPER", // SKINCOLOR_COPPER
|
||||||
"LIME", // 34 // SKINCOLOR_LIME
|
"YELLOW", // SKINCOLOR_YELLOW
|
||||||
"TEA", // 35 // SKINCOLOR_TEA
|
"MUSTARD", // SKINCOLOR_MUSTARD
|
||||||
"PISTACHIO", // 36 // SKINCOLOR_PISTACHIO
|
"OLIVE", // SKINCOLOR_OLIVE
|
||||||
"ROBOHOOD", // 37 // SKINCOLOR_ROBOHOOD
|
"VOMIT", // SKINCOLOR_VOMIT
|
||||||
"MOSS", // 38 // SKINCOLOR_MOSS
|
"GARDEN", // SKINCOLOR_GARDEN
|
||||||
"MINT", // 39 // SKINCOLOR_MINT
|
"LIME", // SKINCOLOR_LIME
|
||||||
"GREEN", // 40 // SKINCOLOR_GREEN
|
"HANDHELD", // SKINCOLOR_HANDHELD
|
||||||
"PINETREE", // 41 // SKINCOLOR_PINETREE
|
"TEA", // SKINCOLOR_TEA
|
||||||
"EMERALD", // 42 // SKINCOLOR_EMERALD
|
"PISTACHIO", // SKINCOLOR_PISTACHIO
|
||||||
"SWAMP", // 43 // SKINCOLOR_SWAMP
|
"ROBOHOOD", // SKINCOLOR_ROBOHOOD
|
||||||
"DREAM", // 44 // SKINCOLOR_DREAM
|
"MOSS", // SKINCOLOR_MOSS
|
||||||
"AQUA", // 45 // SKINCOLOR_AQUA
|
"MINT", // SKINCOLOR_MINT
|
||||||
"TEAL", // 46 // SKINCOLOR_TEAL
|
"GREEN", // SKINCOLOR_GREEN
|
||||||
"CYAN", // 47 // SKINCOLOR_CYAN
|
"PINETREE", // SKINCOLOR_PINETREE
|
||||||
"JAWZ", // 48 // SKINCOLOR_JAWZ
|
"EMERALD", // SKINCOLOR_EMERALD
|
||||||
"CERULEAN", // 49 // SKINCOLOR_CERULEAN
|
"SWAMP", // SKINCOLOR_SWAMP
|
||||||
"NAVY", // 50 // SKINCOLOR_NAVY
|
"DREAM", // SKINCOLOR_DREAM
|
||||||
"SLATE", // 51 // SKINCOLOR_SLATE
|
"ALGAE", // SKINCOLOR_ALGAE
|
||||||
"STEEL", // 52 // SKINCOLOR_STEEL
|
"AQUA", // SKINCOLOR_AQUA
|
||||||
"JET", // 53 // SKINCOLOR_JET
|
"TEAL", // SKINCOLOR_TEAL
|
||||||
"SAPPHIRE", // 54 // SKINCOLOR_SAPPHIRE
|
"CYAN", // SKINCOLOR_CYAN
|
||||||
"PERIWINKLE", // 55 // SKINCOLOR_PERIWINKLE
|
"JAWZ", // SKINCOLOR_JAWZ
|
||||||
"BLUE", // 56 // SKINCOLOR_BLUE
|
"CERULEAN", // SKINCOLOR_CERULEAN
|
||||||
"BLUEBERRY", // 57 // SKINCOLOR_BLUEBERRY
|
"NAVY", // SKINCOLOR_NAVY
|
||||||
"DUSK", // 58 // SKINCOLOR_DUSK
|
"SLATE", // SKINCOLOR_SLATE
|
||||||
"PURPLE", // 59 // SKINCOLOR_PURPLE
|
"STEEL", // SKINCOLOR_STEEL
|
||||||
"LAVENDER", // 60 // SKINCOLOR_LAVENDER
|
"JET", // SKINCOLOR_JET
|
||||||
"BYZANTIUM", // 61 // SKINCOLOR_BYZANTIUM
|
"SAPPHIRE", // SKINCOLOR_SAPPHIRE
|
||||||
"POMEGRANATE", // 62 // SKINCOLOR_POMEGRANATE
|
"PERIWINKLE", // SKINCOLOR_PERIWINKLE
|
||||||
"LILAC", // 63 // SKINCOLOR_LILAC
|
"BLUE", // SKINCOLOR_BLUE
|
||||||
|
"BLUEBERRY", // SKINCOLOR_BLUEBERRY
|
||||||
|
"PASTEL", // SKINCOLOR_PASTEL
|
||||||
|
"DUSK", // SKINCOLOR_DUSK
|
||||||
|
"PURPLE", // SKINCOLOR_PURPLE
|
||||||
|
"FUCHSIA", // SKINCOLOR_FUCHSIA
|
||||||
|
"TOXIC", // SKINCOLOR_TOXIC
|
||||||
|
"LAVENDER", // SKINCOLOR_LAVENDER
|
||||||
|
"BYZANTIUM", // SKINCOLOR_BYZANTIUM
|
||||||
|
"POMEGRANATE", // SKINCOLOR_POMEGRANATE
|
||||||
|
"LILAC", // SKINCOLOR_LILAC
|
||||||
|
|
||||||
// Super special awesome Super flashing colors!
|
// Special super colors
|
||||||
"SUPER1", // SKINCOLOR_SUPER1
|
// Super Sonic Yellow
|
||||||
"SUPER2", // SKINCOLOR_SUPER2,
|
"SUPER1", // SKINCOLOR_SUPER1
|
||||||
"SUPER3", // SKINCOLOR_SUPER3,
|
"SUPER2", // SKINCOLOR_SUPER2,
|
||||||
"SUPER4", // SKINCOLOR_SUPER4,
|
"SUPER3", // SKINCOLOR_SUPER3,
|
||||||
"SUPER5", // SKINCOLOR_SUPER5,
|
"SUPER4", // SKINCOLOR_SUPER4,
|
||||||
// Super Tails
|
"SUPER5", // SKINCOLOR_SUPER5,
|
||||||
"TSUPER1", // SKINCOLOR_TSUPER1,
|
// Super Tails Orange
|
||||||
"TSUPER2", // SKINCOLOR_TSUPER2,
|
"TSUPER1", // SKINCOLOR_TSUPER1,
|
||||||
"TSUPER3", // SKINCOLOR_TSUPER3,
|
"TSUPER2", // SKINCOLOR_TSUPER2,
|
||||||
"TSUPER4", // SKINCOLOR_TSUPER4,
|
"TSUPER3", // SKINCOLOR_TSUPER3,
|
||||||
"TSUPER5", // SKINCOLOR_TSUPER5,
|
"TSUPER4", // SKINCOLOR_TSUPER4,
|
||||||
// Super Knuckles
|
"TSUPER5", // SKINCOLOR_TSUPER5,
|
||||||
"KSUPER1", // SKINCOLOR_KSUPER1,
|
// Super Knuckles Red
|
||||||
"KSUPER2", // SKINCOLOR_KSUPER2,
|
"KSUPER1", // SKINCOLOR_KSUPER1,
|
||||||
"KSUPER3", // SKINCOLOR_KSUPER3,
|
"KSUPER2", // SKINCOLOR_KSUPER2,
|
||||||
"KSUPER4", // SKINCOLOR_KSUPER4,
|
"KSUPER3", // SKINCOLOR_KSUPER3,
|
||||||
"KSUPER5" // SKINCOLOR_KSUPER5,
|
"KSUPER4", // SKINCOLOR_KSUPER4,
|
||||||
|
"KSUPER5", // SKINCOLOR_KSUPER5,
|
||||||
|
// Hyper Sonic Pink
|
||||||
|
"PSUPER1", // SKINCOLOR_PSUPER1,
|
||||||
|
"PSUPER2", // SKINCOLOR_PSUPER2,
|
||||||
|
"PSUPER3", // SKINCOLOR_PSUPER3,
|
||||||
|
"PSUPER4", // SKINCOLOR_PSUPER4,
|
||||||
|
"PSUPER5", // SKINCOLOR_PSUPER5,
|
||||||
|
// Hyper Sonic Blue
|
||||||
|
"BSUPER1", // SKINCOLOR_BSUPER1,
|
||||||
|
"BSUPER2", // SKINCOLOR_BSUPER2,
|
||||||
|
"BSUPER3", // SKINCOLOR_BSUPER3,
|
||||||
|
"BSUPER4", // SKINCOLOR_BSUPER4,
|
||||||
|
"BSUPER5" // SKINCOLOR_BSUPER5,
|
||||||
|
// Hyper Sonic Green
|
||||||
|
"GSUPER1", // SKINCOLOR_GSUPER1,
|
||||||
|
"GSUPER2", // SKINCOLOR_GSUPER2,
|
||||||
|
"GSUPER3", // SKINCOLOR_GSUPER3,
|
||||||
|
"GSUPER4", // SKINCOLOR_GSUPER4,
|
||||||
|
"GSUPER5", // SKINCOLOR_GSUPER5,
|
||||||
|
// Hyper Sonic White
|
||||||
|
"WSUPER1", // SKINCOLOR_WSUPER1,
|
||||||
|
"WSUPER2", // SKINCOLOR_WSUPER2,
|
||||||
|
"WSUPER3", // SKINCOLOR_WSUPER3,
|
||||||
|
"WSUPER4", // SKINCOLOR_WSUPER4,
|
||||||
|
"WSUPER5", // SKINCOLOR_WSUPER5,
|
||||||
|
// Creamy Super (Shadow?)
|
||||||
|
"CSUPER1", // SKINCOLOR_CSUPER1,
|
||||||
|
"CSUPER2", // SKINCOLOR_CSUPER2,
|
||||||
|
"CSUPER3", // SKINCOLOR_CSUPER3,
|
||||||
|
"CSUPER4", // SKINCOLOR_CSUPER4,
|
||||||
|
"CSUPER5", // SKINCOLOR_CSUPER5,
|
||||||
|
// Aqua Super
|
||||||
|
"ASUPER1", // SKINCOLOR_ASUPER1,
|
||||||
|
"ASUPER2", // SKINCOLOR_ASUPER2,
|
||||||
|
"ASUPER3", // SKINCOLOR_ASUPER3,
|
||||||
|
"ASUPER4", // SKINCOLOR_ASUPER4,
|
||||||
|
"ASUPER5" // SKINCOLOR_ASUPER5,
|
||||||
};
|
};
|
||||||
|
|
||||||
static const char *const POWERS_LIST[] = {
|
static const char *const POWERS_LIST[] = {
|
||||||
|
|
|
@ -94,6 +94,9 @@ void I_FinishUpdate (void)
|
||||||
if (cv_ticrate.value)
|
if (cv_ticrate.value)
|
||||||
SCR_DisplayTicRate();
|
SCR_DisplayTicRate();
|
||||||
|
|
||||||
|
if (cv_showping.value && netgame && consoleplayer != serverplayer)
|
||||||
|
SCR_DisplayLocalPing();
|
||||||
|
|
||||||
//blast it to the screen
|
//blast it to the screen
|
||||||
// this code sucks
|
// this code sucks
|
||||||
//memcpy(dascreen,screens[0],screenwidth*screenheight);
|
//memcpy(dascreen,screens[0],screenwidth*screenheight);
|
||||||
|
|
|
@ -265,8 +265,11 @@ typedef enum
|
||||||
SKINCOLOR_ROSE,
|
SKINCOLOR_ROSE,
|
||||||
SKINCOLOR_RUBY,
|
SKINCOLOR_RUBY,
|
||||||
SKINCOLOR_RASPBERRY,
|
SKINCOLOR_RASPBERRY,
|
||||||
|
SKINCOLOR_CHERRY,
|
||||||
SKINCOLOR_RED,
|
SKINCOLOR_RED,
|
||||||
|
SKINCOLOR_SCARLET,
|
||||||
SKINCOLOR_CRIMSON,
|
SKINCOLOR_CRIMSON,
|
||||||
|
SKINCOLOR_NOVA,
|
||||||
SKINCOLOR_KETCHUP,
|
SKINCOLOR_KETCHUP,
|
||||||
SKINCOLOR_DAWN,
|
SKINCOLOR_DAWN,
|
||||||
SKINCOLOR_CREAMSICLE,
|
SKINCOLOR_CREAMSICLE,
|
||||||
|
@ -277,14 +280,17 @@ typedef enum
|
||||||
SKINCOLOR_TANGERINE,
|
SKINCOLOR_TANGERINE,
|
||||||
SKINCOLOR_PEACH,
|
SKINCOLOR_PEACH,
|
||||||
SKINCOLOR_CARAMEL,
|
SKINCOLOR_CARAMEL,
|
||||||
|
SKINCOLOR_CREAM,
|
||||||
SKINCOLOR_GOLD,
|
SKINCOLOR_GOLD,
|
||||||
SKINCOLOR_BRONZE,
|
SKINCOLOR_BRONZE,
|
||||||
|
SKINCOLOR_COPPER,
|
||||||
SKINCOLOR_YELLOW,
|
SKINCOLOR_YELLOW,
|
||||||
SKINCOLOR_MUSTARD,
|
SKINCOLOR_MUSTARD,
|
||||||
SKINCOLOR_OLIVE,
|
SKINCOLOR_OLIVE,
|
||||||
SKINCOLOR_VOMIT,
|
SKINCOLOR_VOMIT,
|
||||||
SKINCOLOR_GARDEN,
|
SKINCOLOR_GARDEN,
|
||||||
SKINCOLOR_LIME,
|
SKINCOLOR_LIME,
|
||||||
|
SKINCOLOR_HANDHELD,
|
||||||
SKINCOLOR_TEA,
|
SKINCOLOR_TEA,
|
||||||
SKINCOLOR_PISTACHIO,
|
SKINCOLOR_PISTACHIO,
|
||||||
SKINCOLOR_ROBOHOOD,
|
SKINCOLOR_ROBOHOOD,
|
||||||
|
@ -295,6 +301,7 @@ typedef enum
|
||||||
SKINCOLOR_EMERALD,
|
SKINCOLOR_EMERALD,
|
||||||
SKINCOLOR_SWAMP,
|
SKINCOLOR_SWAMP,
|
||||||
SKINCOLOR_DREAM,
|
SKINCOLOR_DREAM,
|
||||||
|
SKINCOLOR_ALGAE,
|
||||||
SKINCOLOR_AQUA,
|
SKINCOLOR_AQUA,
|
||||||
SKINCOLOR_TEAL,
|
SKINCOLOR_TEAL,
|
||||||
SKINCOLOR_CYAN,
|
SKINCOLOR_CYAN,
|
||||||
|
@ -308,8 +315,11 @@ typedef enum
|
||||||
SKINCOLOR_PERIWINKLE,
|
SKINCOLOR_PERIWINKLE,
|
||||||
SKINCOLOR_BLUE,
|
SKINCOLOR_BLUE,
|
||||||
SKINCOLOR_BLUEBERRY,
|
SKINCOLOR_BLUEBERRY,
|
||||||
|
SKINCOLOR_PASTEL,
|
||||||
SKINCOLOR_DUSK,
|
SKINCOLOR_DUSK,
|
||||||
SKINCOLOR_PURPLE,
|
SKINCOLOR_PURPLE,
|
||||||
|
SKINCOLOR_FUCHSIA,
|
||||||
|
SKINCOLOR_TOXIC,
|
||||||
SKINCOLOR_LAVENDER,
|
SKINCOLOR_LAVENDER,
|
||||||
SKINCOLOR_BYZANTIUM,
|
SKINCOLOR_BYZANTIUM,
|
||||||
SKINCOLOR_POMEGRANATE,
|
SKINCOLOR_POMEGRANATE,
|
||||||
|
@ -319,26 +329,69 @@ typedef enum
|
||||||
MAXSKINCOLORS,
|
MAXSKINCOLORS,
|
||||||
|
|
||||||
// Super special awesome Super flashing colors!
|
// Super special awesome Super flashing colors!
|
||||||
|
// Super Sonic Yellow
|
||||||
SKINCOLOR_SUPER1 = MAXSKINCOLORS,
|
SKINCOLOR_SUPER1 = MAXSKINCOLORS,
|
||||||
SKINCOLOR_SUPER2,
|
SKINCOLOR_SUPER2,
|
||||||
SKINCOLOR_SUPER3,
|
SKINCOLOR_SUPER3,
|
||||||
SKINCOLOR_SUPER4,
|
SKINCOLOR_SUPER4,
|
||||||
SKINCOLOR_SUPER5,
|
SKINCOLOR_SUPER5,
|
||||||
|
|
||||||
// Super Tails
|
// Super Tails Orange
|
||||||
SKINCOLOR_TSUPER1,
|
SKINCOLOR_TSUPER1,
|
||||||
SKINCOLOR_TSUPER2,
|
SKINCOLOR_TSUPER2,
|
||||||
SKINCOLOR_TSUPER3,
|
SKINCOLOR_TSUPER3,
|
||||||
SKINCOLOR_TSUPER4,
|
SKINCOLOR_TSUPER4,
|
||||||
SKINCOLOR_TSUPER5,
|
SKINCOLOR_TSUPER5,
|
||||||
|
|
||||||
// Super Knuckles
|
// Super Knuckles Red
|
||||||
SKINCOLOR_KSUPER1,
|
SKINCOLOR_KSUPER1,
|
||||||
SKINCOLOR_KSUPER2,
|
SKINCOLOR_KSUPER2,
|
||||||
SKINCOLOR_KSUPER3,
|
SKINCOLOR_KSUPER3,
|
||||||
SKINCOLOR_KSUPER4,
|
SKINCOLOR_KSUPER4,
|
||||||
SKINCOLOR_KSUPER5,
|
SKINCOLOR_KSUPER5,
|
||||||
|
|
||||||
|
// Hyper Sonic Pink
|
||||||
|
SKINCOLOR_PSUPER1,
|
||||||
|
SKINCOLOR_PSUPER2,
|
||||||
|
SKINCOLOR_PSUPER3,
|
||||||
|
SKINCOLOR_PSUPER4,
|
||||||
|
SKINCOLOR_PSUPER5,
|
||||||
|
|
||||||
|
// Hyper Sonic Blue
|
||||||
|
SKINCOLOR_BSUPER1,
|
||||||
|
SKINCOLOR_BSUPER2,
|
||||||
|
SKINCOLOR_BSUPER3,
|
||||||
|
SKINCOLOR_BSUPER4,
|
||||||
|
SKINCOLOR_BSUPER5,
|
||||||
|
|
||||||
|
// Hyper Sonic Green
|
||||||
|
SKINCOLOR_GSUPER1,
|
||||||
|
SKINCOLOR_GSUPER2,
|
||||||
|
SKINCOLOR_GSUPER3,
|
||||||
|
SKINCOLOR_GSUPER4,
|
||||||
|
SKINCOLOR_GSUPER5,
|
||||||
|
|
||||||
|
// Hyper Sonic White
|
||||||
|
SKINCOLOR_WSUPER1,
|
||||||
|
SKINCOLOR_WSUPER2,
|
||||||
|
SKINCOLOR_WSUPER3,
|
||||||
|
SKINCOLOR_WSUPER4,
|
||||||
|
SKINCOLOR_WSUPER5,
|
||||||
|
|
||||||
|
// Creamy Super (Shadow?)
|
||||||
|
SKINCOLOR_CSUPER1,
|
||||||
|
SKINCOLOR_CSUPER2,
|
||||||
|
SKINCOLOR_CSUPER3,
|
||||||
|
SKINCOLOR_CSUPER4,
|
||||||
|
SKINCOLOR_CSUPER5,
|
||||||
|
|
||||||
|
// Aqua Super
|
||||||
|
SKINCOLOR_ASUPER1,
|
||||||
|
SKINCOLOR_ASUPER2,
|
||||||
|
SKINCOLOR_ASUPER3,
|
||||||
|
SKINCOLOR_ASUPER4,
|
||||||
|
SKINCOLOR_ASUPER5,
|
||||||
|
|
||||||
MAXTRANSLATIONS
|
MAXTRANSLATIONS
|
||||||
} skincolors_t;
|
} skincolors_t;
|
||||||
|
|
||||||
|
|
33
src/g_game.c
33
src/g_game.c
|
@ -2162,7 +2162,7 @@ void G_Ticker(boolean run)
|
||||||
G_CopyTiccmd(cmd, &netcmds[buf][i], 1);
|
G_CopyTiccmd(cmd, &netcmds[buf][i], 1);
|
||||||
|
|
||||||
// Use the leveltime sent in the player's ticcmd to determine control lag
|
// Use the leveltime sent in the player's ticcmd to determine control lag
|
||||||
cmd->latency = modeattacking ? 0 : min((leveltime & 0xFF) - cmd->latency, MAXPREDICTTICS-1); //@TODO add a cvar to allow setting this max
|
cmd->latency = modeattacking ? 0 : min(((leveltime & 0xFF) - cmd->latency) & 0xFF, MAXPREDICTTICS-1); //@TODO add a cvar to allow setting this max
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2357,6 +2357,7 @@ void G_PlayerReborn(INT32 player)
|
||||||
UINT8 skincolor;
|
UINT8 skincolor;
|
||||||
INT32 skin;
|
INT32 skin;
|
||||||
tic_t jointime;
|
tic_t jointime;
|
||||||
|
UINT8 splitscreenindex;
|
||||||
boolean spectator;
|
boolean spectator;
|
||||||
INT16 bot;
|
INT16 bot;
|
||||||
SINT8 pity;
|
SINT8 pity;
|
||||||
|
@ -2380,6 +2381,7 @@ void G_PlayerReborn(INT32 player)
|
||||||
ctfteam = players[player].ctfteam;
|
ctfteam = players[player].ctfteam;
|
||||||
exiting = players[player].exiting;
|
exiting = players[player].exiting;
|
||||||
jointime = players[player].jointime;
|
jointime = players[player].jointime;
|
||||||
|
splitscreenindex = players[player].splitscreenindex;
|
||||||
spectator = players[player].spectator;
|
spectator = players[player].spectator;
|
||||||
pflags = (players[player].pflags & (PF_TIMEOVER|PF_FLIPCAM|PF_TAGIT|PF_TAGGED|PF_ANALOGMODE|PF_WANTSTOJOIN));
|
pflags = (players[player].pflags & (PF_TIMEOVER|PF_FLIPCAM|PF_TAGIT|PF_TAGGED|PF_ANALOGMODE|PF_WANTSTOJOIN));
|
||||||
|
|
||||||
|
@ -2476,6 +2478,7 @@ void G_PlayerReborn(INT32 player)
|
||||||
p->pflags = pflags;
|
p->pflags = pflags;
|
||||||
p->ctfteam = ctfteam;
|
p->ctfteam = ctfteam;
|
||||||
p->jointime = jointime;
|
p->jointime = jointime;
|
||||||
|
p->splitscreenindex = splitscreenindex;
|
||||||
p->spectator = spectator;
|
p->spectator = spectator;
|
||||||
|
|
||||||
// save player config truth reborn
|
// save player config truth reborn
|
||||||
|
@ -4763,7 +4766,8 @@ void G_WriteGhostTic(mobj_t *ghost)
|
||||||
// GZT_XYZ is only useful if you've moved 256 FRACUNITS or more in a single tic.
|
// GZT_XYZ is only useful if you've moved 256 FRACUNITS or more in a single tic.
|
||||||
if (abs(ghost->x-oldghost.x) > MAXMOM
|
if (abs(ghost->x-oldghost.x) > MAXMOM
|
||||||
|| abs(ghost->y-oldghost.y) > MAXMOM
|
|| abs(ghost->y-oldghost.y) > MAXMOM
|
||||||
|| abs(ghost->z-oldghost.z) > MAXMOM)
|
|| abs(ghost->z-oldghost.z) > MAXMOM
|
||||||
|
|| (leveltime & 255) == 1) // Hack to enable slightly nicer resyncing
|
||||||
{
|
{
|
||||||
oldghost.x = ghost->x;
|
oldghost.x = ghost->x;
|
||||||
oldghost.y = ghost->y;
|
oldghost.y = ghost->y;
|
||||||
|
@ -4777,8 +4781,8 @@ void G_WriteGhostTic(mobj_t *ghost)
|
||||||
{
|
{
|
||||||
// For moving normally:
|
// For moving normally:
|
||||||
// Store one full byte of movement, plus one byte of fractional movement.
|
// Store one full byte of movement, plus one byte of fractional movement.
|
||||||
INT16 momx = (INT16)((ghost->x-oldghost.x)>>8);
|
INT16 momx = (INT16)((ghost->x-oldghost.x + (1<<4))>>8);
|
||||||
INT16 momy = (INT16)((ghost->y-oldghost.y)>>8);
|
INT16 momy = (INT16)((ghost->y-oldghost.y + (1<<4))>>8);
|
||||||
if (momx != oldghost.momx
|
if (momx != oldghost.momx
|
||||||
|| momy != oldghost.momy)
|
|| momy != oldghost.momy)
|
||||||
{
|
{
|
||||||
|
@ -4788,7 +4792,7 @@ void G_WriteGhostTic(mobj_t *ghost)
|
||||||
WRITEINT16(demo_p,momx);
|
WRITEINT16(demo_p,momx);
|
||||||
WRITEINT16(demo_p,momy);
|
WRITEINT16(demo_p,momy);
|
||||||
}
|
}
|
||||||
momx = (INT16)((ghost->z-oldghost.z)>>8);
|
momx = (INT16)((ghost->z-oldghost.z + (1<<4))>>8);
|
||||||
if (momx != oldghost.momz)
|
if (momx != oldghost.momz)
|
||||||
{
|
{
|
||||||
oldghost.momz = momx;
|
oldghost.momz = momx;
|
||||||
|
@ -4892,8 +4896,9 @@ void G_WriteGhostTic(mobj_t *ghost)
|
||||||
void G_ConsGhostTic(void)
|
void G_ConsGhostTic(void)
|
||||||
{
|
{
|
||||||
UINT8 ziptic;
|
UINT8 ziptic;
|
||||||
UINT16 px,py,pz,gx,gy,gz;
|
fixed_t px,py,pz,gx,gy,gz;
|
||||||
mobj_t *testmo;
|
mobj_t *testmo;
|
||||||
|
fixed_t syncleeway;
|
||||||
boolean nightsfail = false;
|
boolean nightsfail = false;
|
||||||
|
|
||||||
if (!demo_p || !demo_start)
|
if (!demo_p || !demo_start)
|
||||||
|
@ -4910,6 +4915,7 @@ void G_ConsGhostTic(void)
|
||||||
oldghost.x = READFIXED(demo_p);
|
oldghost.x = READFIXED(demo_p);
|
||||||
oldghost.y = READFIXED(demo_p);
|
oldghost.y = READFIXED(demo_p);
|
||||||
oldghost.z = READFIXED(demo_p);
|
oldghost.z = READFIXED(demo_p);
|
||||||
|
syncleeway = 0;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -4923,6 +4929,7 @@ void G_ConsGhostTic(void)
|
||||||
oldghost.x += oldghost.momx;
|
oldghost.x += oldghost.momx;
|
||||||
oldghost.y += oldghost.momy;
|
oldghost.y += oldghost.momy;
|
||||||
oldghost.z += oldghost.momz;
|
oldghost.z += oldghost.momz;
|
||||||
|
syncleeway = FRACUNIT;
|
||||||
}
|
}
|
||||||
if (ziptic & GZT_ANGLE)
|
if (ziptic & GZT_ANGLE)
|
||||||
demo_p++;
|
demo_p++;
|
||||||
|
@ -4988,14 +4995,14 @@ void G_ConsGhostTic(void)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Re-synchronise
|
// Re-synchronise
|
||||||
px = testmo->x>>FRACBITS;
|
px = testmo->x;
|
||||||
py = testmo->y>>FRACBITS;
|
py = testmo->y;
|
||||||
pz = testmo->z>>FRACBITS;
|
pz = testmo->z;
|
||||||
gx = oldghost.x>>FRACBITS;
|
gx = oldghost.x;
|
||||||
gy = oldghost.y>>FRACBITS;
|
gy = oldghost.y;
|
||||||
gz = oldghost.z>>FRACBITS;
|
gz = oldghost.z;
|
||||||
|
|
||||||
if (nightsfail || px != gx || py != gy || pz != gz)
|
if (nightsfail || abs(px-gx) > syncleeway || abs(py-gy) > syncleeway || abs(pz-gz) > syncleeway)
|
||||||
{
|
{
|
||||||
if (demosynced)
|
if (demosynced)
|
||||||
CONS_Alert(CONS_WARNING, M_GetText("Demo playback has desynced!\n"));
|
CONS_Alert(CONS_WARNING, M_GetText("Demo playback has desynced!\n"));
|
||||||
|
|
|
@ -2056,7 +2056,7 @@ EXPORT void HWRAPI(DrawMD2) (INT32 *gl_cmd_buffer, md2_frame_t *frame, FTransfor
|
||||||
EXPORT void HWRAPI(SetTransform) (FTransform *stransform)
|
EXPORT void HWRAPI(SetTransform) (FTransform *stransform)
|
||||||
{
|
{
|
||||||
static boolean special_splitscreen;
|
static boolean special_splitscreen;
|
||||||
float used_fov;
|
double used_fov;
|
||||||
pglLoadIdentity();
|
pglLoadIdentity();
|
||||||
if (stransform)
|
if (stransform)
|
||||||
{
|
{
|
||||||
|
|
|
@ -74,6 +74,14 @@ patch_t *nightsnum[10]; // 0-9
|
||||||
patch_t *lt_font[LT_FONTSIZE];
|
patch_t *lt_font[LT_FONTSIZE];
|
||||||
patch_t *cred_font[CRED_FONTSIZE];
|
patch_t *cred_font[CRED_FONTSIZE];
|
||||||
|
|
||||||
|
// ping font
|
||||||
|
// Note: I'd like to adress that at this point we might *REALLY* want to work towards a common drawString function that can take any font we want because this is really turning into a MESS. :V -Lat'
|
||||||
|
patch_t *pingnum[10];
|
||||||
|
patch_t *pinggfx[5]; // small ping graphic
|
||||||
|
|
||||||
|
patch_t *framecounter;
|
||||||
|
patch_t *frameslash; // framerate stuff. Used in screen.c
|
||||||
|
|
||||||
static player_t *plr;
|
static player_t *plr;
|
||||||
boolean chat_on; // entering a chat message?
|
boolean chat_on; // entering a chat message?
|
||||||
static char w_chat[HU_MAXMSGLEN];
|
static char w_chat[HU_MAXMSGLEN];
|
||||||
|
@ -263,6 +271,8 @@ void HU_LoadGraphics(void)
|
||||||
tallnum[i] = (patch_t *)W_CachePatchName(buffer, PU_HUDGFX);
|
tallnum[i] = (patch_t *)W_CachePatchName(buffer, PU_HUDGFX);
|
||||||
sprintf(buffer, "NGTNUM%d", i);
|
sprintf(buffer, "NGTNUM%d", i);
|
||||||
nightsnum[i] = (patch_t *) W_CachePatchName(buffer, PU_HUDGFX);
|
nightsnum[i] = (patch_t *) W_CachePatchName(buffer, PU_HUDGFX);
|
||||||
|
sprintf(buffer, "PINGN%d", i);
|
||||||
|
pingnum[i] = (patch_t *) W_CachePatchName(buffer, PU_HUDGFX);
|
||||||
}
|
}
|
||||||
|
|
||||||
// minus for negative tallnums
|
// minus for negative tallnums
|
||||||
|
@ -295,6 +305,17 @@ void HU_LoadGraphics(void)
|
||||||
tinyemeraldpics[6] = W_CachePatchName("TEMER7", PU_HUDGFX);
|
tinyemeraldpics[6] = W_CachePatchName("TEMER7", PU_HUDGFX);
|
||||||
|
|
||||||
songcreditbg = W_CachePatchName("K_SONGCR", PU_HUDGFX);
|
songcreditbg = W_CachePatchName("K_SONGCR", PU_HUDGFX);
|
||||||
|
|
||||||
|
// cache ping gfx:
|
||||||
|
for (i = 0; i < 5; i++)
|
||||||
|
{
|
||||||
|
sprintf(buffer, "PINGGFX%d", i+1);
|
||||||
|
pinggfx[i] = (patch_t *)W_CachePatchName(buffer, PU_HUDGFX);
|
||||||
|
}
|
||||||
|
|
||||||
|
// fps stuff
|
||||||
|
framecounter = W_CachePatchName("FRAMER", PU_HUDGFX);
|
||||||
|
frameslash = W_CachePatchName("FRAMESL", PU_HUDGFX);;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Initialise Heads up
|
// Initialise Heads up
|
||||||
|
@ -774,15 +795,15 @@ static void Got_Saycmd(UINT8 **p, INT32 playernum)
|
||||||
cstart = "\x85"; // V_REDMAP
|
cstart = "\x85"; // V_REDMAP
|
||||||
else if (color <= SKINCOLOR_TANGERINE)
|
else if (color <= SKINCOLOR_TANGERINE)
|
||||||
cstart = "\x87"; // V_ORANGEMAP
|
cstart = "\x87"; // V_ORANGEMAP
|
||||||
else if (color <= SKINCOLOR_CARAMEL)
|
else if (color <= SKINCOLOR_CREAM)
|
||||||
cstart = "\x8f"; // V_PEACHMAP
|
cstart = "\x8f"; // V_PEACHMAP
|
||||||
else if (color <= SKINCOLOR_BRONZE)
|
else if (color <= SKINCOLOR_COPPER)
|
||||||
cstart = "\x8A"; // V_GOLDMAP
|
cstart = "\x8A"; // V_GOLDMAP
|
||||||
else if (color <= SKINCOLOR_OLIVE)
|
else if (color <= SKINCOLOR_OLIVE)
|
||||||
cstart = "\x82"; // V_YELLOWMAP
|
cstart = "\x82"; // V_YELLOWMAP
|
||||||
else if (color <= SKINCOLOR_PISTACHIO)
|
else if (color <= SKINCOLOR_PISTACHIO)
|
||||||
cstart = "\x8b"; // V_TEAMAP
|
cstart = "\x8b"; // V_TEAMAP
|
||||||
else if (color <= SKINCOLOR_DREAM || color == SKINCOLOR_LIME)
|
else if (color <= SKINCOLOR_ALGAE || color == SKINCOLOR_LIME || color == SKINCOLOR_HANDHELD)
|
||||||
cstart = "\x83"; // V_GREENMAP
|
cstart = "\x83"; // V_GREENMAP
|
||||||
else if (color <= SKINCOLOR_NAVY || color == SKINCOLOR_SAPPHIRE)
|
else if (color <= SKINCOLOR_NAVY || color == SKINCOLOR_SAPPHIRE)
|
||||||
cstart = "\x88"; // V_SKYMAP
|
cstart = "\x88"; // V_SKYMAP
|
||||||
|
@ -1612,9 +1633,9 @@ static void HU_drawChatLog(INT32 offset)
|
||||||
|
|
||||||
// draw arrows to indicate that we can (or not) scroll.
|
// draw arrows to indicate that we can (or not) scroll.
|
||||||
if (chat_scroll > 0)
|
if (chat_scroll > 0)
|
||||||
V_DrawThinString(chatx-9, ((justscrolledup) ? (chat_topy-1) : (chat_topy)), V_SNAPTOBOTTOM | V_SNAPTOLEFT | highlight, "\x1A"); // up arrow
|
V_DrawCharacter(chatx-9, ((justscrolledup) ? (chat_topy-1) : (chat_topy)), V_SNAPTOBOTTOM | V_SNAPTOLEFT | highlight | '\x1A', false); // up arrow
|
||||||
if (chat_scroll < chat_maxscroll)
|
if (chat_scroll < chat_maxscroll)
|
||||||
V_DrawThinString(chatx-9, chat_bottomy-((justscrolleddown) ? 5 : 6), V_SNAPTOBOTTOM | V_SNAPTOLEFT | highlight, "\x1B"); // down arrow
|
V_DrawCharacter(chatx-9, chat_bottomy-((justscrolleddown) ? 5 : 6), V_SNAPTOBOTTOM | V_SNAPTOLEFT | highlight | '\x1B', false); // down arrow
|
||||||
|
|
||||||
justscrolleddown = false;
|
justscrolleddown = false;
|
||||||
justscrolledup = false;
|
justscrolledup = false;
|
||||||
|
@ -2178,6 +2199,7 @@ static void HU_DrawSongCredits(void)
|
||||||
V_DrawRightAlignedThinString(cursongcredit.x, y, V_ALLOWLOWERCASE|V_6WIDTHSPACE|V_SNAPTOLEFT|(cursongcredit.trans<<V_ALPHASHIFT), str);
|
V_DrawRightAlignedThinString(cursongcredit.x, y, V_ALLOWLOWERCASE|V_6WIDTHSPACE|V_SNAPTOLEFT|(cursongcredit.trans<<V_ALPHASHIFT), str);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// Heads up displays drawer, call each frame
|
// Heads up displays drawer, call each frame
|
||||||
//
|
//
|
||||||
void HU_Drawer(void)
|
void HU_Drawer(void)
|
||||||
|
@ -2369,36 +2391,25 @@ void HU_Erase(void)
|
||||||
//
|
//
|
||||||
// HU_drawPing
|
// HU_drawPing
|
||||||
//
|
//
|
||||||
void HU_drawPing(INT32 x, INT32 y, INT32 ping, boolean notext)
|
void HU_drawPing(INT32 x, INT32 y, UINT32 ping, INT32 flags)
|
||||||
{
|
{
|
||||||
UINT8 numbars = 1; // how many ping bars do we draw?
|
INT32 gfxnum = 4; // gfx to draw
|
||||||
UINT8 barcolor = 128; // color we use for the bars (green, yellow or red)
|
UINT8 const *colormap = R_GetTranslationColormap(TC_RAINBOW, SKINCOLOR_SALMON, GTC_CACHE);
|
||||||
SINT8 i = 0;
|
|
||||||
SINT8 yoffset = 6;
|
|
||||||
INT32 dx = x+1 - (V_SmallStringWidth(va("%dms", ping), V_ALLOWLOWERCASE)/2);
|
|
||||||
|
|
||||||
if (ping < 128)
|
if (ping < 76)
|
||||||
{
|
gfxnum = 0;
|
||||||
numbars = 3;
|
else if (ping < 137)
|
||||||
barcolor = 184;
|
gfxnum = 1;
|
||||||
}
|
|
||||||
else if (ping < 256)
|
else if (ping < 256)
|
||||||
{
|
gfxnum = 2;
|
||||||
numbars = 2; // Apparently ternaries w/ multiple statements don't look good in C so I decided against it.
|
else if (ping < 500)
|
||||||
barcolor = 103;
|
gfxnum = 3;
|
||||||
}
|
|
||||||
|
|
||||||
if (!notext || vid.width >= 640) // how sad, we're using a shit resolution.
|
V_DrawScaledPatch(x, y, flags, pinggfx[gfxnum]);
|
||||||
V_DrawSmallString(dx, y+4, V_ALLOWLOWERCASE, va("%dms", ping));
|
if (servermaxping && ping > servermaxping && hu_tick < 4) // flash ping red if too high
|
||||||
|
V_DrawPingNum(x, y+9, flags, ping, colormap);
|
||||||
for (i=0; (i<3); i++) // Draw the ping bar
|
else
|
||||||
{
|
V_DrawPingNum(x, y+9, flags, ping, NULL);
|
||||||
V_DrawFill(x+2 *(i-1), y+yoffset-4, 2, 8-yoffset, 31);
|
|
||||||
if (i < numbars)
|
|
||||||
V_DrawFill(x+2 *(i-1), y+yoffset-3, 1, 8-yoffset-1, barcolor);
|
|
||||||
|
|
||||||
yoffset -= 2;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//
|
//
|
||||||
|
|
|
@ -80,7 +80,11 @@ extern boolean chat_on;
|
||||||
|
|
||||||
extern patch_t *hu_font[HU_FONTSIZE], *kart_font[KART_FONTSIZE], *tny_font[HU_FONTSIZE]; // SRB2kart
|
extern patch_t *hu_font[HU_FONTSIZE], *kart_font[KART_FONTSIZE], *tny_font[HU_FONTSIZE]; // SRB2kart
|
||||||
extern patch_t *tallnum[10];
|
extern patch_t *tallnum[10];
|
||||||
|
extern patch_t *pingnum[10];
|
||||||
|
extern patch_t *pinggfx[5];
|
||||||
extern patch_t *nightsnum[10];
|
extern patch_t *nightsnum[10];
|
||||||
|
extern patch_t *framecounter;
|
||||||
|
extern patch_t *frameslash;
|
||||||
extern patch_t *lt_font[LT_FONTSIZE];
|
extern patch_t *lt_font[LT_FONTSIZE];
|
||||||
extern patch_t *cred_font[CRED_FONTSIZE];
|
extern patch_t *cred_font[CRED_FONTSIZE];
|
||||||
extern patch_t *emeraldpics[7];
|
extern patch_t *emeraldpics[7];
|
||||||
|
@ -109,7 +113,7 @@ void HU_Drawer(void);
|
||||||
char HU_dequeueChatChar(void);
|
char HU_dequeueChatChar(void);
|
||||||
void HU_Erase(void);
|
void HU_Erase(void);
|
||||||
void HU_clearChatChars(void);
|
void HU_clearChatChars(void);
|
||||||
void HU_drawPing(INT32 x, INT32 y, INT32 ping, boolean notext); // Lat': Ping drawer for scoreboard.
|
void HU_drawPing(INT32 x, INT32 y, UINT32 ping, INT32 flags); // Lat': Ping drawer for scoreboard.
|
||||||
//void HU_DrawTeamTabRankings(playersort_t *tab, INT32 whiteplayer);
|
//void HU_DrawTeamTabRankings(playersort_t *tab, INT32 whiteplayer);
|
||||||
//void HU_DrawDualTabRankings(INT32 x, INT32 y, playersort_t *tab, INT32 scorelines, INT32 whiteplayer);
|
//void HU_DrawDualTabRankings(INT32 x, INT32 y, playersort_t *tab, INT32 scorelines, INT32 whiteplayer);
|
||||||
void HU_DrawTabRankings(INT32 x, INT32 y, playersort_t *tab, INT32 scorelines, INT32 whiteplayer, INT32 hilicol);
|
void HU_DrawTabRankings(INT32 x, INT32 y, playersort_t *tab, INT32 scorelines, INT32 whiteplayer, INT32 hilicol);
|
||||||
|
|
670
src/k_kart.c
670
src/k_kart.c
|
@ -43,187 +43,214 @@
|
||||||
// These should be within 14 characters to fit on the character select screen
|
// These should be within 14 characters to fit on the character select screen
|
||||||
const char *KartColor_Names[MAXSKINCOLORS] =
|
const char *KartColor_Names[MAXSKINCOLORS] =
|
||||||
{
|
{
|
||||||
"None", // 00 // SKINCOLOR_NONE
|
"None", // SKINCOLOR_NONE
|
||||||
"White", // 01 // SKINCOLOR_WHITE
|
"White", // SKINCOLOR_WHITE
|
||||||
"Silver", // 02 // SKINCOLOR_SILVER
|
"Silver", // SKINCOLOR_SILVER
|
||||||
"Grey", // 03 // SKINCOLOR_GREY
|
"Grey", // SKINCOLOR_GREY
|
||||||
"Nickel", // 04 // SKINCOLOR_NICKEL
|
"Nickel", // SKINCOLOR_NICKEL
|
||||||
"Black", // 05 // SKINCOLOR_BLACK
|
"Black", // SKINCOLOR_BLACK
|
||||||
"Sepia", // 06 // SKINCOLOR_SEPIA
|
"Sepia", // SKINCOLOR_SEPIA
|
||||||
"Beige", // 07 // SKINCOLOR_BEIGE
|
"Beige", // SKINCOLOR_BEIGE
|
||||||
"Brown", // 08 // SKINCOLOR_BROWN
|
"Brown", // SKINCOLOR_BROWN
|
||||||
"Leather", // 09 // SKINCOLOR_LEATHER
|
"Leather", // SKINCOLOR_LEATHER
|
||||||
"Salmon", // 10 // SKINCOLOR_SALMON
|
"Salmon", // SKINCOLOR_SALMON
|
||||||
"Pink", // 11 // SKINCOLOR_PINK
|
"Pink", // SKINCOLOR_PINK
|
||||||
"Rose", // 12 // SKINCOLOR_ROSE
|
"Rose", // SKINCOLOR_ROSE
|
||||||
"Ruby", // 13 // SKINCOLOR_RUBY
|
"Ruby", // SKINCOLOR_RUBY
|
||||||
"Raspberry", // 14 // SKINCOLOR_RASPBERRY
|
"Raspberry", // SKINCOLOR_RASPBERRY
|
||||||
"Red", // 15 // SKINCOLOR_RED
|
"Cherry", // SKINCOLOR_CHERRY
|
||||||
"Crimson", // 16 // SKINCOLOR_CRIMSON
|
"Red", // SKINCOLOR_RED
|
||||||
"Ketchup", // 17 // SKINCOLOR_KETCHUP
|
"Scarlet", // SKINCOLOR_SCARLET
|
||||||
"Dawn", // 18 // SKINCOLOR_DAWN
|
"Crimson", // SKINCOLOR_CRIMSON
|
||||||
"Creamsicle", // 19 // SKINCOLOR_CREAMSICLE
|
"Nova", // SKINCOLOR_NOVA
|
||||||
"Orange", // 20 // SKINCOLOR_ORANGE
|
"Ketchup", // SKINCOLOR_KETCHUP
|
||||||
"Pumpkin", // 21 // SKINCOLOR_PUMPKIN
|
"Dawn", // SKINCOLOR_DAWN
|
||||||
"Rosewood", // 22 // SKINCOLOR_ROSEWOOD
|
"Creamsicle", // SKINCOLOR_CREAMSICLE
|
||||||
"Burgundy", // 23 // SKINCOLOR_BURGUNDY
|
"Orange", // SKINCOLOR_ORANGE
|
||||||
"Tangerine", // 24 // SKINCOLOR_TANGERINE
|
"Pumpkin", // SKINCOLOR_PUMPKIN
|
||||||
"Peach", // 25 // SKINCOLOR_PEACH
|
"Rosewood", // SKINCOLOR_ROSEWOOD
|
||||||
"Caramel", // 26 // SKINCOLOR_CARAMEL
|
"Burgundy", // SKINCOLOR_BURGUNDY
|
||||||
"Gold", // 27 // SKINCOLOR_GOLD
|
"Tangerine", // SKINCOLOR_TANGERINE
|
||||||
"Bronze", // 28 // SKINCOLOR_BRONZE
|
"Peach", // SKINCOLOR_PEACH
|
||||||
"Yellow", // 29 // SKINCOLOR_YELLOW
|
"Caramel", // SKINCOLOR_CARAMEL
|
||||||
"Mustard", // 30 // SKINCOLOR_MUSTARD
|
"Cream", // SKINCOLOR_CREAM
|
||||||
"Olive", // 31 // SKINCOLOR_OLIVE
|
"Gold", // SKINCOLOR_GOLD
|
||||||
"Vomit", // 32 // SKINCOLOR_VOMIT
|
"Bronze", // SKINCOLOR_BRONZE
|
||||||
"Garden", // 33 // SKINCOLOR_GARDEN
|
"Copper", // SKINCOLOR_COPPER
|
||||||
"Lime", // 34 // SKINCOLOR_LIME
|
"Yellow", // SKINCOLOR_YELLOW
|
||||||
"Tea", // 35 // SKINCOLOR_TEA
|
"Mustard", // SKINCOLOR_MUSTARD
|
||||||
"Pistachio", // 36 // SKINCOLOR_PISTACHIO
|
"Olive", // SKINCOLOR_OLIVE
|
||||||
"Robo-Hood", // 37 // SKINCOLOR_ROBOHOOD
|
"Vomit", // SKINCOLOR_VOMIT
|
||||||
"Moss", // 38 // SKINCOLOR_MOSS
|
"Garden", // SKINCOLOR_GARDEN
|
||||||
"Mint", // 39 // SKINCOLOR_MINT
|
"Lime", // SKINCOLOR_LIME
|
||||||
"Green", // 40 // SKINCOLOR_GREEN
|
"Handheld", // SKINCOLOR_HANDHELD
|
||||||
"Pinetree", // 41 // SKINCOLOR_PINETREE
|
"Tea", // SKINCOLOR_TEA
|
||||||
"Emerald", // 42 // SKINCOLOR_EMERALD
|
"Pistachio", // SKINCOLOR_PISTACHIO
|
||||||
"Swamp", // 43 // SKINCOLOR_SWAMP
|
"Robo-Hood", // SKINCOLOR_ROBOHOOD
|
||||||
"Dream", // 44 // SKINCOLOR_DREAM
|
"Moss", // SKINCOLOR_MOSS
|
||||||
"Aqua", // 45 // SKINCOLOR_AQUA
|
"Mint", // SKINCOLOR_MINT
|
||||||
"Teal", // 46 // SKINCOLOR_TEAL
|
"Green", // SKINCOLOR_GREEN
|
||||||
"Cyan", // 47 // SKINCOLOR_CYAN
|
"Pinetree", // SKINCOLOR_PINETREE
|
||||||
"Jawz", // 48 // SKINCOLOR_JAWZ
|
"Emerald", // SKINCOLOR_EMERALD
|
||||||
"Cerulean", // 49 // SKINCOLOR_CERULEAN
|
"Swamp", // SKINCOLOR_SWAMP
|
||||||
"Navy", // 50 // SKINCOLOR_NAVY
|
"Dream", // SKINCOLOR_DREAM
|
||||||
"Slate", // 51 // SKINCOLOR_SLATE
|
"Algae", // SKINCOLOR_ALGAE
|
||||||
"Steel", // 52 // SKINCOLOR_STEEL
|
"Aqua", // SKINCOLOR_AQUA
|
||||||
"Jet", // 53 // SKINCOLOR_JET
|
"Teal", // SKINCOLOR_TEAL
|
||||||
"Sapphire", // 54 // SKINCOLOR_SAPPHIRE
|
"Cyan", // SKINCOLOR_CYAN
|
||||||
"Periwinkle", // 55 // SKINCOLOR_PERIWINKLE
|
"Jawz", // SKINCOLOR_JAWZ
|
||||||
"Blue", // 56 // SKINCOLOR_BLUE
|
"Cerulean", // SKINCOLOR_CERULEAN
|
||||||
"Blueberry", // 57 // SKINCOLOR_BLUEBERRY
|
"Navy", // SKINCOLOR_NAVY
|
||||||
"Dusk", // 58 // SKINCOLOR_DUSK
|
"Slate", // SKINCOLOR_SLATE
|
||||||
"Purple", // 59 // SKINCOLOR_PURPLE
|
"Steel", // SKINCOLOR_STEEL
|
||||||
"Lavender", // 60 // SKINCOLOR_LAVENDER
|
"Jet", // SKINCOLOR_JET
|
||||||
"Byzantium", // 61 // SKINCOLOR_BYZANTIUM
|
"Sapphire", // SKINCOLOR_SAPPHIRE
|
||||||
"Pomegranate", // 62 // SKINCOLOR_POMEGRANATE
|
"Periwinkle", // SKINCOLOR_PERIWINKLE
|
||||||
"Lilac" // 63 // SKINCOLOR_LILAC
|
"Blue", // SKINCOLOR_BLUE
|
||||||
|
"Blueberry", // SKINCOLOR_BLUEBERRY
|
||||||
|
"Pastel", // SKINCOLOR_PASTEL
|
||||||
|
"Dusk", // SKINCOLOR_DUSK
|
||||||
|
"Purple", // SKINCOLOR_PURPLE
|
||||||
|
"Fuchsia", // SKINCOLOR_FUCHSIA
|
||||||
|
"Toxic", // SKINCOLOR_TOXIC
|
||||||
|
"Lavender", // SKINCOLOR_LAVENDER
|
||||||
|
"Byzantium", // SKINCOLOR_BYZANTIUM
|
||||||
|
"Pomegranate", // SKINCOLOR_POMEGRANATE
|
||||||
|
"Lilac" // SKINCOLOR_LILAC
|
||||||
};
|
};
|
||||||
|
|
||||||
// Color_Opposite replacement; frame setting has not been changed from 8 for most, should be done later
|
// Color_Opposite replacement; frame setting has not been changed from 8 for most, should be done later
|
||||||
const UINT8 KartColor_Opposite[MAXSKINCOLORS*2] =
|
const UINT8 KartColor_Opposite[MAXSKINCOLORS*2] =
|
||||||
{
|
{
|
||||||
SKINCOLOR_NONE,8, // 00 // SKINCOLOR_NONE
|
SKINCOLOR_NONE,8, // SKINCOLOR_NONE
|
||||||
SKINCOLOR_BLACK,8, // 01 // SKINCOLOR_WHITE
|
SKINCOLOR_BLACK,8, // SKINCOLOR_WHITE
|
||||||
SKINCOLOR_NICKEL,8, // 02 // SKINCOLOR_SILVER
|
SKINCOLOR_NICKEL,8, // SKINCOLOR_SILVER
|
||||||
SKINCOLOR_GREY,8, // 03 // SKINCOLOR_GREY
|
SKINCOLOR_GREY,8, // SKINCOLOR_GREY
|
||||||
SKINCOLOR_SILVER,8, // 04 // SKINCOLOR_NICKEL
|
SKINCOLOR_SILVER,8, // SKINCOLOR_NICKEL
|
||||||
SKINCOLOR_WHITE,8, // 05 // SKINCOLOR_BLACK
|
SKINCOLOR_WHITE,8, // SKINCOLOR_BLACK
|
||||||
SKINCOLOR_LEATHER,6, // 06 // SKINCOLOR_SEPIA
|
SKINCOLOR_LEATHER,6, // SKINCOLOR_SEPIA
|
||||||
SKINCOLOR_BROWN,2, // 07 // SKINCOLOR_BEIGE
|
SKINCOLOR_BROWN,2, // SKINCOLOR_BEIGE
|
||||||
SKINCOLOR_BEIGE,8, // 08 // SKINCOLOR_BROWN
|
SKINCOLOR_BEIGE,8, // SKINCOLOR_BROWN
|
||||||
SKINCOLOR_SEPIA,8, // 09 // SKINCOLOR_LEATHER
|
SKINCOLOR_SEPIA,8, // SKINCOLOR_LEATHER
|
||||||
SKINCOLOR_TEA,8, // 10 // SKINCOLOR_SALMON
|
SKINCOLOR_TEA,8, // SKINCOLOR_SALMON
|
||||||
SKINCOLOR_PISTACHIO,8, // 11 // SKINCOLOR_PINK
|
SKINCOLOR_PISTACHIO,8, // SKINCOLOR_PINK
|
||||||
SKINCOLOR_MOSS,8, // 12 // SKINCOLOR_ROSE
|
SKINCOLOR_MOSS,8, // SKINCOLOR_ROSE
|
||||||
SKINCOLOR_SAPPHIRE,8, // 13 // SKINCOLOR_RUBY
|
SKINCOLOR_SAPPHIRE,8, // SKINCOLOR_RUBY
|
||||||
SKINCOLOR_MINT,8, // 14 // SKINCOLOR_RASPBERRY
|
SKINCOLOR_MINT,8, // SKINCOLOR_RASPBERRY
|
||||||
SKINCOLOR_GREEN,6, // 15 // SKINCOLOR_RED
|
SKINCOLOR_HANDHELD,10, // SKINCOLOR_CHERRY
|
||||||
SKINCOLOR_PINETREE,6, // 16 // SKINCOLOR_CRIMSON
|
SKINCOLOR_GREEN,6, // SKINCOLOR_RED
|
||||||
SKINCOLOR_MUSTARD,10, // 17 // SKINCOLOR_KETCHUP
|
SKINCOLOR_PINETREE,6, // SKINCOLOR_SCARLET
|
||||||
SKINCOLOR_DUSK,8, // 18 // SKINCOLOR_DAWN
|
SKINCOLOR_TOXIC,8, // SKINCOLOR_CRIMSON
|
||||||
SKINCOLOR_PERIWINKLE,8, // 19 // SKINCOLOR_CREAMSICLE
|
SKINCOLOR_ALGAE,10, // SKINCOLOR_NOVA
|
||||||
SKINCOLOR_BLUE,8, // 20 // SKINCOLOR_ORANGE
|
SKINCOLOR_MUSTARD,10, // SKINCOLOR_KETCHUP
|
||||||
SKINCOLOR_BLUEBERRY,8, // 21 // SKINCOLOR_PUMPKIN
|
SKINCOLOR_DUSK,8, // SKINCOLOR_DAWN
|
||||||
SKINCOLOR_NAVY,6, // 22 // SKINCOLOR_ROSEWOOD
|
SKINCOLOR_PERIWINKLE,8, // SKINCOLOR_CREAMSICLE
|
||||||
SKINCOLOR_JET,8, // 23 // SKINCOLOR_BURGUNDY
|
SKINCOLOR_BLUE,8, // SKINCOLOR_ORANGE
|
||||||
SKINCOLOR_LIME,8, // 24 // SKINCOLOR_TANGERINE
|
SKINCOLOR_BLUEBERRY,8, // SKINCOLOR_PUMPKIN
|
||||||
SKINCOLOR_CYAN,8, // 25 // SKINCOLOR_PEACH
|
SKINCOLOR_NAVY,6, // SKINCOLOR_ROSEWOOD
|
||||||
SKINCOLOR_CERULEAN,8, // 26 // SKINCOLOR_CARAMEL
|
SKINCOLOR_JET,8, // SKINCOLOR_BURGUNDY
|
||||||
SKINCOLOR_SLATE,8, // 27 // SKINCOLOR_GOLD
|
SKINCOLOR_LIME,8, // SKINCOLOR_TANGERINE
|
||||||
SKINCOLOR_STEEL,8, // 28 // SKINCOLOR_BRONZE
|
SKINCOLOR_CYAN,8, // SKINCOLOR_PEACH
|
||||||
SKINCOLOR_AQUA,8, // 29 // SKINCOLOR_YELLOW
|
SKINCOLOR_CERULEAN,8, // SKINCOLOR_CARAMEL
|
||||||
SKINCOLOR_KETCHUP,8, // 30 // SKINCOLOR_MUSTARD
|
SKINCOLOR_COPPER,10, // SKINCOLOR_CREAM
|
||||||
SKINCOLOR_TEAL,8, // 31 // SKINCOLOR_OLIVE
|
SKINCOLOR_SLATE,8, // SKINCOLOR_GOLD
|
||||||
SKINCOLOR_ROBOHOOD,8, // 32 // SKINCOLOR_VOMIT
|
SKINCOLOR_STEEL,8, // SKINCOLOR_BRONZE
|
||||||
SKINCOLOR_LAVENDER,6, // 33 // SKINCOLOR_GARDEN
|
SKINCOLOR_CREAM,6, // SKINCOLOR_COPPER
|
||||||
SKINCOLOR_TANGERINE,8, // 34 // SKINCOLOR_LIME
|
SKINCOLOR_AQUA,8, // SKINCOLOR_YELLOW
|
||||||
SKINCOLOR_SALMON,8, // 35 // SKINCOLOR_TEA
|
SKINCOLOR_KETCHUP,8, // SKINCOLOR_MUSTARD
|
||||||
SKINCOLOR_PINK,6, // 36 // SKINCOLOR_PISTACHIO
|
SKINCOLOR_TEAL,8, // SKINCOLOR_OLIVE
|
||||||
SKINCOLOR_VOMIT,8, // 37 // SKINCOLOR_ROBOHOOD
|
SKINCOLOR_ROBOHOOD,8, // SKINCOLOR_VOMIT
|
||||||
SKINCOLOR_ROSE,8, // 38 // SKINCOLOR_MOSS
|
SKINCOLOR_LAVENDER,6, // SKINCOLOR_GARDEN
|
||||||
SKINCOLOR_RASPBERRY,8, // 39 // SKINCOLOR_MINT
|
SKINCOLOR_TANGERINE,8, // SKINCOLOR_LIME
|
||||||
SKINCOLOR_RED,8, // 40 // SKINCOLOR_GREEN
|
SKINCOLOR_CHERRY,8, // SKINCOLOR_HANDHELD
|
||||||
SKINCOLOR_CRIMSON,8, // 41 // SKINCOLOR_PINETREE
|
SKINCOLOR_SALMON,8, // SKINCOLOR_TEA
|
||||||
SKINCOLOR_PURPLE,8, // 42 // SKINCOLOR_EMERALD
|
SKINCOLOR_PINK,6, // SKINCOLOR_PISTACHIO
|
||||||
SKINCOLOR_BYZANTIUM,8, // 43 // SKINCOLOR_SWAMP
|
SKINCOLOR_VOMIT,8, // SKINCOLOR_ROBOHOOD
|
||||||
SKINCOLOR_POMEGRANATE,8, // 44 // SKINCOLOR_DREAM
|
SKINCOLOR_ROSE,8, // SKINCOLOR_MOSS
|
||||||
SKINCOLOR_YELLOW,8, // 45 // SKINCOLOR_AQUA
|
SKINCOLOR_RASPBERRY,8, // SKINCOLOR_MINT
|
||||||
SKINCOLOR_OLIVE,8, // 46 // SKINCOLOR_TEAL
|
SKINCOLOR_RED,8, // SKINCOLOR_GREEN
|
||||||
SKINCOLOR_PEACH,8, // 47 // SKINCOLOR_CYAN
|
SKINCOLOR_SCARLET,8, // SKINCOLOR_PINETREE
|
||||||
SKINCOLOR_LILAC,10, // 48 // SKINCOLOR_JAWZ
|
SKINCOLOR_PURPLE,8, // SKINCOLOR_EMERALD
|
||||||
SKINCOLOR_CARAMEL,8, // 49 // SKINCOLOR_CERULEAN
|
SKINCOLOR_BYZANTIUM,8, // SKINCOLOR_SWAMP
|
||||||
SKINCOLOR_ROSEWOOD,8, // 50 // SKINCOLOR_NAVY
|
SKINCOLOR_POMEGRANATE,8, // SKINCOLOR_DREAM
|
||||||
SKINCOLOR_GOLD,10, // 51 // SKINCOLOR_SLATE
|
SKINCOLOR_NOVA,10, // SKINCOLOR_ALGAE
|
||||||
SKINCOLOR_BRONZE,10, // 52 // SKINCOLOR_STEEL
|
SKINCOLOR_YELLOW,8, // SKINCOLOR_AQUA
|
||||||
SKINCOLOR_BURGUNDY,8, // 53 // SKINCOLOR_JET
|
SKINCOLOR_OLIVE,8, // SKINCOLOR_TEAL
|
||||||
SKINCOLOR_RUBY,6, // 54 // SKINCOLOR_SAPPHIRE
|
SKINCOLOR_PEACH,8, // SKINCOLOR_CYAN
|
||||||
SKINCOLOR_CREAMSICLE,8, // 55 // SKINCOLOR_PERIWINKLE
|
SKINCOLOR_LILAC,10, // SKINCOLOR_JAWZ
|
||||||
SKINCOLOR_ORANGE,8, // 56 // SKINCOLOR_BLUE
|
SKINCOLOR_CARAMEL,8, // SKINCOLOR_CERULEAN
|
||||||
SKINCOLOR_PUMPKIN,8, // 57 // SKINCOLOR_BLUEBERRY
|
SKINCOLOR_ROSEWOOD,8, // SKINCOLOR_NAVY
|
||||||
SKINCOLOR_DAWN,6, // 58 // SKINCOLOR_DUSK
|
SKINCOLOR_GOLD,10, // SKINCOLOR_SLATE
|
||||||
SKINCOLOR_EMERALD,8, // 59 // SKINCOLOR_PURPLE
|
SKINCOLOR_BRONZE,10, // SKINCOLOR_STEEL
|
||||||
SKINCOLOR_GARDEN,6, // 60 // SKINCOLOR_LAVENDER
|
SKINCOLOR_BURGUNDY,8, // SKINCOLOR_JET
|
||||||
SKINCOLOR_SWAMP,8, // 61 // SKINCOLOR_BYZANTIUM
|
SKINCOLOR_RUBY,6, // SKINCOLOR_SAPPHIRE
|
||||||
SKINCOLOR_DREAM,8, // 62 // SKINCOLOR_POMEGRANATE
|
SKINCOLOR_CREAMSICLE,8, // SKINCOLOR_PERIWINKLE
|
||||||
SKINCOLOR_JAWZ,6 // 63 // SKINCOLOR_LILAC
|
SKINCOLOR_ORANGE,8, // SKINCOLOR_BLUE
|
||||||
|
SKINCOLOR_PUMPKIN,8, // SKINCOLOR_BLUEBERRY
|
||||||
|
SKINCOLOR_FUCHSIA,11, // SKINCOLOR_PASTEL
|
||||||
|
SKINCOLOR_DAWN,6, // SKINCOLOR_DUSK
|
||||||
|
SKINCOLOR_EMERALD,8, // SKINCOLOR_PURPLE
|
||||||
|
SKINCOLOR_PASTEL,11, // SKINCOLOR_FUCHSIA
|
||||||
|
SKINCOLOR_CRIMSON,8, // SKINCOLOR_TOXIC
|
||||||
|
SKINCOLOR_GARDEN,6, // SKINCOLOR_LAVENDER
|
||||||
|
SKINCOLOR_SWAMP,8, // SKINCOLOR_BYZANTIUM
|
||||||
|
SKINCOLOR_DREAM,8, // SKINCOLOR_POMEGRANATE
|
||||||
|
SKINCOLOR_JAWZ,6 // SKINCOLOR_LILAC
|
||||||
};
|
};
|
||||||
|
|
||||||
UINT8 colortranslations[MAXSKINCOLORS][16] = {
|
UINT8 colortranslations[MAXTRANSLATIONS][16] = {
|
||||||
{ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}, // SKINCOLOR_NONE
|
{ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}, // SKINCOLOR_NONE
|
||||||
{120, 120, 120, 120, 0, 1, 3, 4, 6, 7, 10, 14, 18, 22, 25, 28}, // SKINCOLOR_WHITE
|
{120, 120, 120, 120, 0, 2, 5, 8, 9, 11, 14, 17, 20, 22, 25, 28}, // SKINCOLOR_WHITE
|
||||||
{ 0, 1, 2, 4, 5, 7, 8, 10, 13, 15, 18, 20, 23, 25, 28, 30}, // SKINCOLOR_SILVER
|
{ 0, 1, 2, 3, 5, 7, 9, 12, 13, 15, 18, 20, 23, 25, 27, 30}, // SKINCOLOR_SILVER
|
||||||
{ 1, 3, 5, 7, 9, 11, 13, 15, 17, 19, 21, 23, 25, 27, 29, 31}, // SKINCOLOR_GREY
|
{ 1, 3, 5, 7, 9, 11, 13, 15, 17, 19, 21, 23, 25, 27, 29, 31}, // SKINCOLOR_GREY
|
||||||
{ 12, 14, 16, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31}, // SKINCOLOR_NICKEL
|
{ 3, 5, 8, 11, 15, 17, 19, 21, 23, 24, 25, 26, 27, 29, 30, 31}, // SKINCOLOR_NICKEL
|
||||||
{ 16, 17, 19, 21, 22, 24, 26, 27, 27, 28, 28, 29, 29, 30, 30, 31}, // SKINCOLOR_BLACK
|
{ 4, 7, 11, 15, 20, 22, 24, 27, 28, 28, 28, 29, 29, 30, 30, 31}, // SKINCOLOR_BLACK
|
||||||
{ 0, 1, 3, 5, 7, 9, 34, 36, 38, 40, 42, 44, 60, 61, 62, 63}, // SKINCOLOR_SEPIA
|
{ 0, 1, 3, 5, 7, 9, 34, 36, 38, 40, 42, 44, 60, 61, 62, 63}, // SKINCOLOR_SEPIA
|
||||||
{ 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47}, // SKINCOLOR_BEIGE
|
{120, 65, 67, 69, 32, 34, 36, 38, 40, 42, 44, 45, 46, 47, 62, 63}, // SKINCOLOR_BEIGE
|
||||||
{ 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63}, // SKINCOLOR_BROWN
|
{ 67, 70, 73, 76, 48, 49, 51, 53, 54, 56, 58, 59, 61, 63, 29, 30}, // SKINCOLOR_BROWN
|
||||||
{ 51, 52, 53, 55, 56, 57, 58, 60, 61, 63, 28, 28, 29, 29, 30, 31}, // SKINCOLOR_LEATHER
|
{ 72, 76, 48, 51, 53, 55, 57, 59, 61, 63, 28, 28, 29, 29, 30, 31}, // SKINCOLOR_LEATHER
|
||||||
{120, 120, 120, 121, 121, 122, 122, 123, 124, 125, 126, 128, 129, 131, 133, 135}, // SKINCOLOR_SALMON
|
{120, 120, 120, 121, 121, 122, 123, 124, 126, 127, 129, 131, 133, 135, 137, 139}, // SKINCOLOR_SALMON
|
||||||
{120, 121, 121, 122, 144, 145, 146, 147, 148, 149, 150, 151, 134, 136, 138, 140}, // SKINCOLOR_PINK
|
{120, 121, 121, 122, 144, 145, 146, 147, 148, 149, 150, 151, 134, 136, 138, 140}, // SKINCOLOR_PINK
|
||||||
{144, 145, 146, 147, 148, 149, 150, 151, 134, 135, 136, 137, 138, 139, 140, 141}, // SKINCOLOR_ROSE
|
{144, 145, 146, 147, 148, 149, 150, 151, 134, 135, 136, 137, 138, 139, 140, 141}, // SKINCOLOR_ROSE
|
||||||
{121, 122, 145, 146, 147, 149, 131, 132, 133, 134, 135, 197, 197, 198, 199, 255}, // SKINCOLOR_RUBY
|
{120, 121, 144, 145, 147, 149, 132, 133, 134, 136, 198, 198, 199, 255, 30, 31}, // SKINCOLOR_RUBY
|
||||||
{120, 121, 122, 123, 124, 125, 126, 127, 128, 130, 131, 133, 134, 136, 137, 139}, // SKINCOLOR_RASPBERRY
|
{120, 121, 122, 123, 124, 125, 126, 127, 128, 130, 131, 134, 136, 137, 139, 140}, // SKINCOLOR_RASPBERRY
|
||||||
{125, 126, 127, 128, 129, 130, 131, 132, 133, 134, 135, 136, 137, 138, 139, 140}, // SKINCOLOR_RED
|
{120, 65, 67, 69, 71, 124, 125, 127, 132, 133, 135, 136, 138, 139, 140, 141}, // SKINCOLOR_CHERRY
|
||||||
{130, 131, 132, 133, 134, 136, 137, 138, 139, 139, 140, 140, 141, 141, 142, 143}, // SKINCOLOR_CRIMSON
|
{122, 123, 124, 126, 129, 132, 133, 134, 135, 136, 137, 138, 139, 140, 141, 142}, // SKINCOLOR_RED
|
||||||
|
{123, 125, 128, 131, 133, 135, 136, 138, 140, 140, 141, 141, 142, 142, 143, 31}, // SKINCOLOR_SCARLET
|
||||||
|
{123, 124, 126, 128, 132, 135, 137, 63, 28, 28, 28, 29, 29, 30, 30, 31}, // SKINCOLOR_CRIMSON
|
||||||
|
{ 99, 113, 113, 84, 85, 87, 126, 128, 130, 196, 197, 198, 199, 240, 243, 246}, // SKINCOLOR_NOVA
|
||||||
{104, 113, 113, 85, 86, 88, 128, 129, 131, 133, 134, 136, 138, 139, 141, 143}, // SKINCOLOR_KETCHUP
|
{104, 113, 113, 85, 86, 88, 128, 129, 131, 133, 134, 136, 138, 139, 141, 143}, // SKINCOLOR_KETCHUP
|
||||||
{120, 121, 122, 123, 124, 147, 147, 148, 90, 91, 92, 93, 94, 95, 152, 154}, // SKINCOLOR_DAWN
|
{120, 121, 122, 123, 124, 147, 147, 148, 90, 91, 92, 93, 94, 95, 152, 154}, // SKINCOLOR_DAWN
|
||||||
{120, 120, 80, 80, 81, 82, 83, 83, 84, 85, 86, 88, 89, 91, 93, 95}, // SKINCOLOR_CREAMSICLE
|
{120, 120, 80, 80, 81, 82, 83, 83, 84, 85, 86, 88, 89, 91, 93, 95}, // SKINCOLOR_CREAMSICLE
|
||||||
{ 80, 81, 82, 83, 84, 85, 86, 88, 89, 91, 94, 95, 154, 156, 158, 159}, // SKINCOLOR_ORANGE
|
{ 80, 81, 82, 83, 84, 85, 86, 88, 89, 91, 94, 95, 154, 156, 158, 159}, // SKINCOLOR_ORANGE
|
||||||
{ 84, 85, 86, 87, 88, 90, 92, 93, 94, 95, 152, 153, 154, 156, 157, 159}, // SKINCOLOR_PUMPKIN
|
{ 82, 83, 84, 85, 87, 89, 90, 92, 94, 152, 153, 155, 157, 159, 141, 142}, // SKINCOLOR_PUMPKIN
|
||||||
{ 90, 91, 92, 93, 94, 152, 153, 154, 155, 156, 157, 158, 159, 139, 141, 143}, // SKINCOLOR_ROSEWOOD
|
{ 83, 85, 88, 90, 92, 94, 152, 153, 154, 156, 157, 159, 140, 141, 142, 143}, // SKINCOLOR_ROSEWOOD
|
||||||
{ 94, 95, 152, 153, 154, 156, 157, 159, 141, 141, 141, 142, 142, 143, 143, 31}, // SKINCOLOR_BURGUNDY
|
{ 84, 86, 89, 91, 152, 154, 155, 157, 158, 159, 140, 141, 142, 143, 31, 31}, // SKINCOLOR_BURGUNDY
|
||||||
{ 98, 98, 112, 112, 113, 113, 84, 85, 87, 89, 91, 93, 95, 153, 156, 159}, // SKINCOLOR_TANGERINE
|
{ 98, 98, 112, 112, 113, 113, 84, 85, 87, 89, 91, 93, 95, 153, 156, 159}, // SKINCOLOR_TANGERINE
|
||||||
{ 64, 65, 67, 68, 70, 71, 73, 74, 76, 77, 79, 48, 50, 53, 56, 59}, // SKINCOLOR_PEACH
|
{120, 80, 66, 70, 72, 76, 148, 149, 150, 151, 153, 154, 156, 61, 62, 63}, // SKINCOLOR_PEACH
|
||||||
{ 64, 66, 68, 70, 72, 74, 76, 78, 48, 50, 52, 54, 56, 58, 60, 62}, // SKINCOLOR_CARAMEL
|
{ 64, 66, 68, 70, 72, 74, 76, 78, 48, 50, 52, 54, 56, 58, 60, 62}, // SKINCOLOR_CARAMEL
|
||||||
|
{120, 120, 96, 96, 97, 82, 84, 77, 50, 54, 57, 59, 61, 63, 29, 31}, // SKINCOLOR_CREAM
|
||||||
{112, 112, 112, 113, 113, 114, 114, 115, 115, 116, 116, 117, 117, 118, 118, 119}, // SKINCOLOR_GOLD
|
{112, 112, 112, 113, 113, 114, 114, 115, 115, 116, 116, 117, 117, 118, 118, 119}, // SKINCOLOR_GOLD
|
||||||
{112, 113, 114, 115, 116, 117, 118, 119, 156, 157, 158, 159, 141, 141, 142, 143}, // SKINCOLOR_BRONZE
|
{112, 113, 114, 115, 116, 117, 118, 119, 156, 157, 158, 159, 141, 141, 142, 143}, // SKINCOLOR_BRONZE
|
||||||
|
{120, 99, 113, 114, 116, 117, 119, 61, 63, 28, 28, 29, 29, 30, 30, 31}, // SKINCOLOR_COPPER
|
||||||
{ 96, 97, 98, 100, 101, 102, 104, 113, 114, 115, 116, 117, 118, 119, 156, 159}, // SKINCOLOR_YELLOW
|
{ 96, 97, 98, 100, 101, 102, 104, 113, 114, 115, 116, 117, 118, 119, 156, 159}, // SKINCOLOR_YELLOW
|
||||||
{ 96, 98, 99, 112, 113, 114, 114, 106, 106, 107, 107, 108, 108, 109, 110, 111}, // SKINCOLOR_MUSTARD
|
{ 96, 98, 99, 112, 113, 114, 114, 106, 106, 107, 107, 108, 108, 109, 110, 111}, // SKINCOLOR_MUSTARD
|
||||||
{105, 105, 105, 106, 106, 107, 107, 108, 108, 109, 109, 110, 110, 111, 111, 31}, // SKINCOLOR_OLIVE
|
{105, 105, 105, 106, 106, 107, 107, 108, 108, 109, 109, 110, 110, 111, 111, 31}, // SKINCOLOR_OLIVE
|
||||||
{121, 144, 145, 72, 73, 84, 114, 115, 107, 108, 109, 183, 223, 207, 30, 246}, // SKINCOLOR_VOMIT
|
{121, 144, 145, 72, 73, 84, 114, 115, 107, 108, 109, 183, 223, 207, 30, 246}, // SKINCOLOR_VOMIT
|
||||||
{ 98, 99, 112, 101, 113, 114, 106, 179, 180, 180, 181, 182, 183, 173, 174, 175}, // SKINCOLOR_GARDEN
|
{ 98, 99, 112, 101, 113, 114, 106, 179, 180, 180, 181, 182, 183, 173, 174, 175}, // SKINCOLOR_GARDEN
|
||||||
{ 96, 97, 99, 100, 102, 104, 160, 162, 164, 166, 168, 171, 223, 223, 207, 31}, // SKINCOLOR_LIME
|
{ 96, 97, 99, 100, 102, 104, 160, 162, 164, 166, 168, 171, 223, 223, 207, 31}, // SKINCOLOR_LIME
|
||||||
|
{ 98, 104, 105, 105, 106, 167, 168, 169, 170, 171, 172, 173, 174, 175, 30, 31}, // SKINCOLOR_HANDHELD
|
||||||
{120, 120, 176, 176, 176, 177, 177, 178, 178, 179, 179, 180, 180, 181, 182, 183}, // SKINCOLOR_TEA
|
{120, 120, 176, 176, 176, 177, 177, 178, 178, 179, 179, 180, 180, 181, 182, 183}, // SKINCOLOR_TEA
|
||||||
{120, 120, 176, 176, 177, 177, 178, 179, 165, 166, 167, 168, 169, 170, 171, 172}, // SKINCOLOR_PISTACHIO
|
{120, 120, 176, 176, 177, 177, 178, 179, 165, 166, 167, 168, 169, 170, 171, 172}, // SKINCOLOR_PISTACHIO
|
||||||
{176, 176, 177, 178, 165, 166, 167, 167, 168, 169, 182, 182, 182, 183, 183, 183}, // SKINCOLOR_ROBOHOOD
|
{120, 176, 178, 165, 167, 168, 169, 182, 182, 171, 171, 172, 173, 174, 175, 30}, // SKINCOLOR_ROBOHOOD
|
||||||
{178, 178, 178, 179, 179, 180, 181, 182, 183, 172, 172, 173, 173, 174, 174, 175}, // SKINCOLOR_MOSS
|
{178, 178, 178, 179, 179, 180, 181, 182, 183, 172, 172, 173, 173, 174, 174, 175}, // SKINCOLOR_MOSS
|
||||||
{120, 176, 176, 176, 177, 163, 164, 165, 167, 221, 221, 222, 223, 207, 207, 31}, // SKINCOLOR_MINT
|
{120, 176, 176, 176, 177, 163, 164, 165, 167, 221, 221, 222, 223, 207, 207, 31}, // SKINCOLOR_MINT
|
||||||
{160, 161, 162, 163, 164, 165, 166, 167, 168, 169, 170, 171, 172, 173, 174, 175}, // SKINCOLOR_GREEN
|
{160, 161, 162, 163, 164, 165, 166, 167, 168, 169, 170, 171, 172, 173, 174, 175}, // SKINCOLOR_GREEN
|
||||||
{160, 161, 162, 164, 165, 167, 169, 170, 171, 171, 172, 173, 174, 175, 30, 31}, // SKINCOLOR_PINETREE
|
{161, 163, 165, 166, 167, 168, 169, 170, 171, 172, 173, 174, 175, 30, 30, 31}, // SKINCOLOR_PINETREE
|
||||||
{160, 184, 184, 185, 185, 186, 186, 187, 187, 188, 188, 189, 189, 190, 191, 175}, // SKINCOLOR_EMERALD
|
{160, 184, 184, 185, 185, 186, 186, 187, 187, 188, 188, 189, 189, 190, 191, 175}, // SKINCOLOR_EMERALD
|
||||||
{186, 187, 188, 188, 188, 189, 189, 190, 190, 191, 175, 175, 30, 30, 31, 31}, // SKINCOLOR_SWAMP
|
{160, 184, 185, 186, 187, 188, 189, 190, 191, 191, 29, 29, 30, 30, 31, 31}, // SKINCOLOR_SWAMP
|
||||||
{120, 120, 80, 80, 81, 177, 162, 164, 228, 228, 204, 204, 205, 205, 206, 207}, // SKINCOLOR_DREAM
|
{120, 120, 80, 80, 81, 177, 162, 164, 228, 228, 204, 204, 205, 205, 206, 207}, // SKINCOLOR_DREAM
|
||||||
|
{208, 209, 210, 211, 213, 220, 216, 167, 168, 188, 188, 189, 190, 191, 30, 31}, // SKINCOLOR_ALGAE
|
||||||
{120, 208, 208, 210, 212, 214, 220, 220, 220, 221, 221, 222, 222, 223, 223, 191}, // SKINCOLOR_AQUA
|
{120, 208, 208, 210, 212, 214, 220, 220, 220, 221, 221, 222, 222, 223, 223, 191}, // SKINCOLOR_AQUA
|
||||||
{210, 213, 220, 220, 220, 216, 216, 221, 221, 221, 222, 222, 223, 223, 191, 31}, // SKINCOLOR_TEAL
|
{210, 213, 220, 220, 220, 216, 216, 221, 221, 221, 222, 222, 223, 223, 191, 31}, // SKINCOLOR_TEAL
|
||||||
{120, 120, 208, 208, 209, 210, 211, 212, 213, 215, 216, 217, 218, 219, 222, 223}, // SKINCOLOR_CYAN
|
{120, 120, 208, 208, 209, 210, 211, 212, 213, 215, 216, 217, 218, 219, 222, 223}, // SKINCOLOR_CYAN
|
||||||
|
@ -234,27 +261,65 @@ UINT8 colortranslations[MAXSKINCOLORS][16] = {
|
||||||
{120, 200, 200, 201, 201, 202, 202, 203, 203, 204, 204, 205, 205, 206, 207, 31}, // SKINCOLOR_STEEL
|
{120, 200, 200, 201, 201, 202, 202, 203, 203, 204, 204, 205, 205, 206, 207, 31}, // SKINCOLOR_STEEL
|
||||||
{225, 226, 227, 228, 229, 205, 205, 206, 207, 207, 28, 28, 29, 29, 30, 31}, // SKINCOLOR_JET
|
{225, 226, 227, 228, 229, 205, 205, 206, 207, 207, 28, 28, 29, 29, 30, 31}, // SKINCOLOR_JET
|
||||||
{208, 209, 211, 213, 215, 217, 229, 230, 232, 234, 236, 238, 240, 242, 244, 246}, // SKINCOLOR_SAPPHIRE
|
{208, 209, 211, 213, 215, 217, 229, 230, 232, 234, 236, 238, 240, 242, 244, 246}, // SKINCOLOR_SAPPHIRE
|
||||||
{120, 224, 225, 226, 226, 227, 228, 228, 229, 230, 231, 234, 235, 237, 239, 241}, // SKINCOLOR_PERIWINKLE
|
{120, 120, 224, 225, 226, 202, 227, 228, 229, 230, 231, 233, 235, 237, 239, 241}, // SKINCOLOR_PERIWINKLE
|
||||||
{224, 225, 226, 227, 228, 229, 230, 231, 232, 233, 234, 235, 236, 237, 238, 239}, // SKINCOLOR_BLUE
|
{224, 225, 226, 227, 228, 229, 230, 231, 232, 233, 235, 236, 238, 242, 244, 246}, // SKINCOLOR_BLUE
|
||||||
{228, 229, 230, 231, 232, 233, 234, 235, 237, 238, 239, 240, 242, 243, 244, 245}, // SKINCOLOR_BLUEBERRY
|
{226, 228, 229, 230, 232, 233, 235, 237, 239, 240, 242, 244, 246, 31, 31, 31}, // SKINCOLOR_BLUEBERRY
|
||||||
{192, 192, 248, 249, 250, 251, 204, 204, 205, 205, 206, 206, 207, 29, 30, 31}, // SKINCOLOR_DUSK
|
{120, 208, 209, 210, 211, 226, 202, 249, 194, 195, 196, 197, 198, 199, 255, 30}, // SKINCOLOR_PASTEL
|
||||||
{192, 192, 192, 193, 193, 194, 194, 195, 195, 196, 196, 197, 197, 198, 198, 199}, // SKINCOLOR_PURPLE
|
{121, 145, 192, 249, 250, 251, 204, 204, 205, 205, 206, 206, 207, 29, 30, 31}, // SKINCOLOR_DUSK
|
||||||
{248, 248, 248, 249, 249, 250, 250, 251, 251, 252, 252, 253, 253, 254, 254, 255}, // SKINCOLOR_LAVENDER
|
{121, 145, 192, 192, 193, 194, 195, 196, 196, 197, 197, 198, 198, 199, 30, 31}, // SKINCOLOR_PURPLE
|
||||||
{192, 248, 249, 250, 251, 252, 253, 254, 255, 255, 29, 29, 30, 30, 31, 31}, // SKINCOLOR_BYZANTIUM
|
{120, 122, 124, 125, 126, 150, 196, 197, 198, 198, 199, 199, 240, 242, 244, 246}, // SKINCOLOR_FUCHSIA
|
||||||
|
{120, 120, 176, 176, 177, 6, 8, 10, 249, 250, 196, 197, 198, 199, 143, 31}, // SKINCOLOR_TOXIC
|
||||||
|
{121, 145, 192, 248, 249, 250, 251, 252, 252, 253, 253, 254, 254, 255, 30, 31}, // SKINCOLOR_LAVENDER
|
||||||
|
{144, 248, 249, 250, 251, 252, 253, 254, 255, 255, 29, 29, 30, 30, 31, 31}, // SKINCOLOR_BYZANTIUM
|
||||||
{144, 145, 146, 147, 148, 149, 150, 251, 251, 252, 252, 253, 254, 255, 29, 30}, // SKINCOLOR_POMEGRANATE
|
{144, 145, 146, 147, 148, 149, 150, 251, 251, 252, 252, 253, 254, 255, 29, 30}, // SKINCOLOR_POMEGRANATE
|
||||||
{120, 120, 120, 121, 121, 122, 122, 123, 192, 248, 249, 250, 251, 252, 253, 254}, // SKINCOLOR_LILAC
|
{120, 120, 120, 121, 121, 122, 122, 123, 192, 248, 249, 250, 251, 252, 253, 254}, // SKINCOLOR_LILAC
|
||||||
/* Removed Colours
|
// MAXSKINCOLORS
|
||||||
{120, 121, 123, 124, 126, 127, 129, 130, 132, 133, 135, 136, 138, 139, 141, 143}, // old SKINCOLOR_RUBY, removed for other colors
|
{120, 120, 120, 120, 120, 120, 120, 120, 120, 120, 96, 100, 104, 113, 116, 119}, // SKINCOLOR_SUPER1
|
||||||
{224, 225, 226, 228, 229, 231, 232, 234, 235, 237, 238, 240, 241, 243, 244, 246}, // old SKINCOLOR_SAPPHIRE, removed for other colors
|
{120, 120, 120, 120, 120, 120, 120, 120, 96, 98, 101, 104, 113, 115, 117, 119}, // SKINCOLOR_SUPER2
|
||||||
{ 72, 73, 74, 75, 76, 77, 78, 79, 48, 49, 50, 51, 52, 53, 54, 55}, // old SKINCOLOR_CARAMEL, new Caramel was previously Shiny Caramel
|
{120, 120, 120, 120, 120, 120, 96, 98, 100, 102, 104, 113, 114, 116, 117, 119}, // SKINCOLOR_SUPER3
|
||||||
{215, 216, 217, 218, 204, 205, 206, 237, 238, 239, 240, 241, 242, 243, 244, 245}, // old SKINCOLOR_NAVY, too similar to Jet
|
{120, 120, 120, 120, 96, 97, 99, 100, 102, 104, 113, 114, 115, 116, 117, 119}, // SKINCOLOR_SUPER4
|
||||||
{ 80, 81, 83, 85, 86, 88, 90, 91, 93, 95, 152, 153, 154, 156, 157, 159}, // SKINCOLOR_AMBER, removed for other colors
|
{120, 120, 96, 120, 120, 120, 120, 120, 104, 113, 114, 115, 116, 117, 118, 119}, // SKINCOLOR_SUPER5
|
||||||
{160, 160, 160, 184, 184, 184, 185, 185, 185, 186, 187, 187, 188, 188, 189, 190}, // SKINCOLOR_JADE, removed for other colors
|
{120, 120, 120, 120, 120, 120, 120, 120, 120, 120, 80, 82, 85, 115, 117, 119}, // SKINCOLOR_TSUPER1
|
||||||
{224, 225, 226, 212, 213, 213, 214, 215, 220, 221, 172, 222, 173, 223, 174, 175}, // SKINCOLOR_FROST, merged into Aqua
|
{120, 120, 120, 120, 120, 120, 120, 120, 80, 81, 83, 85, 115, 116, 117, 119}, // SKINCOLOR_TSUPER2
|
||||||
{ 96, 97, 99, 100, 102, 104, 105, 105, 106, 107, 107, 108, 109, 109, 110, 111}, // SKINCOLOR_CANARY, replaced with Mustard
|
{120, 120, 120, 120, 120, 120, 80, 81, 82, 83, 85, 115, 116, 117, 118, 119}, // SKINCOLOR_TSUPER3
|
||||||
{192, 193, 194, 195, 196, 197, 198, 199, 255, 255, 29, 29, 30, 30, 31, 31}, // SKINCOLOR_INDIGO, too similar to Byzantium
|
{120, 120, 120, 120, 80, 81, 82, 83, 84, 85, 115, 115, 116, 117, 118, 119}, // SKINCOLOR_TSUPER4
|
||||||
{ 1, 145, 125, 73, 83, 114, 106, 180, 187, 168, 219, 205, 236, 206, 199, 255}, // SKINCOLOR_RAINBOW, is Vomit 2.0
|
{120, 120, 80, 80, 81, 82, 83, 84, 85, 115, 115, 116, 117, 117, 118, 119}, // SKINCOLOR_TSUPER5
|
||||||
*/
|
{120, 120, 120, 120, 120, 120, 120, 120, 120, 120, 121, 123, 125, 127, 129, 132}, // SKINCOLOR_KSUPER1
|
||||||
|
{120, 120, 120, 120, 120, 120, 120, 120, 121, 122, 124, 125, 127, 128, 130, 132}, // SKINCOLOR_KSUPER2
|
||||||
|
{120, 120, 120, 120, 120, 120, 121, 122, 123, 124, 125, 127, 128, 129, 130, 132}, // SKINCOLOR_KSUPER3
|
||||||
|
{120, 120, 120, 120, 121, 122, 123, 124, 125, 126, 127, 128, 129, 130, 131, 132}, // SKINCOLOR_KSUPER4
|
||||||
|
{120, 120, 121, 121, 122, 123, 124, 125, 126, 126, 127, 128, 129, 130, 131, 132}, // SKINCOLOR_KSUPER5
|
||||||
|
{120, 120, 120, 120, 120, 120, 120, 120, 120, 120, 0, 122, 124, 248, 251, 255}, // SKINCOLOR_PSUPER1
|
||||||
|
{120, 120, 120, 120, 120, 120, 120, 120, 0, 121, 122, 124, 248, 250, 252, 255}, // SKINCOLOR_PSUPER2
|
||||||
|
{120, 120, 120, 120, 120, 120, 0, 121, 122, 123, 124, 248, 249, 251, 253, 255}, // SKINCOLOR_PSUPER3
|
||||||
|
{120, 120, 120, 120, 0, 121, 122, 123, 124, 248, 249, 250, 251, 252, 253, 255}, // SKINCOLOR_PSUPER4
|
||||||
|
{120, 120, 0, 121, 122, 123, 124, 248, 248, 249, 250, 251, 252, 253, 254, 255}, // SKINCOLOR_PSUPER5
|
||||||
|
{120, 120, 120, 120, 120, 120, 120, 120, 120, 120, 224, 225, 227, 228, 230, 232}, // SKINCOLOR_BSUPER1
|
||||||
|
{120, 120, 120, 120, 120, 120, 120, 120, 224, 225, 226, 227, 228, 229, 230, 232}, // SKINCOLOR_BSUPER2
|
||||||
|
{120, 120, 120, 120, 120, 120, 224, 224, 225, 226, 227, 228, 229, 230, 231, 232}, // SKINCOLOR_BSUPER3
|
||||||
|
{120, 120, 120, 120, 224, 224, 225, 226, 226, 227, 228, 229, 229, 230, 231, 232}, // SKINCOLOR_BSUPER4
|
||||||
|
{120, 120, 224, 224, 225, 225, 226, 227, 227, 228, 228, 229, 230, 230, 231, 232}, // SKINCOLOR_BSUPER5
|
||||||
|
{120, 120, 120, 120, 120, 120, 120, 120, 120, 120, 176, 160, 163, 167, 171, 175}, // SKINCOLOR_GSUPER1
|
||||||
|
{120, 120, 120, 120, 120, 120, 120, 120, 176, 176, 160, 163, 166, 169, 172, 175}, // SKINCOLOR_GSUPER2
|
||||||
|
{120, 120, 120, 120, 120, 120, 176, 176, 160, 162, 164, 166, 168, 170, 172, 175}, // SKINCOLOR_GSUPER3
|
||||||
|
{120, 120, 120, 120, 176, 176, 176, 160, 161, 163, 165, 167, 169, 171, 173, 175}, // SKINCOLOR_GSUPER4
|
||||||
|
{120, 120, 176, 176, 176, 160, 161, 163, 164, 166, 167, 169, 170, 172, 173, 175}, // SKINCOLOR_GSUPER5
|
||||||
|
{120, 120, 120, 120, 120, 120, 120, 120, 120, 120, 120, 120, 120, 120, 120, 120}, // SKINCOLOR_WSUPER1
|
||||||
|
{120, 120, 120, 120, 120, 120, 120, 120, 120, 120, 120, 120, 120, 0, 4, 9}, // SKINCOLOR_WSUPER2
|
||||||
|
{120, 120, 120, 120, 120, 120, 120, 120, 120, 120, 0, 2, 4, 6, 8, 11}, // SKINCOLOR_WSUPER3
|
||||||
|
{120, 120, 120, 120, 120, 120, 120, 0, 1, 3, 4, 6, 8, 9, 11, 13}, // SKINCOLOR_WSUPER4
|
||||||
|
{120, 120, 120, 120, 0, 1, 2, 4, 5, 6, 8, 9, 10, 12, 13, 15}, // SKINCOLOR_WSUPER5
|
||||||
|
{120, 120, 120, 120, 120, 120, 120, 120, 120, 120, 96, 98, 99, 81, 73, 79}, // SKINCOLOR_CSUPER1
|
||||||
|
{120, 120, 120, 120, 120, 120, 120, 120, 96, 97, 98, 81, 81, 71, 75, 79}, // SKINCOLOR_CSUPER2
|
||||||
|
{120, 120, 120, 120, 120, 120, 96, 97, 98, 99, 81, 81, 70, 73, 76, 79}, // SKINCOLOR_CSUPER3
|
||||||
|
{120, 120, 120, 120, 96, 96, 97, 98, 99, 81, 81, 70, 72, 74, 76, 79}, // SKINCOLOR_CSUPER4
|
||||||
|
{120, 120, 96, 96, 97, 98, 98, 99, 81, 81, 69, 71, 73, 75, 77, 79}, // SKINCOLOR_CSUPER5
|
||||||
|
{120, 120, 120, 120, 120, 120, 120, 120, 120, 120, 208, 210, 212, 215, 220, 222}, // SKINCOLOR_ASUPER1
|
||||||
|
{120, 120, 120, 120, 120, 120, 120, 120, 208, 209, 211, 213, 215, 220, 221, 223}, // SKINCOLOR_ASUPER2
|
||||||
|
{120, 120, 120, 120, 120, 120, 208, 209, 210, 211, 212, 213, 215, 220, 221, 223}, // SKINCOLOR_ASUPER3
|
||||||
|
{120, 120, 120, 120, 208, 209, 210, 211, 212, 213, 214, 215, 220, 221, 222, 223}, // SKINCOLOR_ASUPER4
|
||||||
|
{120, 120, 208, 208, 209, 210, 211, 211, 212, 213, 214, 215, 220, 221, 222, 223}, // SKINCOLOR_ASUPER5
|
||||||
|
// MAXTRANSLATIONS
|
||||||
};
|
};
|
||||||
|
|
||||||
// Define for getting accurate color brightness readings according to how the human eye sees them.
|
// Define for getting accurate color brightness readings according to how the human eye sees them.
|
||||||
|
@ -443,6 +508,7 @@ void K_RegisterKartStuff(void)
|
||||||
|
|
||||||
CV_RegisterVar(&cv_kartdebugcheckpoint);
|
CV_RegisterVar(&cv_kartdebugcheckpoint);
|
||||||
CV_RegisterVar(&cv_kartdebugnodes);
|
CV_RegisterVar(&cv_kartdebugnodes);
|
||||||
|
CV_RegisterVar(&cv_kartdebugcolorize);
|
||||||
}
|
}
|
||||||
|
|
||||||
//}
|
//}
|
||||||
|
@ -496,17 +562,17 @@ boolean K_IsPlayerWanted(player_t *player)
|
||||||
static INT32 K_KartItemOddsRace[NUMKARTRESULTS][10] =
|
static INT32 K_KartItemOddsRace[NUMKARTRESULTS][10] =
|
||||||
{
|
{
|
||||||
//P-Odds 0 1 2 3 4 5 6 7 8 9
|
//P-Odds 0 1 2 3 4 5 6 7 8 9
|
||||||
/*Sneaker*/ {20, 0, 0, 4, 6, 6, 0, 0, 0, 0 }, // Sneaker
|
/*Sneaker*/ {20, 0, 0, 4, 6, 7, 0, 0, 0, 0 }, // Sneaker
|
||||||
/*Rocket Sneaker*/ { 0, 0, 0, 0, 0, 1, 3, 5, 3, 0 }, // Rocket Sneaker
|
/*Rocket Sneaker*/ { 0, 0, 0, 0, 0, 1, 4, 5, 3, 0 }, // Rocket Sneaker
|
||||||
/*Invincibility*/ { 0, 0, 0, 0, 0, 1, 4, 6,14, 0 }, // Invincibility
|
/*Invincibility*/ { 0, 0, 0, 0, 0, 1, 4, 6,10, 0 }, // Invincibility
|
||||||
/*Banana*/ { 0,10, 4, 2, 1, 0, 0, 0, 0, 0 }, // Banana
|
/*Banana*/ { 0, 9, 4, 2, 1, 0, 0, 0, 0, 0 }, // Banana
|
||||||
/*Eggman Monitor*/ { 0, 3, 2, 1, 0, 0, 0, 0, 0, 0 }, // Eggman Monitor
|
/*Eggman Monitor*/ { 0, 3, 2, 1, 0, 0, 0, 0, 0, 0 }, // Eggman Monitor
|
||||||
/*Orbinaut*/ { 0, 8, 6, 4, 2, 0, 0, 0, 0, 0 }, // Orbinaut
|
/*Orbinaut*/ { 0, 7, 6, 4, 2, 0, 0, 0, 0, 0 }, // Orbinaut
|
||||||
/*Jawz*/ { 0, 0, 3, 2, 1, 1, 0, 0, 0, 0 }, // Jawz
|
/*Jawz*/ { 0, 0, 3, 2, 1, 1, 0, 0, 0, 0 }, // Jawz
|
||||||
/*Mine*/ { 0, 0, 2, 2, 1, 0, 0, 0, 0, 0 }, // Mine
|
/*Mine*/ { 0, 0, 2, 2, 1, 0, 0, 0, 0, 0 }, // Mine
|
||||||
/*Ballhog*/ { 0, 0, 0, 2, 1, 0, 0, 0, 0, 0 }, // Ballhog
|
/*Ballhog*/ { 0, 0, 0, 2, 1, 0, 0, 0, 0, 0 }, // Ballhog
|
||||||
/*Self-Propelled Bomb*/ { 0, 0, 1, 2, 3, 4, 2, 2, 0,20 }, // Self-Propelled Bomb
|
/*Self-Propelled Bomb*/ { 0, 0, 1, 2, 3, 4, 2, 2, 0,20 }, // Self-Propelled Bomb
|
||||||
/*Grow*/ { 0, 0, 0, 0, 0, 1, 3, 5, 3, 0 }, // Grow
|
/*Grow*/ { 0, 0, 0, 0, 0, 0, 2, 5, 7, 0 }, // Grow
|
||||||
/*Shrink*/ { 0, 0, 0, 0, 0, 0, 0, 2, 0, 0 }, // Shrink
|
/*Shrink*/ { 0, 0, 0, 0, 0, 0, 0, 2, 0, 0 }, // Shrink
|
||||||
/*Thunder Shield*/ { 0, 1, 2, 0, 0, 0, 0, 0, 0, 0 }, // Thunder Shield
|
/*Thunder Shield*/ { 0, 1, 2, 0, 0, 0, 0, 0, 0, 0 }, // Thunder Shield
|
||||||
/*Hyudoro*/ { 0, 0, 0, 0, 1, 2, 1, 0, 0, 0 }, // Hyudoro
|
/*Hyudoro*/ { 0, 0, 0, 0, 1, 2, 1, 0, 0, 0 }, // Hyudoro
|
||||||
|
@ -616,7 +682,7 @@ static INT32 K_KartGetItemOdds(UINT8 pos, SINT8 item, fixed_t mashed)
|
||||||
UINT8 pingame = 0, pexiting = 0, pinvin = 0;
|
UINT8 pingame = 0, pexiting = 0, pinvin = 0;
|
||||||
SINT8 first = -1, second = -1;
|
SINT8 first = -1, second = -1;
|
||||||
INT32 secondist = 0;
|
INT32 secondist = 0;
|
||||||
boolean itemenabled[NUMKARTRESULTS] = {
|
boolean itemenabled[NUMKARTRESULTS-1] = {
|
||||||
cv_sneaker.value,
|
cv_sneaker.value,
|
||||||
cv_rocketsneaker.value,
|
cv_rocketsneaker.value,
|
||||||
cv_invincibility.value,
|
cv_invincibility.value,
|
||||||
|
@ -631,6 +697,7 @@ static INT32 K_KartGetItemOdds(UINT8 pos, SINT8 item, fixed_t mashed)
|
||||||
cv_shrink.value,
|
cv_shrink.value,
|
||||||
cv_thundershield.value,
|
cv_thundershield.value,
|
||||||
cv_hyudoro.value,
|
cv_hyudoro.value,
|
||||||
|
cv_pogospring.value,
|
||||||
cv_kitchensink.value,
|
cv_kitchensink.value,
|
||||||
cv_triplesneaker.value,
|
cv_triplesneaker.value,
|
||||||
cv_triplebanana.value,
|
cv_triplebanana.value,
|
||||||
|
@ -640,7 +707,9 @@ static INT32 K_KartGetItemOdds(UINT8 pos, SINT8 item, fixed_t mashed)
|
||||||
cv_dualjawz.value
|
cv_dualjawz.value
|
||||||
};
|
};
|
||||||
|
|
||||||
if (!itemenabled[item] && !modeattacking)
|
I_Assert(item > KITEM_NONE); // too many off by one scenarioes.
|
||||||
|
|
||||||
|
if (!itemenabled[item-1] && !modeattacking)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
if (G_BattleGametype())
|
if (G_BattleGametype())
|
||||||
|
@ -648,6 +717,9 @@ static INT32 K_KartGetItemOdds(UINT8 pos, SINT8 item, fixed_t mashed)
|
||||||
else
|
else
|
||||||
newodds = K_KartItemOddsRace[item-1][pos];
|
newodds = K_KartItemOddsRace[item-1][pos];
|
||||||
|
|
||||||
|
// Base multiplication to ALL item odds to simulate fractional precision
|
||||||
|
newodds *= 4;
|
||||||
|
|
||||||
for (i = 0; i < MAXPLAYERS; i++)
|
for (i = 0; i < MAXPLAYERS; i++)
|
||||||
{
|
{
|
||||||
if (!playeringame[i] || players[i].spectator)
|
if (!playeringame[i] || players[i].spectator)
|
||||||
|
@ -761,7 +833,7 @@ static INT32 K_FindUseodds(player_t *player, fixed_t mashed, INT32 pingame, INT3
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
for (j = 0; j < NUMKARTRESULTS; j++)
|
for (j = 1; j < NUMKARTRESULTS; j++)
|
||||||
{
|
{
|
||||||
if (K_KartGetItemOdds(i, j, mashed) > 0)
|
if (K_KartGetItemOdds(i, j, mashed) > 0)
|
||||||
{
|
{
|
||||||
|
@ -864,8 +936,8 @@ static void K_KartItemRoulette(player_t *player, ticcmd_t *cmd)
|
||||||
UINT8 pingame = 0;
|
UINT8 pingame = 0;
|
||||||
UINT8 roulettestop;
|
UINT8 roulettestop;
|
||||||
INT32 useodds = 0;
|
INT32 useodds = 0;
|
||||||
INT32 spawnchance[NUMKARTRESULTS * NUMKARTODDS];
|
INT32 spawnchance[NUMKARTRESULTS];
|
||||||
INT32 chance = 0, numchoices = 0;
|
INT32 totalspawnchance = 0;
|
||||||
INT32 bestbumper = 0;
|
INT32 bestbumper = 0;
|
||||||
fixed_t mashed = 0;
|
fixed_t mashed = 0;
|
||||||
boolean dontforcespb = false;
|
boolean dontforcespb = false;
|
||||||
|
@ -962,24 +1034,23 @@ static void K_KartItemRoulette(player_t *player, ticcmd_t *cmd)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Initializes existing spawnchance values
|
// Initializes existing spawnchance values
|
||||||
for (i = 0; i < (NUMKARTRESULTS * NUMKARTODDS); i++)
|
for (i = 0; i < NUMKARTRESULTS; i++)
|
||||||
spawnchance[i] = 0;
|
spawnchance[i] = 0;
|
||||||
|
|
||||||
// Split into another function for a debug function below
|
// Split into another function for a debug function below
|
||||||
useodds = K_FindUseodds(player, mashed, pingame, bestbumper, (spbplace != -1 && player->kartstuff[k_position] == spbplace+1), dontforcespb);
|
useodds = K_FindUseodds(player, mashed, pingame, bestbumper, (spbplace != -1 && player->kartstuff[k_position] == spbplace+1), dontforcespb);
|
||||||
|
|
||||||
#define SETITEMRESULT(itemnum) \
|
|
||||||
for (chance = 0; chance < K_KartGetItemOdds(useodds, itemnum, mashed); chance++) \
|
|
||||||
spawnchance[numchoices++] = itemnum
|
|
||||||
|
|
||||||
for (i = 1; i < NUMKARTRESULTS; i++)
|
for (i = 1; i < NUMKARTRESULTS; i++)
|
||||||
SETITEMRESULT(i);
|
spawnchance[i] = (totalspawnchance += K_KartGetItemOdds(useodds, i, mashed));
|
||||||
|
|
||||||
#undef SETITEMRESULT
|
|
||||||
|
|
||||||
// Award the player whatever power is rolled
|
// Award the player whatever power is rolled
|
||||||
if (numchoices > 0)
|
if (totalspawnchance > 0)
|
||||||
K_KartGetItemResult(player, spawnchance[P_RandomKey(numchoices)]);
|
{
|
||||||
|
totalspawnchance = P_RandomKey(totalspawnchance);
|
||||||
|
for (i = 0; i < NUMKARTRESULTS && spawnchance[i] <= totalspawnchance; i++);
|
||||||
|
|
||||||
|
K_KartGetItemResult(player, i);
|
||||||
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
player->kartstuff[k_itemtype] = KITEM_SAD;
|
player->kartstuff[k_itemtype] = KITEM_SAD;
|
||||||
|
@ -1053,7 +1124,7 @@ void K_KartBouncing(mobj_t *mobj1, mobj_t *mobj2, boolean bounce, boolean solid)
|
||||||
mobj_t *fx;
|
mobj_t *fx;
|
||||||
fixed_t momdifx, momdify;
|
fixed_t momdifx, momdify;
|
||||||
fixed_t distx, disty;
|
fixed_t distx, disty;
|
||||||
fixed_t dot, p;
|
fixed_t dot, force;
|
||||||
fixed_t mass1, mass2;
|
fixed_t mass1, mass2;
|
||||||
|
|
||||||
if (!mobj1 || !mobj2)
|
if (!mobj1 || !mobj2)
|
||||||
|
@ -1111,6 +1182,31 @@ void K_KartBouncing(mobj_t *mobj1, mobj_t *mobj2, boolean bounce, boolean solid)
|
||||||
momdifx = mobj1->momx - mobj2->momx;
|
momdifx = mobj1->momx - mobj2->momx;
|
||||||
momdify = mobj1->momy - mobj2->momy;
|
momdify = mobj1->momy - mobj2->momy;
|
||||||
|
|
||||||
|
// Adds the OTHER player's momentum times a bunch, for the best chance of getting the correct direction
|
||||||
|
distx = (mobj1->x + mobj2->momx*3) - (mobj2->x + mobj1->momx*3);
|
||||||
|
disty = (mobj1->y + mobj2->momy*3) - (mobj2->y + mobj1->momy*3);
|
||||||
|
|
||||||
|
if (distx == 0 && disty == 0)
|
||||||
|
// if there's no distance between the 2, they're directly on top of each other, don't run this
|
||||||
|
return;
|
||||||
|
|
||||||
|
{ // Normalize distance to the sum of the two objects' radii, since in a perfect world that would be the distance at the point of collision...
|
||||||
|
fixed_t dist = P_AproxDistance(distx, disty);
|
||||||
|
fixed_t nx = FixedDiv(distx, dist);
|
||||||
|
fixed_t ny = FixedDiv(disty, dist);
|
||||||
|
|
||||||
|
dist = dist ? dist : 1;
|
||||||
|
distx = FixedMul(mobj1->radius+mobj2->radius, nx);
|
||||||
|
disty = FixedMul(mobj1->radius+mobj2->radius, ny);
|
||||||
|
|
||||||
|
if (momdifx == 0 && momdify == 0)
|
||||||
|
{
|
||||||
|
// If there's no momentum difference, they're moving at exactly the same rate. Pretend they moved into each other.
|
||||||
|
momdifx = -nx;
|
||||||
|
momdify = -ny;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// if the speed difference is less than this let's assume they're going proportionately faster from each other
|
// if the speed difference is less than this let's assume they're going proportionately faster from each other
|
||||||
if (P_AproxDistance(momdifx, momdify) < (25*mapobjectscale))
|
if (P_AproxDistance(momdifx, momdify) < (25*mapobjectscale))
|
||||||
{
|
{
|
||||||
|
@ -1121,34 +1217,6 @@ void K_KartBouncing(mobj_t *mobj1, mobj_t *mobj2, boolean bounce, boolean solid)
|
||||||
momdify = FixedMul((25*mapobjectscale), normalisedy);
|
momdify = FixedMul((25*mapobjectscale), normalisedy);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Adds the OTHER player's momentum, so that it reduces the chance of you being "inside" the other object
|
|
||||||
distx = (mobj1->x + mobj2->momx) - (mobj2->x + mobj1->momx);
|
|
||||||
disty = (mobj1->y + mobj2->momy) - (mobj2->y + mobj1->momy);
|
|
||||||
|
|
||||||
{ // Don't allow dist to get WAY too low, that it pushes you stupidly huge amounts, or backwards...
|
|
||||||
fixed_t dist = P_AproxDistance(distx, disty);
|
|
||||||
fixed_t nx = FixedDiv(distx, dist);
|
|
||||||
fixed_t ny = FixedDiv(disty, dist);
|
|
||||||
|
|
||||||
if (P_AproxDistance(distx, disty) < (3*mobj1->radius)/4)
|
|
||||||
{
|
|
||||||
distx = FixedMul((3*mobj1->radius)/4, nx);
|
|
||||||
disty = FixedMul((3*mobj1->radius)/4, ny);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (P_AproxDistance(distx, disty) < (3*mobj2->radius)/4)
|
|
||||||
{
|
|
||||||
distx = FixedMul((3*mobj2->radius)/4, nx);
|
|
||||||
disty = FixedMul((3*mobj2->radius)/4, ny);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (distx == 0 && disty == 0)
|
|
||||||
{
|
|
||||||
// if there's no distance between the 2, they're directly on top of each other, don't run this
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
dot = FixedMul(momdifx, distx) + FixedMul(momdify, disty);
|
dot = FixedMul(momdifx, distx) + FixedMul(momdify, disty);
|
||||||
|
|
||||||
if (dot >= 0)
|
if (dot >= 0)
|
||||||
|
@ -1157,7 +1225,7 @@ void K_KartBouncing(mobj_t *mobj1, mobj_t *mobj2, boolean bounce, boolean solid)
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
p = FixedDiv(dot, FixedMul(distx, distx)+FixedMul(disty, disty));
|
force = FixedDiv(dot, FixedMul(distx, distx)+FixedMul(disty, disty));
|
||||||
|
|
||||||
if (bounce == true && mass2 > 0) // Perform a Goomba Bounce.
|
if (bounce == true && mass2 > 0) // Perform a Goomba Bounce.
|
||||||
mobj1->momz = -mobj1->momz;
|
mobj1->momz = -mobj1->momz;
|
||||||
|
@ -1172,14 +1240,14 @@ void K_KartBouncing(mobj_t *mobj1, mobj_t *mobj2, boolean bounce, boolean solid)
|
||||||
|
|
||||||
if (mass2 > 0)
|
if (mass2 > 0)
|
||||||
{
|
{
|
||||||
mobj1->momx = mobj1->momx - FixedMul(FixedMul(FixedDiv(2*mass2, mass1 + mass2), p), distx);
|
mobj1->momx = mobj1->momx - FixedMul(FixedMul(FixedDiv(2*mass2, mass1 + mass2), force), distx);
|
||||||
mobj1->momy = mobj1->momy - FixedMul(FixedMul(FixedDiv(2*mass2, mass1 + mass2), p), disty);
|
mobj1->momy = mobj1->momy - FixedMul(FixedMul(FixedDiv(2*mass2, mass1 + mass2), force), disty);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (mass1 > 0 && solid == false)
|
if (mass1 > 0 && solid == false)
|
||||||
{
|
{
|
||||||
mobj2->momx = mobj2->momx - FixedMul(FixedMul(FixedDiv(2*mass1, mass1 + mass2), p), -distx);
|
mobj2->momx = mobj2->momx - FixedMul(FixedMul(FixedDiv(2*mass1, mass1 + mass2), force), -distx);
|
||||||
mobj2->momy = mobj2->momy - FixedMul(FixedMul(FixedDiv(2*mass1, mass1 + mass2), p), -disty);
|
mobj2->momy = mobj2->momy - FixedMul(FixedMul(FixedDiv(2*mass1, mass1 + mass2), force), -disty);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Do the bump fx when we've CONFIRMED we can bump.
|
// Do the bump fx when we've CONFIRMED we can bump.
|
||||||
|
@ -1400,7 +1468,7 @@ void K_RespawnChecker(player_t *player)
|
||||||
mo->eflags |= MFE_VERTICALFLIP;
|
mo->eflags |= MFE_VERTICALFLIP;
|
||||||
P_SetTarget(&mo->target, player->mo);
|
P_SetTarget(&mo->target, player->mo);
|
||||||
mo->angle = newangle+ANGLE_90;
|
mo->angle = newangle+ANGLE_90;
|
||||||
mo->momz = (8*FRACUNIT)*P_MobjFlip(player->mo);
|
mo->momz = (8<<FRACBITS) * P_MobjFlip(player->mo);
|
||||||
P_SetScale(mo, (mo->destscale = FRACUNIT));
|
P_SetScale(mo, (mo->destscale = FRACUNIT));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1975,12 +2043,16 @@ void K_SpinPlayer(player_t *player, mobj_t *source, INT32 type, mobj_t *inflicto
|
||||||
static void K_RemoveGrowShrink(player_t *player)
|
static void K_RemoveGrowShrink(player_t *player)
|
||||||
{
|
{
|
||||||
player->kartstuff[k_growshrinktimer] = 0;
|
player->kartstuff[k_growshrinktimer] = 0;
|
||||||
if (player->kartstuff[k_invincibilitytimer] == 0)
|
|
||||||
player->mo->color = player->skincolor;
|
if (player->mo && !P_MobjWasRemoved(player->mo))
|
||||||
player->mo->scalespeed = mapobjectscale/TICRATE;
|
{
|
||||||
player->mo->destscale = mapobjectscale;
|
if (player->kartstuff[k_invincibilitytimer] == 0)
|
||||||
if (cv_kartdebugshrink.value && !modeattacking && !player->bot)
|
player->mo->color = player->skincolor;
|
||||||
player->mo->destscale = (6*player->mo->destscale)/8;
|
player->mo->scalespeed = mapobjectscale/TICRATE;
|
||||||
|
player->mo->destscale = mapobjectscale;
|
||||||
|
if (cv_kartdebugshrink.value && !modeattacking && !player->bot)
|
||||||
|
player->mo->destscale = (6*player->mo->destscale)/8;
|
||||||
|
}
|
||||||
P_RestoreMusic(player);
|
P_RestoreMusic(player);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2209,6 +2281,9 @@ void K_ExplodePlayer(player_t *player, mobj_t *source, mobj_t *inflictor) // A b
|
||||||
player->mo->momz *= 2;
|
player->mo->momz *= 2;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (player->mo->eflags & MFE_UNDERWATER)
|
||||||
|
player->mo->momz = (117 * player->mo->momz) / 200;
|
||||||
|
|
||||||
if (player->mo->state != &states[S_KART_SPIN])
|
if (player->mo->state != &states[S_KART_SPIN])
|
||||||
P_SetPlayerMobjState(player->mo, S_KART_SPIN);
|
P_SetPlayerMobjState(player->mo, S_KART_SPIN);
|
||||||
|
|
||||||
|
@ -2418,6 +2493,8 @@ void K_SpawnMineExplosion(mobj_t *source, UINT8 color)
|
||||||
truc->momy = P_RandomRange(-speed, speed)*FRACUNIT;
|
truc->momy = P_RandomRange(-speed, speed)*FRACUNIT;
|
||||||
speed = FixedMul(20*FRACUNIT, source->scale)>>FRACBITS;
|
speed = FixedMul(20*FRACUNIT, source->scale)>>FRACBITS;
|
||||||
truc->momz = P_RandomRange(-speed, speed)*FRACUNIT;
|
truc->momz = P_RandomRange(-speed, speed)*FRACUNIT;
|
||||||
|
if (truc->eflags & MFE_UNDERWATER)
|
||||||
|
truc->momz = (117 * truc->momz) / 200;
|
||||||
truc->color = color;
|
truc->color = color;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2446,6 +2523,8 @@ void K_SpawnMineExplosion(mobj_t *source, UINT8 color)
|
||||||
truc->momz = P_RandomRange(speed, speed2)*FRACUNIT;
|
truc->momz = P_RandomRange(speed, speed2)*FRACUNIT;
|
||||||
if (P_RandomChance(FRACUNIT/2))
|
if (P_RandomChance(FRACUNIT/2))
|
||||||
truc->momz = -truc->momz;
|
truc->momz = -truc->momz;
|
||||||
|
if (truc->eflags & MFE_UNDERWATER)
|
||||||
|
truc->momz = (117 * truc->momz) / 200;
|
||||||
truc->tics = TICRATE*2;
|
truc->tics = TICRATE*2;
|
||||||
truc->color = color;
|
truc->color = color;
|
||||||
}
|
}
|
||||||
|
@ -2768,11 +2847,24 @@ void K_SpawnSparkleTrail(mobj_t *mo)
|
||||||
void K_SpawnWipeoutTrail(mobj_t *mo, boolean translucent)
|
void K_SpawnWipeoutTrail(mobj_t *mo, boolean translucent)
|
||||||
{
|
{
|
||||||
mobj_t *dust;
|
mobj_t *dust;
|
||||||
|
angle_t aoff;
|
||||||
|
|
||||||
I_Assert(mo != NULL);
|
I_Assert(mo != NULL);
|
||||||
I_Assert(!P_MobjWasRemoved(mo));
|
I_Assert(!P_MobjWasRemoved(mo));
|
||||||
|
|
||||||
dust = P_SpawnMobj(mo->x + (P_RandomRange(-25,25) * mo->scale), mo->y + (P_RandomRange(-25,25) * mo->scale), mo->z, MT_WIPEOUTTRAIL);
|
if (mo->player)
|
||||||
|
aoff = (mo->player->frameangle + ANGLE_180);
|
||||||
|
else
|
||||||
|
aoff = (mo->angle + ANGLE_180);
|
||||||
|
|
||||||
|
if ((leveltime / 2) & 1)
|
||||||
|
aoff -= ANGLE_45;
|
||||||
|
else
|
||||||
|
aoff += ANGLE_45;
|
||||||
|
|
||||||
|
dust = P_SpawnMobj(mo->x + FixedMul(24*mo->scale, FINECOSINE(aoff>>ANGLETOFINESHIFT)) + (P_RandomRange(-8,8) << FRACBITS),
|
||||||
|
mo->y + FixedMul(24*mo->scale, FINESINE(aoff>>ANGLETOFINESHIFT)) + (P_RandomRange(-8,8) << FRACBITS),
|
||||||
|
mo->z, MT_WIPEOUTTRAIL);
|
||||||
|
|
||||||
P_SetTarget(&dust->target, mo);
|
P_SetTarget(&dust->target, mo);
|
||||||
dust->angle = R_PointToAngle2(0,0,mo->momx,mo->momy);
|
dust->angle = R_PointToAngle2(0,0,mo->momx,mo->momy);
|
||||||
|
@ -3003,6 +3095,9 @@ static mobj_t *K_ThrowKartItem(player_t *player, boolean missile, mobjtype_t map
|
||||||
mo->momy = player->mo->momy + FixedMul(FINESINE(fa), (altthrow == 2 ? 2*PROJSPEED/3 : PROJSPEED));
|
mo->momy = player->mo->momy + FixedMul(FINESINE(fa), (altthrow == 2 ? 2*PROJSPEED/3 : PROJSPEED));
|
||||||
mo->momz = P_MobjFlip(player->mo) * HEIGHT;
|
mo->momz = P_MobjFlip(player->mo) * HEIGHT;
|
||||||
|
|
||||||
|
if (mo->eflags & MFE_UNDERWATER)
|
||||||
|
mo->momz = (117 * mo->momz) / 200;
|
||||||
|
|
||||||
if (player->mo->eflags & MFE_VERTICALFLIP)
|
if (player->mo->eflags & MFE_VERTICALFLIP)
|
||||||
mo->eflags |= MFE_VERTICALFLIP;
|
mo->eflags |= MFE_VERTICALFLIP;
|
||||||
}
|
}
|
||||||
|
@ -3261,6 +3356,7 @@ void K_DoSneaker(player_t *player, INT32 type)
|
||||||
{
|
{
|
||||||
player->pflags |= PF_ATTACKDOWN;
|
player->pflags |= PF_ATTACKDOWN;
|
||||||
K_PlayBoostTaunt(player->mo);
|
K_PlayBoostTaunt(player->mo);
|
||||||
|
player->powers[pw_flashing] = 0; // Stop flashing after boosting
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3286,11 +3382,15 @@ static void K_DoShrink(player_t *user)
|
||||||
{
|
{
|
||||||
// Start shrinking!
|
// Start shrinking!
|
||||||
K_DropItems(&players[i]);
|
K_DropItems(&players[i]);
|
||||||
players[i].mo->scalespeed = mapobjectscale/TICRATE;
|
|
||||||
players[i].mo->destscale = (6*mapobjectscale)/8;
|
if (!P_MobjWasRemoved(players[i].mo))
|
||||||
if (cv_kartdebugshrink.value && !modeattacking && !players[i].bot)
|
{
|
||||||
players[i].mo->destscale = (6*players[i].mo->destscale)/8;
|
players[i].mo->scalespeed = mapobjectscale/TICRATE;
|
||||||
players[i].kartstuff[k_growshrinktimer] = -(200+(40*(MAXPLAYERS-players[i].kartstuff[k_position])));
|
players[i].mo->destscale = (6*mapobjectscale)/8;
|
||||||
|
if (cv_kartdebugshrink.value && !modeattacking && !players[i].bot)
|
||||||
|
players[i].mo->destscale = (6*players[i].mo->destscale)/8;
|
||||||
|
players[i].kartstuff[k_growshrinktimer] = -(200+(40*(MAXPLAYERS-players[i].kartstuff[k_position])));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Grow should get taken away.
|
// Grow should get taken away.
|
||||||
|
@ -3356,6 +3456,9 @@ void K_DoPogoSpring(mobj_t *mo, fixed_t vertispeed, UINT8 sound)
|
||||||
else
|
else
|
||||||
mo->momz = FixedMul(vertispeed, vscale);
|
mo->momz = FixedMul(vertispeed, vscale);
|
||||||
|
|
||||||
|
if (mo->eflags & MFE_UNDERWATER)
|
||||||
|
mo->momz = (117 * mo->momz) / 200;
|
||||||
|
|
||||||
if (sound)
|
if (sound)
|
||||||
S_StartSound(mo, (sound == 1 ? sfx_kc2f : sfx_kpogos));
|
S_StartSound(mo, (sound == 1 ? sfx_kc2f : sfx_kpogos));
|
||||||
}
|
}
|
||||||
|
@ -3415,7 +3518,7 @@ void K_DropHnextList(player_t *player)
|
||||||
mobjtype_t type;
|
mobjtype_t type;
|
||||||
boolean orbit, ponground, dropall = true;
|
boolean orbit, ponground, dropall = true;
|
||||||
|
|
||||||
if (!work)
|
if (!work || P_MobjWasRemoved(work))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
flip = P_MobjFlip(player->mo);
|
flip = P_MobjFlip(player->mo);
|
||||||
|
@ -3505,6 +3608,8 @@ void K_DropHnextList(player_t *player)
|
||||||
dropwork->momx = player->mo->momx>>1;
|
dropwork->momx = player->mo->momx>>1;
|
||||||
dropwork->momy = player->mo->momy>>1;
|
dropwork->momy = player->mo->momy>>1;
|
||||||
dropwork->momz = 3*flip*mapobjectscale;
|
dropwork->momz = 3*flip*mapobjectscale;
|
||||||
|
if (dropwork->eflags & MFE_UNDERWATER)
|
||||||
|
dropwork->momz = (117 * dropwork->momz) / 200;
|
||||||
P_Thrust(dropwork, work->angle - ANGLE_90, 6*mapobjectscale);
|
P_Thrust(dropwork, work->angle - ANGLE_90, 6*mapobjectscale);
|
||||||
dropwork->movecount = 2;
|
dropwork->movecount = 2;
|
||||||
dropwork->movedir = work->angle - ANGLE_90;
|
dropwork->movedir = work->angle - ANGLE_90;
|
||||||
|
@ -3552,7 +3657,7 @@ void K_DropItems(player_t *player)
|
||||||
|
|
||||||
K_DropHnextList(player);
|
K_DropHnextList(player);
|
||||||
|
|
||||||
if (player->mo && player->kartstuff[k_itemamount])
|
if (player->mo && !P_MobjWasRemoved(player->mo) && player->kartstuff[k_itemamount])
|
||||||
{
|
{
|
||||||
mobj_t *drop = P_SpawnMobj(player->mo->x, player->mo->y, player->mo->z + player->mo->height/2, MT_FLOATINGITEM);
|
mobj_t *drop = P_SpawnMobj(player->mo->x, player->mo->y, player->mo->z + player->mo->height/2, MT_FLOATINGITEM);
|
||||||
P_SetScale(drop, drop->scale>>4);
|
P_SetScale(drop, drop->scale>>4);
|
||||||
|
@ -3563,6 +3668,8 @@ void K_DropItems(player_t *player)
|
||||||
FixedAngle(P_RandomFixed()*180) + player->mo->angle + ANGLE_90,
|
FixedAngle(P_RandomFixed()*180) + player->mo->angle + ANGLE_90,
|
||||||
16*mapobjectscale);
|
16*mapobjectscale);
|
||||||
drop->momz = P_MobjFlip(player->mo)*3*mapobjectscale;
|
drop->momz = P_MobjFlip(player->mo)*3*mapobjectscale;
|
||||||
|
if (drop->eflags & MFE_UNDERWATER)
|
||||||
|
drop->momz = (117 * drop->momz) / 200;
|
||||||
|
|
||||||
drop->threshold = (thunderhack ? KITEM_THUNDERSHIELD : player->kartstuff[k_itemtype]);
|
drop->threshold = (thunderhack ? KITEM_THUNDERSHIELD : player->kartstuff[k_itemtype]);
|
||||||
drop->movecount = player->kartstuff[k_itemamount];
|
drop->movecount = player->kartstuff[k_itemamount];
|
||||||
|
@ -4211,7 +4318,7 @@ void K_KartPlayerThink(player_t *player, ticcmd_t *cmd)
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
player->mo->colorized = true;
|
player->mo->colorized = true;
|
||||||
player->mo->color = SKINCOLOR_CRIMSON;
|
player->mo->color = SKINCOLOR_SCARLET;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (player->kartstuff[k_invincibilitytimer]) // setting players to use the star colormap and spawning afterimages
|
else if (player->kartstuff[k_invincibilitytimer]) // setting players to use the star colormap and spawning afterimages
|
||||||
|
@ -4685,6 +4792,7 @@ static void K_KartDrift(player_t *player, boolean onground)
|
||||||
player->kartstuff[k_driftend] = 0;
|
player->kartstuff[k_driftend] = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// Incease/decrease the drift value to continue drifting in that direction
|
// Incease/decrease the drift value to continue drifting in that direction
|
||||||
if (player->kartstuff[k_spinouttimer] == 0 && player->kartstuff[k_jmp] == 1 && onground && player->kartstuff[k_drift] != 0)
|
if (player->kartstuff[k_spinouttimer] == 0 && player->kartstuff[k_jmp] == 1 && onground && player->kartstuff[k_drift] != 0)
|
||||||
{
|
{
|
||||||
|
@ -4714,7 +4822,7 @@ static void K_KartDrift(player_t *player, boolean onground)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Disable drift-sparks until you're going fast enough
|
// Disable drift-sparks until you're going fast enough
|
||||||
if (player->kartstuff[k_getsparks] == 0 || player->kartstuff[k_offroad])
|
if (player->kartstuff[k_getsparks] == 0 || (player->kartstuff[k_offroad] && !player->kartstuff[k_invincibilitytimer] && !player->kartstuff[k_hyudorotimer] && !player->kartstuff[k_sneakertimer]))
|
||||||
driftadditive = 0;
|
driftadditive = 0;
|
||||||
if (player->speed > minspeed*2)
|
if (player->speed > minspeed*2)
|
||||||
player->kartstuff[k_getsparks] = 1;
|
player->kartstuff[k_getsparks] = 1;
|
||||||
|
@ -5440,43 +5548,46 @@ void K_MoveKartPlayer(player_t *player, boolean onground)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Friction
|
if (onground)
|
||||||
if (!player->kartstuff[k_offroad])
|
|
||||||
{
|
{
|
||||||
if (player->speed > 0 && cmd->forwardmove == 0 && player->mo->friction == 59392)
|
// Friction
|
||||||
player->mo->friction += 4608;
|
if (!player->kartstuff[k_offroad])
|
||||||
if (player->speed > 0 && cmd->forwardmove < 0 && player->mo->friction == 59392)
|
{
|
||||||
player->mo->friction += 1608;
|
if (player->speed > 0 && cmd->forwardmove == 0 && player->mo->friction == 59392)
|
||||||
}
|
player->mo->friction += 4608;
|
||||||
|
if (player->speed > 0 && cmd->forwardmove < 0 && player->mo->friction == 59392)
|
||||||
|
player->mo->friction += 1608;
|
||||||
|
}
|
||||||
|
|
||||||
// Karma ice physics
|
// Karma ice physics
|
||||||
if (G_BattleGametype() && player->kartstuff[k_bumper] <= 0)
|
if (G_BattleGametype() && player->kartstuff[k_bumper] <= 0)
|
||||||
{
|
{
|
||||||
player->mo->friction += 1228;
|
player->mo->friction += 1228;
|
||||||
|
|
||||||
if (player->mo->friction > FRACUNIT)
|
if (player->mo->friction > FRACUNIT)
|
||||||
player->mo->friction = FRACUNIT;
|
player->mo->friction = FRACUNIT;
|
||||||
if (player->mo->friction < 0)
|
if (player->mo->friction < 0)
|
||||||
player->mo->friction = 0;
|
player->mo->friction = 0;
|
||||||
|
|
||||||
player->mo->movefactor = FixedDiv(ORIG_FRICTION, player->mo->friction);
|
player->mo->movefactor = FixedDiv(ORIG_FRICTION, player->mo->friction);
|
||||||
|
|
||||||
if (player->mo->movefactor < FRACUNIT)
|
if (player->mo->movefactor < FRACUNIT)
|
||||||
player->mo->movefactor = 19*player->mo->movefactor - 18*FRACUNIT;
|
player->mo->movefactor = 19*player->mo->movefactor - 18*FRACUNIT;
|
||||||
else
|
else
|
||||||
player->mo->movefactor = FRACUNIT; //player->mo->movefactor = ((player->mo->friction - 0xDB34)*(0xA))/0x80;
|
player->mo->movefactor = FRACUNIT; //player->mo->movefactor = ((player->mo->friction - 0xDB34)*(0xA))/0x80;
|
||||||
|
|
||||||
if (player->mo->movefactor < 32)
|
if (player->mo->movefactor < 32)
|
||||||
player->mo->movefactor = 32;
|
player->mo->movefactor = 32;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Wipeout slowdown
|
// Wipeout slowdown
|
||||||
if (player->kartstuff[k_spinouttimer] && player->kartstuff[k_wipeoutslow])
|
if (player->kartstuff[k_spinouttimer] && player->kartstuff[k_wipeoutslow])
|
||||||
{
|
{
|
||||||
if (player->kartstuff[k_offroad])
|
if (player->kartstuff[k_offroad])
|
||||||
player->mo->friction -= 4912;
|
player->mo->friction -= 4912;
|
||||||
if (player->kartstuff[k_wipeoutslow] == 1)
|
if (player->kartstuff[k_wipeoutslow] == 1)
|
||||||
player->mo->friction -= 9824;
|
player->mo->friction -= 9824;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
K_KartDrift(player, onground);
|
K_KartDrift(player, onground);
|
||||||
|
@ -7171,7 +7282,7 @@ void HU_DrawTabRankings(INT32 x, INT32 y, playersort_t *tab, INT32 scorelines, I
|
||||||
|
|
||||||
if (netgame // don't draw it offline
|
if (netgame // don't draw it offline
|
||||||
&& tab[i].num != serverplayer)
|
&& tab[i].num != serverplayer)
|
||||||
HU_drawPing(x + ((i < 8) ? -19 : rightoffset + 13), y+2, playerpingtable[tab[i].num], false);
|
HU_drawPing(x + ((i < 8) ? -17 : rightoffset + 11), y-4, playerpingtable[tab[i].num], 0);
|
||||||
|
|
||||||
STRBUFCPY(strtime, tab[i].name);
|
STRBUFCPY(strtime, tab[i].name);
|
||||||
|
|
||||||
|
@ -8579,6 +8690,25 @@ void K_drawKartHUD(void)
|
||||||
for (p = 0; p < MAXPLAYERS; p++)
|
for (p = 0; p < MAXPLAYERS; p++)
|
||||||
V_DrawString(8, 64+(8*p), V_YELLOWMAP, va("%d - %d (%dl)", p, playernode[p], players[p].cmd.latency));
|
V_DrawString(8, 64+(8*p), V_YELLOWMAP, va("%d - %d (%dl)", p, playernode[p], players[p].cmd.latency));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (cv_kartdebugcolorize.value && stplyr->mo && stplyr->mo->skin)
|
||||||
|
{
|
||||||
|
INT32 x = 0, y = 0;
|
||||||
|
UINT8 c;
|
||||||
|
|
||||||
|
for (c = 1; c < MAXSKINCOLORS; c++)
|
||||||
|
{
|
||||||
|
UINT8 *cm = R_GetTranslationColormap(TC_RAINBOW, c, 0);
|
||||||
|
V_DrawFixedPatch(x<<FRACBITS, y<<FRACBITS, FRACUNIT, 0, facewantprefix[stplyr->skin], cm);
|
||||||
|
|
||||||
|
x += 30;
|
||||||
|
if (x > BASEVIDWIDTH-30)
|
||||||
|
{
|
||||||
|
x = 0;
|
||||||
|
y += 30;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//}
|
//}
|
||||||
|
|
|
@ -11,7 +11,7 @@
|
||||||
|
|
||||||
#define KART_FULLTURN 800
|
#define KART_FULLTURN 800
|
||||||
|
|
||||||
UINT8 colortranslations[MAXSKINCOLORS][16];
|
UINT8 colortranslations[MAXTRANSLATIONS][16];
|
||||||
extern const char *KartColor_Names[MAXSKINCOLORS];
|
extern const char *KartColor_Names[MAXSKINCOLORS];
|
||||||
extern const UINT8 KartColor_Opposite[MAXSKINCOLORS*2];
|
extern const UINT8 KartColor_Opposite[MAXSKINCOLORS*2];
|
||||||
void K_RainbowColormap(UINT8 *dest_colormap, UINT8 skincolor);
|
void K_RainbowColormap(UINT8 *dest_colormap, UINT8 skincolor);
|
||||||
|
|
|
@ -410,6 +410,24 @@ static int libd_drawPaddedNum(lua_State *L)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static int libd_drawPingNum(lua_State *L)
|
||||||
|
{
|
||||||
|
INT32 x, y, flags, num;
|
||||||
|
const UINT8 *colormap = NULL;
|
||||||
|
HUDONLY
|
||||||
|
x = luaL_checkinteger(L, 1);
|
||||||
|
y = luaL_checkinteger(L, 2);
|
||||||
|
num = luaL_checkinteger(L, 3);
|
||||||
|
flags = luaL_optinteger(L, 4, 0);
|
||||||
|
flags &= ~V_PARAMMASK; // Don't let crashes happen.
|
||||||
|
if (!lua_isnoneornil(L, 5))
|
||||||
|
colormap = *((UINT8 **)luaL_checkudata(L, 5, META_COLORMAP));
|
||||||
|
|
||||||
|
V_DrawPingNum(x, y, flags, num, colormap);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
static int libd_drawFill(lua_State *L)
|
static int libd_drawFill(lua_State *L)
|
||||||
{
|
{
|
||||||
INT32 x = luaL_optinteger(L, 1, 0);
|
INT32 x = luaL_optinteger(L, 1, 0);
|
||||||
|
@ -613,6 +631,7 @@ static luaL_Reg lib_draw[] = {
|
||||||
{"drawScaled", libd_drawScaled},
|
{"drawScaled", libd_drawScaled},
|
||||||
{"drawNum", libd_drawNum},
|
{"drawNum", libd_drawNum},
|
||||||
{"drawPaddedNum", libd_drawPaddedNum},
|
{"drawPaddedNum", libd_drawPaddedNum},
|
||||||
|
{"drawPingNum", libd_drawPingNum},
|
||||||
{"drawFill", libd_drawFill},
|
{"drawFill", libd_drawFill},
|
||||||
{"fadeScreen", libd_fadeScreen},
|
{"fadeScreen", libd_fadeScreen},
|
||||||
{"drawString", libd_drawString},
|
{"drawString", libd_drawString},
|
||||||
|
|
|
@ -325,6 +325,8 @@ static int player_get(lua_State *L)
|
||||||
lua_pushinteger(L, plr->bot);
|
lua_pushinteger(L, plr->bot);
|
||||||
else if (fastcmp(field,"jointime"))
|
else if (fastcmp(field,"jointime"))
|
||||||
lua_pushinteger(L, plr->jointime);
|
lua_pushinteger(L, plr->jointime);
|
||||||
|
else if (fastcmp(field,"splitscreenindex"))
|
||||||
|
lua_pushinteger(L, plr->splitscreenindex);
|
||||||
#ifdef HWRENDER
|
#ifdef HWRENDER
|
||||||
else if (fastcmp(field,"fovadd"))
|
else if (fastcmp(field,"fovadd"))
|
||||||
lua_pushfixed(L, plr->fovadd);
|
lua_pushfixed(L, plr->fovadd);
|
||||||
|
@ -613,6 +615,8 @@ static int player_set(lua_State *L)
|
||||||
return NOSET;
|
return NOSET;
|
||||||
else if (fastcmp(field,"jointime"))
|
else if (fastcmp(field,"jointime"))
|
||||||
plr->jointime = (tic_t)luaL_checkinteger(L, 3);
|
plr->jointime = (tic_t)luaL_checkinteger(L, 3);
|
||||||
|
else if (fastcmp(field,"splitscreenindex"))
|
||||||
|
return NOSET;
|
||||||
#ifdef HWRENDER
|
#ifdef HWRENDER
|
||||||
else if (fastcmp(field,"fovadd"))
|
else if (fastcmp(field,"fovadd"))
|
||||||
plr->fovadd = luaL_checkfixed(L, 3);
|
plr->fovadd = luaL_checkfixed(L, 3);
|
||||||
|
|
|
@ -1020,7 +1020,7 @@ void LUA_Archive(void)
|
||||||
|
|
||||||
for (i = 0; i < MAXPLAYERS; i++)
|
for (i = 0; i < MAXPLAYERS; i++)
|
||||||
{
|
{
|
||||||
if (!playeringame[i])
|
if (!playeringame[i] && i > 0) // NEVER skip player 0, this is for dedi servs.
|
||||||
continue;
|
continue;
|
||||||
// all players in game will be archived, even if they just add a 0.
|
// all players in game will be archived, even if they just add a 0.
|
||||||
ArchiveExtVars(&players[i], "player");
|
ArchiveExtVars(&players[i], "player");
|
||||||
|
@ -1056,7 +1056,7 @@ void LUA_UnArchive(void)
|
||||||
|
|
||||||
for (i = 0; i < MAXPLAYERS; i++)
|
for (i = 0; i < MAXPLAYERS; i++)
|
||||||
{
|
{
|
||||||
if (!playeringame[i])
|
if (!playeringame[i] && i > 0) // same here, this is to synch dediservs properly.
|
||||||
continue;
|
continue;
|
||||||
UnArchiveExtVars(&players[i]);
|
UnArchiveExtVars(&players[i]);
|
||||||
}
|
}
|
||||||
|
|
20
src/m_menu.c
20
src/m_menu.c
|
@ -1390,7 +1390,7 @@ static menuitem_t OP_HUDOptionsMenu[] =
|
||||||
{IT_STRING | IT_CVAR | IT_CV_SLIDER,
|
{IT_STRING | IT_CVAR | IT_CV_SLIDER,
|
||||||
NULL, "HUD Visibility", &cv_translucenthud, 20},
|
NULL, "HUD Visibility", &cv_translucenthud, 20},
|
||||||
|
|
||||||
{IT_STRING | IT_SUBMENU, NULL, "Online chat options...",&OP_ChatOptionsDef, 35},
|
{IT_STRING | IT_SUBMENU, NULL, "Online HUD options...",&OP_ChatOptionsDef, 35},
|
||||||
{IT_STRING | IT_CVAR, NULL, "Background Glass", &cons_backcolor, 45},
|
{IT_STRING | IT_CVAR, NULL, "Background Glass", &cons_backcolor, 45},
|
||||||
|
|
||||||
{IT_STRING | IT_CVAR | IT_CV_SLIDER,
|
{IT_STRING | IT_CVAR | IT_CV_SLIDER,
|
||||||
|
@ -1404,6 +1404,7 @@ static menuitem_t OP_HUDOptionsMenu[] =
|
||||||
{IT_STRING | IT_CVAR, NULL, "Console Text Size", &cv_constextsize, 120},
|
{IT_STRING | IT_CVAR, NULL, "Console Text Size", &cv_constextsize, 120},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// Ok it's still called chatoptions but we'll put ping display in here to be clean
|
||||||
static menuitem_t OP_ChatOptionsMenu[] =
|
static menuitem_t OP_ChatOptionsMenu[] =
|
||||||
{
|
{
|
||||||
// will ANYONE who doesn't know how to use the console want to touch this one?
|
// will ANYONE who doesn't know how to use the console want to touch this one?
|
||||||
|
@ -1417,6 +1418,8 @@ static menuitem_t OP_ChatOptionsMenu[] =
|
||||||
{IT_STRING | IT_CVAR, NULL, "Chat Background Tint", &cv_chatbacktint, 50},
|
{IT_STRING | IT_CVAR, NULL, "Chat Background Tint", &cv_chatbacktint, 50},
|
||||||
{IT_STRING | IT_CVAR, NULL, "Message Fadeout Time", &cv_chattime, 60},
|
{IT_STRING | IT_CVAR, NULL, "Message Fadeout Time", &cv_chattime, 60},
|
||||||
{IT_STRING | IT_CVAR, NULL, "Spam Protection", &cv_chatspamprotection, 70},
|
{IT_STRING | IT_CVAR, NULL, "Spam Protection", &cv_chatspamprotection, 70},
|
||||||
|
|
||||||
|
{IT_STRING | IT_CVAR, NULL, "Local ping display", &cv_showping, 90}, // shows ping next to framerate if we want to.
|
||||||
};
|
};
|
||||||
|
|
||||||
static menuitem_t OP_GameOptionsMenu[] =
|
static menuitem_t OP_GameOptionsMenu[] =
|
||||||
|
@ -1469,15 +1472,16 @@ static menuitem_t OP_AdvServerOptionsMenu[] =
|
||||||
|
|
||||||
{IT_STRING | IT_CVAR, NULL, "Attempts to resynchronise", &cv_resynchattempts, 40},
|
{IT_STRING | IT_CVAR, NULL, "Attempts to resynchronise", &cv_resynchattempts, 40},
|
||||||
{IT_STRING | IT_CVAR, NULL, "Ping limit (ms)", &cv_maxping, 50},
|
{IT_STRING | IT_CVAR, NULL, "Ping limit (ms)", &cv_maxping, 50},
|
||||||
{IT_STRING | IT_CVAR, NULL, "Connection timeout (tics)", &cv_nettimeout, 60},
|
{IT_STRING | IT_CVAR, NULL, "Ping timeout (s)", &cv_pingtimeout, 60},
|
||||||
{IT_STRING | IT_CVAR, NULL, "Join timeout (tics)", &cv_jointimeout, 70},
|
{IT_STRING | IT_CVAR, NULL, "Connection timeout (tics)", &cv_nettimeout, 70},
|
||||||
|
{IT_STRING | IT_CVAR, NULL, "Join timeout (tics)", &cv_jointimeout, 80},
|
||||||
|
|
||||||
{IT_STRING | IT_CVAR, NULL, "Max. file transfer send (KB)", &cv_maxsend, 90},
|
{IT_STRING | IT_CVAR, NULL, "Max. file transfer send (KB)", &cv_maxsend, 100},
|
||||||
{IT_STRING | IT_CVAR, NULL, "File transfer packet rate", &cv_downloadspeed, 100},
|
{IT_STRING | IT_CVAR, NULL, "File transfer packet rate", &cv_downloadspeed, 110},
|
||||||
|
|
||||||
{IT_STRING | IT_CVAR, NULL, "Log join addresses", &cv_showjoinaddress, 120},
|
{IT_STRING | IT_CVAR, NULL, "Log join addresses", &cv_showjoinaddress, 130},
|
||||||
{IT_STRING | IT_CVAR, NULL, "Log resyncs", &cv_blamecfail, 130},
|
{IT_STRING | IT_CVAR, NULL, "Log resyncs", &cv_blamecfail, 140},
|
||||||
{IT_STRING | IT_CVAR, NULL, "Log file transfers", &cv_noticedownload, 140},
|
{IT_STRING | IT_CVAR, NULL, "Log file transfers", &cv_noticedownload, 150},
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
|
@ -747,6 +747,9 @@ static boolean PIT_CheckThing(mobj_t *thing)
|
||||||
&& !(tmthing->type == MT_ORBINAUT || tmthing->type == MT_JAWZ || tmthing->type == MT_JAWZ_DUD))
|
&& !(tmthing->type == MT_ORBINAUT || tmthing->type == MT_JAWZ || tmthing->type == MT_JAWZ_DUD))
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
|
if (thing->player && thing->player->kartstuff[k_hyudorotimer])
|
||||||
|
return true; // no interaction
|
||||||
|
|
||||||
if (thing->type == MT_PLAYER)
|
if (thing->type == MT_PLAYER)
|
||||||
{
|
{
|
||||||
// Player Damage
|
// Player Damage
|
||||||
|
@ -1021,6 +1024,9 @@ static boolean PIT_CheckThing(mobj_t *thing)
|
||||||
&& !(thing->type == MT_ORBINAUT || thing->type == MT_JAWZ || thing->type == MT_JAWZ_DUD))
|
&& !(thing->type == MT_ORBINAUT || thing->type == MT_JAWZ || thing->type == MT_JAWZ_DUD))
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
|
if (tmthing->player && tmthing->player->kartstuff[k_hyudorotimer]) // I thought about doing this for just the objects below but figured it should apply to everything.
|
||||||
|
return true; // no interaction
|
||||||
|
|
||||||
if (thing->type == MT_ORBINAUT_SHIELD || thing->type == MT_JAWZ_SHIELD
|
if (thing->type == MT_ORBINAUT_SHIELD || thing->type == MT_JAWZ_SHIELD
|
||||||
|| thing->type == MT_ORBINAUT || thing->type == MT_JAWZ || thing->type == MT_JAWZ_DUD)
|
|| thing->type == MT_ORBINAUT || thing->type == MT_JAWZ || thing->type == MT_JAWZ_DUD)
|
||||||
{
|
{
|
||||||
|
|
|
@ -3399,8 +3399,8 @@ void P_MobjCheckWater(mobj_t *mobj)
|
||||||
|
|
||||||
// skipping stone!
|
// skipping stone!
|
||||||
if (p && p->kartstuff[k_waterskip] < 2
|
if (p && p->kartstuff[k_waterskip] < 2
|
||||||
&& ((p->speed/2 > abs(mobj->momz)) // Going more forward than horizontal, so you can skip across the water.
|
&& ((p->speed/3 > abs(mobj->momz)) // Going more forward than horizontal, so you can skip across the water.
|
||||||
|| (p->speed > K_GetKartSpeed(p,false)/4 && p->kartstuff[k_waterskip])) // Already skipped once, so you can skip once more!
|
|| (p->speed > K_GetKartSpeed(p,false)/3 && p->kartstuff[k_waterskip])) // Already skipped once, so you can skip once more!
|
||||||
&& ((!(mobj->eflags & MFE_VERTICALFLIP) && thingtop - mobj->momz > mobj->watertop)
|
&& ((!(mobj->eflags & MFE_VERTICALFLIP) && thingtop - mobj->momz > mobj->watertop)
|
||||||
|| ((mobj->eflags & MFE_VERTICALFLIP) && mobj->z - mobj->momz < mobj->waterbottom)))
|
|| ((mobj->eflags & MFE_VERTICALFLIP) && mobj->z - mobj->momz < mobj->waterbottom)))
|
||||||
{
|
{
|
||||||
|
|
|
@ -249,6 +249,8 @@ static void P_NetArchivePlayers(void)
|
||||||
|
|
||||||
WRITEUINT32(save_p, players[i].jointime);
|
WRITEUINT32(save_p, players[i].jointime);
|
||||||
|
|
||||||
|
WRITEUINT8(save_p, players[i].splitscreenindex);
|
||||||
|
|
||||||
WRITEUINT16(save_p, flags);
|
WRITEUINT16(save_p, flags);
|
||||||
|
|
||||||
if (flags & CAPSULE)
|
if (flags & CAPSULE)
|
||||||
|
@ -426,6 +428,8 @@ static void P_NetUnArchivePlayers(void)
|
||||||
|
|
||||||
players[i].jointime = READUINT32(save_p);
|
players[i].jointime = READUINT32(save_p);
|
||||||
|
|
||||||
|
players[i].splitscreenindex = READUINT8(save_p);
|
||||||
|
|
||||||
flags = READUINT16(save_p);
|
flags = READUINT16(save_p);
|
||||||
|
|
||||||
if (flags & CAPSULE)
|
if (flags & CAPSULE)
|
||||||
|
|
|
@ -6662,7 +6662,7 @@ static void P_MovePlayer(player_t *player)
|
||||||
//CONS_Printf("leftover turn (%s): %5d or %4d%%\n",
|
//CONS_Printf("leftover turn (%s): %5d or %4d%%\n",
|
||||||
// player_names[player-players],
|
// player_names[player-players],
|
||||||
// (INT16) (cmd->angleturn - (player->mo->angle>>16)),
|
// (INT16) (cmd->angleturn - (player->mo->angle>>16)),
|
||||||
// (INT16) (cmd->angleturn - (player->mo->angle>>16)) * 100 / (angle_diff ?: 1));
|
// (INT16) (cmd->angleturn - (player->mo->angle>>16)) * 100 / (angle_diff ? angle_diff : 1));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1315,6 +1315,7 @@ static void R_ProjectSprite(mobj_t *thing)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
scalestep = (yscale2 - yscale)/(x2 - x1);
|
scalestep = (yscale2 - yscale)/(x2 - x1);
|
||||||
|
scalestep = scalestep ? scalestep : 1;
|
||||||
|
|
||||||
// The following two are alternate sorting methods which might be more applicable in some circumstances. TODO - maybe enable via MF2?
|
// The following two are alternate sorting methods which might be more applicable in some circumstances. TODO - maybe enable via MF2?
|
||||||
// sortscale = max(yscale, yscale2);
|
// sortscale = max(yscale, yscale2);
|
||||||
|
|
33
src/screen.c
33
src/screen.c
|
@ -403,7 +403,7 @@ void SCR_DisplayTicRate(void)
|
||||||
tic_t i;
|
tic_t i;
|
||||||
tic_t ontic = I_GetTime();
|
tic_t ontic = I_GetTime();
|
||||||
tic_t totaltics = 0;
|
tic_t totaltics = 0;
|
||||||
INT32 ticcntcolor = 0;
|
const UINT8 *ticcntcolor = NULL;
|
||||||
|
|
||||||
for (i = lasttic + 1; i < TICRATE+lasttic && i < ontic; ++i)
|
for (i = lasttic + 1; i < TICRATE+lasttic && i < ontic; ++i)
|
||||||
fpsgraph[i % TICRATE] = false;
|
fpsgraph[i % TICRATE] = false;
|
||||||
|
@ -414,13 +414,36 @@ void SCR_DisplayTicRate(void)
|
||||||
if (fpsgraph[i])
|
if (fpsgraph[i])
|
||||||
++totaltics;
|
++totaltics;
|
||||||
|
|
||||||
if (totaltics <= TICRATE/2) ticcntcolor = V_REDMAP;
|
if (totaltics <= TICRATE/2) ticcntcolor = R_GetTranslationColormap(TC_RAINBOW, SKINCOLOR_SALMON, GTC_CACHE);
|
||||||
else if (totaltics == TICRATE) ticcntcolor = V_GREENMAP;
|
else if (totaltics == TICRATE) ticcntcolor = R_GetTranslationColormap(TC_RAINBOW, SKINCOLOR_MINT, GTC_CACHE);
|
||||||
|
|
||||||
V_DrawString(vid.width-(24*vid.dupx), vid.height-(16*vid.dupy),
|
/*V_DrawString(vid.width-(24*vid.dupx), vid.height-(16*vid.dupy),
|
||||||
V_YELLOWMAP|V_NOSCALESTART, "FPS");
|
V_YELLOWMAP|V_NOSCALESTART, "FPS");
|
||||||
V_DrawString(vid.width-(40*vid.dupx), vid.height-( 8*vid.dupy),
|
V_DrawString(vid.width-(40*vid.dupx), vid.height-( 8*vid.dupy),
|
||||||
ticcntcolor|V_NOSCALESTART, va("%02d/%02u", totaltics, TICRATE));
|
ticcntcolor|V_NOSCALESTART, va("%02d/%02u", totaltics, TICRATE));*/
|
||||||
|
|
||||||
|
// draw "FPS"
|
||||||
|
V_DrawFixedPatch(306<<FRACBITS, 183<<FRACBITS, FRACUNIT, V_SNAPTOBOTTOM|V_SNAPTORIGHT, framecounter, R_GetTranslationColormap(TC_RAINBOW, SKINCOLOR_YELLOW, GTC_CACHE));
|
||||||
|
// draw total frame:
|
||||||
|
V_DrawPingNum(318, 190, V_SNAPTOBOTTOM|V_SNAPTORIGHT, TICRATE, ticcntcolor);
|
||||||
|
// draw "/"
|
||||||
|
V_DrawFixedPatch(306<<FRACBITS, 190<<FRACBITS, FRACUNIT, V_SNAPTOBOTTOM|V_SNAPTORIGHT, frameslash, ticcntcolor);
|
||||||
|
// draw our actual framerate
|
||||||
|
V_DrawPingNum(306, 190, V_SNAPTOBOTTOM|V_SNAPTORIGHT, totaltics, ticcntcolor);
|
||||||
|
|
||||||
|
|
||||||
lasttic = ontic;
|
lasttic = ontic;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// SCR_DisplayLocalPing
|
||||||
|
// Used to draw the user's local ping next to the framerate for a quick check without having to hold TAB for instance. By default, it only shows up if your ping is too high and risks getting you kicked.
|
||||||
|
|
||||||
|
void SCR_DisplayLocalPing(void)
|
||||||
|
{
|
||||||
|
UINT32 ping = playerpingtable[consoleplayer]; // consoleplayer's ping is everyone's ping in a splitnetgame :P
|
||||||
|
if (cv_showping.value == 1 || (cv_showping.value == 2 && ping > servermaxping)) // only show 2 (warning) if our ping is at a bad level
|
||||||
|
{
|
||||||
|
INT32 dispy = cv_ticrate.value ? 160 : 181;
|
||||||
|
HU_drawPing(307, dispy, ping, V_SNAPTORIGHT | V_SNAPTOBOTTOM);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -180,5 +180,6 @@ FUNCMATH boolean SCR_IsAspectCorrect(INT32 width, INT32 height);
|
||||||
|
|
||||||
// move out to main code for consistency
|
// move out to main code for consistency
|
||||||
void SCR_DisplayTicRate(void);
|
void SCR_DisplayTicRate(void);
|
||||||
|
void SCR_DisplayLocalPing(void);
|
||||||
#undef DNWH
|
#undef DNWH
|
||||||
#endif //__SCREEN_H__
|
#endif //__SCREEN_H__
|
||||||
|
|
|
@ -64,7 +64,7 @@
|
||||||
#include "../m_menu.h"
|
#include "../m_menu.h"
|
||||||
#include "../d_main.h"
|
#include "../d_main.h"
|
||||||
#include "../s_sound.h"
|
#include "../s_sound.h"
|
||||||
#include "../i_sound.h" // midi pause/unpause
|
#include "../i_sound.h" // midi pause/unpause
|
||||||
#include "../i_joy.h"
|
#include "../i_joy.h"
|
||||||
#include "../st_stuff.h"
|
#include "../st_stuff.h"
|
||||||
#include "../g_game.h"
|
#include "../g_game.h"
|
||||||
|
@ -1361,6 +1361,9 @@ void I_FinishUpdate(void)
|
||||||
if (cv_ticrate.value)
|
if (cv_ticrate.value)
|
||||||
SCR_DisplayTicRate();
|
SCR_DisplayTicRate();
|
||||||
|
|
||||||
|
if (cv_showping.value && netgame && consoleplayer != serverplayer)
|
||||||
|
SCR_DisplayLocalPing();
|
||||||
|
|
||||||
if (rendermode == render_soft && screens[0])
|
if (rendermode == render_soft && screens[0])
|
||||||
{
|
{
|
||||||
SDL_Rect rect;
|
SDL_Rect rect;
|
||||||
|
|
|
@ -1343,6 +1343,9 @@ void I_FinishUpdate(void)
|
||||||
if (cv_ticrate.value)
|
if (cv_ticrate.value)
|
||||||
SCR_DisplayTicRate();
|
SCR_DisplayTicRate();
|
||||||
|
|
||||||
|
if (cv_showping.value && netgame && consoleplayer != serverplayer)
|
||||||
|
SCR_DisplayLocalPing();
|
||||||
|
|
||||||
if (render_soft == rendermode && screens[0])
|
if (render_soft == rendermode && screens[0])
|
||||||
{
|
{
|
||||||
SDL_Rect *dstrect = NULL;
|
SDL_Rect *dstrect = NULL;
|
||||||
|
|
|
@ -1342,8 +1342,8 @@ void V_DrawCharacter(INT32 x, INT32 y, INT32 c, boolean lowercaseallowed)
|
||||||
V_DrawScaledPatch(x, y, flags, hu_font[c]);
|
V_DrawScaledPatch(x, y, flags, hu_font[c]);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Writes a single character for the chat. (draw WHITE if bit 7 set)
|
// Writes a single character for the chat (half scaled). (draw WHITE if bit 7 set)
|
||||||
// Essentially the same as the above but it's small or big depending on what resolution you've chosen to huge..
|
// 16/02/19: Scratch the scaling thing, chat doesn't work anymore under 2x res -Lat'
|
||||||
//
|
//
|
||||||
void V_DrawChatCharacter(INT32 x, INT32 y, INT32 c, boolean lowercaseallowed, UINT8 *colormap)
|
void V_DrawChatCharacter(INT32 x, INT32 y, INT32 c, boolean lowercaseallowed, UINT8 *colormap)
|
||||||
{
|
{
|
||||||
|
@ -1359,13 +1359,11 @@ void V_DrawChatCharacter(INT32 x, INT32 y, INT32 c, boolean lowercaseallowed, UI
|
||||||
if (c < 0 || c >= HU_FONTSIZE || !hu_font[c])
|
if (c < 0 || c >= HU_FONTSIZE || !hu_font[c])
|
||||||
return;
|
return;
|
||||||
|
|
||||||
w = (vid.width < 640 ) ? (SHORT(hu_font[c]->width)/2) : (SHORT(hu_font[c]->width)); // use normal sized characters if we're using a terribly low resolution.
|
w = SHORT(hu_font[c]->width)/2;
|
||||||
if (x + w > vid.width)
|
if (x + w > vid.width)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
V_DrawFixedPatch(x*FRACUNIT, y*FRACUNIT, (vid.width < 640) ? (FRACUNIT) : (FRACUNIT/2), flags, hu_font[c], colormap);
|
V_DrawFixedPatch(x*FRACUNIT, y*FRACUNIT, FRACUNIT/2, flags, hu_font[c], colormap);
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Precompile a wordwrapped string to any given width.
|
// Precompile a wordwrapped string to any given width.
|
||||||
|
@ -2015,6 +2013,28 @@ void V_DrawPaddedTallNum(INT32 x, INT32 y, INT32 flags, INT32 num, INT32 digits)
|
||||||
} while (--digits);
|
} while (--digits);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Draws a number using the PING font thingy.
|
||||||
|
// TODO: Merge number drawing functions into one with "font name" selection.
|
||||||
|
|
||||||
|
void V_DrawPingNum(INT32 x, INT32 y, INT32 flags, INT32 num, const UINT8 *colormap)
|
||||||
|
{
|
||||||
|
INT32 w = SHORT(pingnum[0]->width); // this SHOULD always be 5 but I guess custom graphics exist.
|
||||||
|
|
||||||
|
if (flags & V_NOSCALESTART)
|
||||||
|
w *= vid.dupx;
|
||||||
|
|
||||||
|
if (num < 0)
|
||||||
|
num = -num;
|
||||||
|
|
||||||
|
// draw the number
|
||||||
|
do
|
||||||
|
{
|
||||||
|
x -= (w-1); // Oni wanted their outline to intersect.
|
||||||
|
V_DrawFixedPatch(x<<FRACBITS, y<<FRACBITS, FRACUNIT, flags, pingnum[num%10], colormap);
|
||||||
|
num /= 10;
|
||||||
|
} while (num);
|
||||||
|
}
|
||||||
|
|
||||||
// Write a string using the credit font
|
// Write a string using the credit font
|
||||||
// NOTE: the text is centered for screens larger than the base width
|
// NOTE: the text is centered for screens larger than the base width
|
||||||
//
|
//
|
||||||
|
|
|
@ -190,6 +190,10 @@ void V_DrawStringAtFixed(fixed_t x, fixed_t y, INT32 option, const char *string)
|
||||||
void V_DrawTallNum(INT32 x, INT32 y, INT32 flags, INT32 num);
|
void V_DrawTallNum(INT32 x, INT32 y, INT32 flags, INT32 num);
|
||||||
void V_DrawPaddedTallNum(INT32 x, INT32 y, INT32 flags, INT32 num, INT32 digits);
|
void V_DrawPaddedTallNum(INT32 x, INT32 y, INT32 flags, INT32 num, INT32 digits);
|
||||||
|
|
||||||
|
// Draw ping numbers. Used by the scoreboard and that one ping option. :P
|
||||||
|
// This is a separate function because IMO lua should have access to it as well.
|
||||||
|
void V_DrawPingNum(INT32 x, INT32 y, INT32 flags, INT32 num, const UINT8 *colormap);
|
||||||
|
|
||||||
// Find string width from lt_font chars
|
// Find string width from lt_font chars
|
||||||
INT32 V_LevelNameWidth(const char *string);
|
INT32 V_LevelNameWidth(const char *string);
|
||||||
INT32 V_LevelNameHeight(const char *string);
|
INT32 V_LevelNameHeight(const char *string);
|
||||||
|
|
|
@ -639,9 +639,6 @@ void I_Error(const char *error, ...)
|
||||||
if (!errorcount)
|
if (!errorcount)
|
||||||
{
|
{
|
||||||
M_SaveConfig(NULL); // save game config, cvars..
|
M_SaveConfig(NULL); // save game config, cvars..
|
||||||
#ifndef NONET
|
|
||||||
D_SaveBan(); // save the ban list
|
|
||||||
#endif
|
|
||||||
G_SaveGameData();
|
G_SaveGameData();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -366,6 +366,9 @@ void I_FinishUpdate(void)
|
||||||
if (cv_ticrate.value)
|
if (cv_ticrate.value)
|
||||||
SCR_DisplayTicRate();
|
SCR_DisplayTicRate();
|
||||||
|
|
||||||
|
if (cv_showping.value && netgame && consoleplayer != serverplayer)
|
||||||
|
SCR_DisplayLocalPing();
|
||||||
|
|
||||||
//
|
//
|
||||||
if (bDIBMode)
|
if (bDIBMode)
|
||||||
{
|
{
|
||||||
|
|
|
@ -198,6 +198,9 @@ void I_FinishUpdate(void)
|
||||||
if (cv_ticrate.value)
|
if (cv_ticrate.value)
|
||||||
SCR_DisplayTicRate();
|
SCR_DisplayTicRate();
|
||||||
|
|
||||||
|
if (cv_showping.value && netgame && consoleplayer != serverplayer)
|
||||||
|
SCR_DisplayLocalPing();
|
||||||
|
|
||||||
//
|
//
|
||||||
if (bDIBMode)
|
if (bDIBMode)
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in a new issue