- Blood: fixed scriptified MP statusbar code to the point where it compiles.

Mainly to avoid code rot by future changes, this probably cannot remain as it is if MP gets reimplemented.
This commit is contained in:
Christoph Oelckers 2021-05-13 09:31:08 +02:00
parent 55abb261c6
commit 317238147b
4 changed files with 74 additions and 67 deletions

View file

@ -2373,6 +2373,7 @@ DEFINE_FIELD_X(BloodPlayer, PLAYER, aimTargetsCount)
DEFINE_FIELD_X(BloodPlayer, PLAYER, aimTargets) DEFINE_FIELD_X(BloodPlayer, PLAYER, aimTargets)
DEFINE_FIELD_X(BloodPlayer, PLAYER, deathTime) DEFINE_FIELD_X(BloodPlayer, PLAYER, deathTime)
DEFINE_FIELD_X(BloodPlayer, PLAYER, pwUpTime) DEFINE_FIELD_X(BloodPlayer, PLAYER, pwUpTime)
DEFINE_FIELD_X(BloodPlayer, PLAYER, teamId)
DEFINE_FIELD_X(BloodPlayer, PLAYER, fragCount) DEFINE_FIELD_X(BloodPlayer, PLAYER, fragCount)
DEFINE_FIELD_X(BloodPlayer, PLAYER, fragInfo) DEFINE_FIELD_X(BloodPlayer, PLAYER, fragInfo)
DEFINE_FIELD_X(BloodPlayer, PLAYER, underwaterTime) DEFINE_FIELD_X(BloodPlayer, PLAYER, underwaterTime)

View file

@ -40,6 +40,7 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
#include "gamecvars.h" #include "gamecvars.h"
CVARD(Bool, hud_powerupduration, true, CVAR_ARCHIVE/*|CVAR_FRONTEND_BLOOD*/, "enable/disable displaying the remaining seconds for power-ups") CVARD(Bool, hud_powerupduration, true, CVAR_ARCHIVE/*|CVAR_FRONTEND_BLOOD*/, "enable/disable displaying the remaining seconds for power-ups")
CVAR(Bool, hud_ctf_vanilla, false, CVAR_ARCHIVE)
BEGIN_BLD_NS BEGIN_BLD_NS

View file

@ -29,6 +29,18 @@ struct Blood native
native static void sndStartSampleNamed(String sname, int volume, int channel); native static void sndStartSampleNamed(String sname, int volume, int channel);
native static TextureID PowerupIcon(int pwup); native static TextureID PowerupIcon(int pwup);
native static BloodPlayer GetViewPlayer(); native static BloodPlayer GetViewPlayer();
// These are just dummies to make the MP statusbar code compile.
static void GetPlayers(Array<BloodPlayer> players)
{
players.Clear();
players.Push(GetViewPlayer());
}
static int getGameType()
{
return 0;
}
} }
struct PACKINFO // not native! struct PACKINFO // not native!
@ -93,6 +105,7 @@ struct BloodPlayer native
native int pwUpTime[51]; // kMaxPowerUps native int pwUpTime[51]; // kMaxPowerUps
native int fragCount; native int fragCount;
native int fragInfo[8]; native int fragInfo[8];
native int teamId;
native int underwaterTime; native int underwaterTime;
native int bubbleTime; native int bubbleTime;
native int restTime; native int restTime;

View file

@ -27,6 +27,8 @@ class BloodStatusBar : RazeStatusBar
static const String gPackIcons[] = { "PackIcon1", "PackIcon2", "PackIcon3", "PackIcon4", "PackIcon5" }; static const String gPackIcons[] = { "PackIcon1", "PackIcon2", "PackIcon3", "PackIcon4", "PackIcon5" };
HUDFont smallf, tinyf; HUDFont smallf, tinyf;
int team_score[2], team_ticker[2]; // placeholders for MP display
bool gBlueFlagDropped, gRedFlagDropped; // also placeholders until we know where MP will go.
void Init() void Init()
{ {
@ -296,19 +298,15 @@ class BloodStatusBar : RazeStatusBar
DrawStatNumber("%3d", pPlayer.packSlots[pPlayer.packItemId].curAmount, "SBarNumberInv", x2, y2, 0, 0, nScale); DrawStatNumber("%3d", pPlayer.packSlots[pPlayer.packItemId].curAmount, "SBarNumberInv", x2, y2, 0, 0, nScale);
} }
/*
MP is non-functional, implementation details may change,
so keep the code disabled for now to avoid breaking it by forcing it to compile
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
// //
// //
// //
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
void drawPlayerSlots() void drawPlayerSlots(Array<BloodPlayer> players)
{ {
for (int nRows = (gNetPlayers - 1) / 4; nRows >= 0; nRows--) for (int nRows = (players.Size() - 1) / 4; nRows >= 0; nRows--)
{ {
for (int nCol = 0; nCol < 4; nCol++) for (int nCol = 0; nCol < 4; nCol++)
{ {
@ -324,55 +322,49 @@ class BloodStatusBar : RazeStatusBar
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
void drawPlayerFrags() void drawPlayerFrags(Array<BloodPlayer> players)
{
drawPlayerSlots(players);
for (int i = 0; i < players.Size(); i++)
{
int x = -160 + 80 * (i & 3);
int y = 9 * (i / 4);
int col = players[i].teamId & 3;
int cr = col == 0? Font.CR_UNDEFINED : col == 1? Font.CR_BLUE : Font.CR_RED;
DrawString(tinyf, Raze.PlayerName(i), (x + 4, y), DI_SCREEN_CENTER_TOP, cr, 1., -1, -1);
String gTempStr = String.Format("%2d", players[i].fragCount);
DrawString(tinyf, gTempStr, (x + 76, y), DI_SCREEN_CENTER_TOP, cr, 1., -1, -1);
}
}
//---------------------------------------------------------------------------
//
//
//
//---------------------------------------------------------------------------
void drawPlayerFlags(Array<BloodPlayer> players)
{ {
String gTempStr; String gTempStr;
drawPlayerSlots(); drawPlayerSlots(players);
for (int i = 0, p = connecthead; p >= 0; i++, p = connectpoint2[p]) for (int i = 0; i < players.Size(); i++)
{ {
int x = -160 + 80 * (i & 3); int x = -160 + 80 * (i & 3);
int y = 9 * (i / 4); int y = 9 * (i / 4);
int col = gPlayer[p].teamId & 3; int col = players[i].teamId & 3;
String name = PlayerName(p); gTempStr = String.Format("%s", Raze.PlayerName(i));
gTempStr.Format("%s", name); int cr = col == 0? Font.CR_UNDEFINED : col == 1? Font.CR_BLUE : Font.CR_RED;
int color = CR_UNDEFINED;// todo: remap the colors. (11+col) DrawString(tinyf, gTempStr.MakeUpper(), (x + 4, y), DI_SCREEN_CENTER_TOP, cr, 1., -1, -1);
DrawString(tinyf, gTempStr, x + 4, y, DI_SCREEN_CENTER_TOP, color, 1., -1, -1, 1, 1);
gTempStr.Format("%2d", gPlayer[p].fragCount);
DrawString(tinyf, gTempStr, x + 76, y, DI_SCREEN_CENTER_TOP, color, 1., -1, -1, 1, 1);
}
}
//---------------------------------------------------------------------------
//
//
//
//---------------------------------------------------------------------------
void drawPlayerFlags()
{
FString gTempStr;
drawPlayerSlots();
for (int i = 0, p = connecthead; p >= 0; i++, p = connectpoint2[p])
{
int x = -160 + 80 * (i & 3);
int y = 9 * (i / 4);
int col = gPlayer[p].teamId & 3;
String name = PlayerName(p);
gTempStr.Format("%s", name);
gTempStr.ToUpper();
int color = CR_UNDEFINED;// todo: remap the colors.
DrawString(tinyf, gTempStr, x + 4, y, DI_SCREEN_CENTER_TOP, color, 1., -1, -1, 1, 1);
gTempStr = "F";
x += 76; x += 76;
if (gPlayer[p].hasFlag & 2) if (players[i].hasFlag & 2)
{ {
DrawString(tinyf, gTempStr, x, y, DI_SCREEN_CENTER_TOP, CR_GREEN/ *12* /, 1., -1, -1, 1, 1); DrawString(tinyf, "F", (x, y), DI_SCREEN_CENTER_TOP, Font.CR_BLUE/*12*/, 1., -1, -1);
x -= 6; x -= 6;
} }
if (gPlayer[p].hasFlag & 1) if (players[i].hasFlag & 1)
DrawString(tinyf, gTempStr, x, y, DI_SCREEN_CENTER_TOP, CR_RED/ *11* /, 1., -1, -1, 1, 1); DrawString(tinyf, "F", (x, y), DI_SCREEN_CENTER_TOP, Font.CR_RED/*11*/, 1., -1, -1);
} }
} }
@ -383,22 +375,22 @@ class BloodStatusBar : RazeStatusBar
// //
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
void drawCtfHudVanilla() void drawCtfHudVanilla(Array<BloodPlayer> players)
{ {
FString gTempStr; String gTempStr;
int x = 1, y = 1; int x = 1, y = 1;
if (team_ticker[0] == 0 || (PlayClock & 8)) if (team_ticker[0] == 0 || (PlayClock & 8))
{ {
DrawString(smallf, GStrings("TXT_COLOR_BLUE"), x, y, 0, CR_LIGHTBLUE, 1., -1, -1, 1, 1); DrawString(smallf, "$TXT_COLOR_BLUE", (x, y), 0, Font.CR_LIGHTBLUE, 1., -1, -1);
gTempStr.Format("%-3d", team_score[0]); gTempStr = String.Format("%-3d", team_score[0]);
DrawString(smallf, gTempStr, x, y + 10, 0, CR_LIGHTBLUE, 1., -1, -1, 1, 1); DrawString(smallf, gTempStr, (x, y + 10), 0, Font.CR_LIGHTBLUE, 1., -1, -1);
} }
x = -2; x = -2;
if (team_ticker[1] == 0 || (PlayClock & 8)) if (team_ticker[1] == 0 || (PlayClock & 8))
{ {
DrawString(smallf, GStrings("TXT_COLOR_RED"), x, y, DI_TEXT_ALIGN_RIGHT, CR_BRICK, 1., -1, -1, 1, 1); DrawString(smallf, "$TXT_COLOR_RED", (x, y), DI_TEXT_ALIGN_RIGHT, Font.CR_BRICK, 1., -1, -1);
gTempStr.Format("%3d", team_score[1]); gTempStr = String.Format("%3d", team_score[1]);
DrawString(smallf, gTempStr, x, y + 10, DI_TEXT_ALIGN_RIGHT, CR_BRICK, 1., -1, -1, 1, 1); DrawString(smallf, gTempStr, (x, y + 10), DI_TEXT_ALIGN_RIGHT, Font.CR_BRICK, 1., -1, -1);
} }
} }
@ -423,7 +415,7 @@ class BloodStatusBar : RazeStatusBar
// //
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
void drawCtfHud() void drawCtfHud(BloodPlayer pPlayer, Array<BloodPlayer> players)
{ {
if (hud_size == Hud_Nothing) if (hud_size == Hud_Nothing)
{ {
@ -436,34 +428,36 @@ class BloodStatusBar : RazeStatusBar
bool redFlagTaken = false; bool redFlagTaken = false;
int blueFlagCarrierColor = 0; int blueFlagCarrierColor = 0;
int redFlagCarrierColor = 0; int redFlagCarrierColor = 0;
for (int i = 0, p = connecthead; p >= 0; i++, p = connectpoint2[p]) for (int i = 0; i < players.Size(); i++)
{ {
if ((gPlayer[p].hasFlag & 1) != 0) if ((players[i].hasFlag & 1) != 0)
{ {
blueFlagTaken = true; blueFlagTaken = true;
blueFlagCarrierColor = gPlayer[p].teamId & 3; blueFlagCarrierColor = players[i].teamId & 3;
} }
if ((gPlayer[p].hasFlag & 2) != 0) if ((players[i].hasFlag & 2) != 0)
{ {
redFlagTaken = true; redFlagTaken = true;
redFlagCarrierColor = gPlayer[p].teamId & 3; redFlagCarrierColor = players[i].teamId & 3;
} }
} }
bool meHaveBlueFlag = gMe.hasFlag & 1; bool meHaveBlueFlag = pPlayer.hasFlag & 1;
DrawStatMaskedSprite(meHaveBlueFlag ? "FlagHave" : "FlagHaveNot", 0, 75 - 100, 0, palette:10, scale:0.35, flags:DI_SCREEN_RIGHT_CENTER); int trans10 = Translation.MakeID(Translation_Remap, 10);
int trans2 = Translation.MakeID(Translation_Remap, 2);
DrawImage(meHaveBlueFlag ? "FlagHave" : "FlagHaveNot", (0, 75 - 100), DI_SCREEN_RIGHT_CENTER|DI_ITEM_RELCENTER, scale:(0.35, 0.35), translation:trans10);
if (gBlueFlagDropped) if (gBlueFlagDropped)
DrawStatMaskedSprite("FlagDropped", 305 - 320, 83 - 100, 0, 10, 1, DI_SCREEN_RIGHT_CENTER); DrawImage("FlagDropped", (305 - 320, 83 - 100), DI_SCREEN_RIGHT_CENTER|DI_ITEM_RELCENTER, translation:trans10);
else if (blueFlagTaken) else if (blueFlagTaken)
DrawStatMaskedSprite("FlagTaken", 307 - 320, 77 - 100, 0, blueFlagCarrierColor ? 2 : 10, 65536, DI_SCREEN_RIGHT_CENTER); DrawImage("FlagTaken", (307 - 320, 77 - 100), DI_SCREEN_RIGHT_CENTER|DI_ITEM_RELCENTER, translation:blueFlagCarrierColor ? trans2 : trans10);
flashTeamScore(0, true); flashTeamScore(0, true);
bool meHaveRedFlag = gMe.hasFlag & 2; bool meHaveRedFlag = pPlayer.hasFlag & 2;
DrawStatMaskedSprite(meHaveRedFlag ? "FlagHave" : "FlagHaveNot", 0, 10, 0, 2, 65536 * 0.35, DI_SCREEN_RIGHT_CENTER); DrawImage(meHaveRedFlag ? "FlagHave" : "FlagHaveNot", (0, 10), DI_SCREEN_RIGHT_CENTER|DI_ITEM_RELCENTER, scale:(0.35, 0.35), translation:trans2);
if (gRedFlagDropped) if (gRedFlagDropped)
DrawStatMaskedSprite("FlagDropped", 305 - 320, 17, 0, 2, 65536, DI_SCREEN_RIGHT_CENTER); DrawImage("FlagDropped", (305 - 320, 17), DI_SCREEN_RIGHT_CENTER|DI_ITEM_RELCENTER, translation:trans2);
else if (redFlagTaken) else if (redFlagTaken)
DrawStatMaskedSprite("FlagTaken", 307 - 320, 11, 0, redFlagCarrierColor ? 2 : 10, 65536, DI_SCREEN_RIGHT_CENTER); DrawImage("FlagTaken", (307 - 320, 11), DI_SCREEN_RIGHT_CENTER|DI_ITEM_RELCENTER, translation:redFlagCarrierColor ? trans2 : trans10);
flashTeamScore(1, true); flashTeamScore(1, true);
} }
@ -473,29 +467,30 @@ class BloodStatusBar : RazeStatusBar
// //
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
void drawMultiHUD() void drawMultiHUD(BloodPlayer pPlayer, int nGameType)
{ {
if (nGameType >= 1) if (nGameType >= 1)
{ {
Array<BloodPlayer> players;
Blood.GetPlayers(players);
if (nGameType == 3) if (nGameType == 3)
{ {
if (VanillaMode()) if (hud_ctf_Vanilla)
{ {
drawCtfHudVanilla(); drawCtfHudVanilla(players);
} }
else else
{ {
drawCtfHud(); drawCtfHud(pPlayer, players);
drawPlayerFlags(); drawPlayerFlags(players);
} }
} }
else else
{ {
drawPlayerFrags(); drawPlayerFrags(players);
} }
} }
} }
*/
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
// //
@ -724,7 +719,7 @@ class BloodStatusBar : RazeStatusBar
let pPlayer = Blood.GetViewPlayer(); let pPlayer = Blood.GetViewPlayer();
int y = 0; int y = 0;
/* int nGameType = Blood.getGameType();
if (nGameType == 3) if (nGameType == 3)
{ {
if (pPlayer.teamId & 1) if (pPlayer.teamId & 1)
@ -732,9 +727,8 @@ class BloodStatusBar : RazeStatusBar
else else
nPalette = 10; nPalette = 10;
palette = Translation.MakeID(Translation_Remap, nPalette); nPalette = Translation.MakeID(Translation_Remap, nPalette);
} }
*/
if (hud_size == Hud_full) if (hud_size == Hud_full)
{ {
@ -762,9 +756,7 @@ class BloodStatusBar : RazeStatusBar
BeginHUD(1, false, 320, 200); BeginHUD(1, false, 320, 200);
drawPowerUps(pPlayer); drawPowerUps(pPlayer);
/* drawMultiHUD(pPlayer, nGameType);
drawMultiHUD();
*/
} }
} }