mirror of
https://git.do.srb2.org/KartKrew/Kart-Public.git
synced 2025-01-12 04:41:17 +00:00
Closer to done HUD tweaking?
Splitscreen in Battle is left
This commit is contained in:
parent
d7227a3dcc
commit
7a5bd7c597
5 changed files with 108 additions and 62 deletions
|
@ -3,19 +3,20 @@
|
||||||
# MD5 generation
|
# MD5 generation
|
||||||
set(SRB2_ASSET_ALL
|
set(SRB2_ASSET_ALL
|
||||||
${CMAKE_CURRENT_SOURCE_DIR}/srb2.srb
|
${CMAKE_CURRENT_SOURCE_DIR}/srb2.srb
|
||||||
${CMAKE_CURRENT_SOURCE_DIR}/player.dta
|
${CMAKE_CURRENT_SOURCE_DIR}/chars.kart
|
||||||
${CMAKE_CURRENT_SOURCE_DIR}/rings.dta
|
${CMAKE_CURRENT_SOURCE_DIR}/gfx.kart
|
||||||
${CMAKE_CURRENT_SOURCE_DIR}/zones.dta
|
${CMAKE_CURRENT_SOURCE_DIR}/maps.kart
|
||||||
${CMAKE_CURRENT_SOURCE_DIR}/patch.dta
|
${CMAKE_CURRENT_SOURCE_DIR}/sounds.kart
|
||||||
${CMAKE_CURRENT_SOURCE_DIR}/music.dta
|
${CMAKE_CURRENT_SOURCE_DIR}/music.dta
|
||||||
|
${CMAKE_CURRENT_SOURCE_DIR}/music.kart
|
||||||
)
|
)
|
||||||
|
|
||||||
set(SRB2_ASSET_HASHED
|
set(SRB2_ASSET_HASHED
|
||||||
srb2.srb
|
srb2.srb
|
||||||
player.dta
|
chars.kart
|
||||||
rings.dta
|
gfx.kart
|
||||||
zones.dta
|
maps.kart
|
||||||
patch.dta
|
sounds.kart
|
||||||
)
|
)
|
||||||
|
|
||||||
foreach(SRB2_ASSET ${SRB2_ASSET_HASHED})
|
foreach(SRB2_ASSET ${SRB2_ASSET_HASHED})
|
||||||
|
|
|
@ -156,6 +156,7 @@ set(SRB2_CORE_GAME_SOURCES
|
||||||
p_telept.c
|
p_telept.c
|
||||||
p_tick.c
|
p_tick.c
|
||||||
p_user.c
|
p_user.c
|
||||||
|
k_kart.c
|
||||||
|
|
||||||
p_local.h
|
p_local.h
|
||||||
p_maputl.h
|
p_maputl.h
|
||||||
|
@ -167,6 +168,7 @@ set(SRB2_CORE_GAME_SOURCES
|
||||||
p_slopes.h
|
p_slopes.h
|
||||||
p_spec.h
|
p_spec.h
|
||||||
p_tick.h
|
p_tick.h
|
||||||
|
k_kart.h
|
||||||
)
|
)
|
||||||
|
|
||||||
if(NOT (CMAKE_CXX_COMPILER_ID MATCHES "Clang"))
|
if(NOT (CMAKE_CXX_COMPILER_ID MATCHES "Clang"))
|
||||||
|
|
148
src/k_kart.c
148
src/k_kart.c
|
@ -3759,11 +3759,12 @@ void K_CheckBalloons(void)
|
||||||
|
|
||||||
//{ Patch Definitions
|
//{ Patch Definitions
|
||||||
static patch_t *kp_nodraw;
|
static patch_t *kp_nodraw;
|
||||||
static patch_t *kp_noitem;
|
static patch_t *kp_itembg;
|
||||||
static patch_t *kp_timesticker;
|
static patch_t *kp_timesticker;
|
||||||
static patch_t *kp_timestickerwide;
|
static patch_t *kp_timestickerwide;
|
||||||
static patch_t *kp_lapsticker;
|
static patch_t *kp_lapsticker;
|
||||||
static patch_t *kp_lapstickernarrow;
|
static patch_t *kp_lapstickernarrow;
|
||||||
|
static patch_t *kp_splitlapflag;
|
||||||
static patch_t *kp_balloonsticker;
|
static patch_t *kp_balloonsticker;
|
||||||
static patch_t *kp_balloonstickerwide;
|
static patch_t *kp_balloonstickerwide;
|
||||||
static patch_t *kp_karmasticker;
|
static patch_t *kp_karmasticker;
|
||||||
|
@ -3861,7 +3862,7 @@ void K_LoadKartHUDGraphics(void)
|
||||||
|
|
||||||
// Null Stuff
|
// Null Stuff
|
||||||
kp_nodraw = W_CachePatchName("K_TRNULL", PU_HUDGFX);
|
kp_nodraw = W_CachePatchName("K_TRNULL", PU_HUDGFX);
|
||||||
kp_noitem = W_CachePatchName("K_ITNULL", PU_HUDGFX);
|
kp_itembg = W_CachePatchName("K_ITNULL", PU_HUDGFX);
|
||||||
//kp_neonoitem = W_CachePatchName("KNITNULL", PU_HUDGFX);
|
//kp_neonoitem = W_CachePatchName("KNITNULL", PU_HUDGFX);
|
||||||
|
|
||||||
// Stickers
|
// Stickers
|
||||||
|
@ -3869,6 +3870,7 @@ void K_LoadKartHUDGraphics(void)
|
||||||
kp_timestickerwide = W_CachePatchName("K_STTIMW", PU_HUDGFX);
|
kp_timestickerwide = W_CachePatchName("K_STTIMW", PU_HUDGFX);
|
||||||
kp_lapsticker = W_CachePatchName("K_STLAPS", PU_HUDGFX);
|
kp_lapsticker = W_CachePatchName("K_STLAPS", PU_HUDGFX);
|
||||||
kp_lapstickernarrow = W_CachePatchName("K_STLAPN", PU_HUDGFX);
|
kp_lapstickernarrow = W_CachePatchName("K_STLAPN", PU_HUDGFX);
|
||||||
|
kp_splitlapflag = W_CachePatchName("K_SPTLAP", PU_HUDGFX);
|
||||||
kp_balloonsticker = W_CachePatchName("K_STBALN", PU_HUDGFX);
|
kp_balloonsticker = W_CachePatchName("K_STBALN", PU_HUDGFX);
|
||||||
kp_balloonstickerwide = W_CachePatchName("K_STBALW", PU_HUDGFX);
|
kp_balloonstickerwide = W_CachePatchName("K_STBALW", PU_HUDGFX);
|
||||||
kp_karmasticker = W_CachePatchName("K_STKARM", PU_HUDGFX);
|
kp_karmasticker = W_CachePatchName("K_STKARM", PU_HUDGFX);
|
||||||
|
@ -4088,7 +4090,7 @@ static void K_initKartHUD(void)
|
||||||
SPDM_X = 9; // 9
|
SPDM_X = 9; // 9
|
||||||
SPDM_Y = BASEVIDHEIGHT- 45; // 155
|
SPDM_Y = BASEVIDHEIGHT- 45; // 155
|
||||||
// Position Number
|
// Position Number
|
||||||
POSI_X = BASEVIDWIDTH - 52; // 268
|
POSI_X = BASEVIDWIDTH - 6; // 268
|
||||||
POSI_Y = BASEVIDHEIGHT- 4; // 138
|
POSI_Y = BASEVIDHEIGHT- 4; // 138
|
||||||
// Top-Four Faces
|
// Top-Four Faces
|
||||||
FACE_X = 9; // 9
|
FACE_X = 9; // 9
|
||||||
|
@ -4104,7 +4106,8 @@ static void K_initKartHUD(void)
|
||||||
|
|
||||||
if (splitscreen) // Splitscreen
|
if (splitscreen) // Splitscreen
|
||||||
{
|
{
|
||||||
ITEM_Y = 4;
|
ITEM_X = -2;
|
||||||
|
ITEM_Y = 0;
|
||||||
|
|
||||||
TIME_Y = 4;
|
TIME_Y = 4;
|
||||||
|
|
||||||
|
@ -4117,13 +4120,12 @@ static void K_initKartHUD(void)
|
||||||
if (splitscreen > 1) // 3P/4P Small Splitscreen
|
if (splitscreen > 1) // 3P/4P Small Splitscreen
|
||||||
{
|
{
|
||||||
ITEM_X = 4;
|
ITEM_X = 4;
|
||||||
ITEM_Y = 4;
|
ITEM_Y = 0;
|
||||||
|
|
||||||
LAPS_X = 2;
|
LAPS_X = 3;
|
||||||
LAPS_Y = (BASEVIDHEIGHT/2)-22;
|
LAPS_Y = (BASEVIDHEIGHT/2)-13;
|
||||||
|
|
||||||
POSI_X = 12;
|
POSI_X = (BASEVIDWIDTH/2)-3;
|
||||||
POSI_Y = (BASEVIDHEIGHT/2)-24;
|
|
||||||
|
|
||||||
MINI_X = (3*BASEVIDWIDTH/4);
|
MINI_X = (3*BASEVIDWIDTH/4);
|
||||||
MINI_Y = (3*BASEVIDHEIGHT/4);
|
MINI_Y = (3*BASEVIDHEIGHT/4);
|
||||||
|
@ -4214,9 +4216,12 @@ static void K_drawKartItemRoulette(void)
|
||||||
// Why write V_DrawScaledPatch calls over and over when they're all the same?
|
// Why write V_DrawScaledPatch calls over and over when they're all the same?
|
||||||
// Set to 'no item' just in case.
|
// Set to 'no item' just in case.
|
||||||
patch_t *localpatch = kp_nodraw;
|
patch_t *localpatch = kp_nodraw;
|
||||||
|
patch_t *localbg = kp_itembg;
|
||||||
INT32 X = ITEM_X;
|
INT32 X = ITEM_X;
|
||||||
INT32 splitflags = K_calcSplitFlags(V_SNAPTOTOP|V_SNAPTOLEFT);
|
INT32 splitflags = K_calcSplitFlags(V_SNAPTOTOP|V_SNAPTOLEFT);
|
||||||
if (!splitscreen)
|
if (splitscreen > 1)
|
||||||
|
localbg = kp_itemused1;
|
||||||
|
else
|
||||||
splitflags = V_SNAPTOTOP|V_SNAPTORIGHT;
|
splitflags = V_SNAPTOTOP|V_SNAPTORIGHT;
|
||||||
|
|
||||||
/*if ()
|
/*if ()
|
||||||
|
@ -4270,6 +4275,10 @@ static void K_drawKartItemRoulette(void)
|
||||||
default: break;
|
default: break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (localpatch == kp_nodraw)
|
||||||
|
return;
|
||||||
|
|
||||||
|
V_DrawScaledPatch(X, ITEM_Y, splitflags, localbg);
|
||||||
V_DrawScaledPatch(X, ITEM_Y, splitflags, localpatch);
|
V_DrawScaledPatch(X, ITEM_Y, splitflags, localpatch);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -4281,9 +4290,13 @@ static void K_drawKartRetroItem(void)
|
||||||
// Why write V_DrawScaledPatch calls over and over when they're all the same?
|
// Why write V_DrawScaledPatch calls over and over when they're all the same?
|
||||||
// Set to 'no item' just in case.
|
// Set to 'no item' just in case.
|
||||||
patch_t *localpatch = kp_nodraw;
|
patch_t *localpatch = kp_nodraw;
|
||||||
|
patch_t *localbg = kp_itembg;
|
||||||
INT32 X = ITEM_X;
|
INT32 X = ITEM_X;
|
||||||
INT32 splitflags = K_calcSplitFlags(V_SNAPTOTOP|V_SNAPTOLEFT);
|
INT32 splitflags = K_calcSplitFlags(V_SNAPTOTOP|V_SNAPTOLEFT);
|
||||||
if (!splitscreen)
|
|
||||||
|
if (splitscreen > 1)
|
||||||
|
localbg = kp_itemused1;
|
||||||
|
else
|
||||||
splitflags = V_SNAPTOTOP|V_SNAPTORIGHT;
|
splitflags = V_SNAPTOTOP|V_SNAPTORIGHT;
|
||||||
|
|
||||||
// I'm doing this a little weird and drawing mostly in reverse order
|
// I'm doing this a little weird and drawing mostly in reverse order
|
||||||
|
@ -4292,7 +4305,7 @@ static void K_drawKartRetroItem(void)
|
||||||
// Boo is first, because we're drawing it on top of the player's current item
|
// Boo is first, because we're drawing it on top of the player's current item
|
||||||
if ((stplyr->kartstuff[k_bootaketimer] > 0 || stplyr->kartstuff[k_boostolentimer] > 0)
|
if ((stplyr->kartstuff[k_bootaketimer] > 0 || stplyr->kartstuff[k_boostolentimer] > 0)
|
||||||
&& (leveltime & 2)) localpatch = kp_boosteal;
|
&& (leveltime & 2)) localpatch = kp_boosteal;
|
||||||
else if (stplyr->kartstuff[k_boostolentimer] > 0 && !(leveltime & 2)) localpatch = kp_noitem;
|
else if (stplyr->kartstuff[k_boostolentimer] > 0 && !(leveltime & 2)) localpatch = kp_nodraw;
|
||||||
else if (stplyr->kartstuff[k_kitchensink] == 1) localpatch = kp_kitchensink;
|
else if (stplyr->kartstuff[k_kitchensink] == 1) localpatch = kp_kitchensink;
|
||||||
else if (stplyr->kartstuff[k_feather] & 1) localpatch = kp_feather;
|
else if (stplyr->kartstuff[k_feather] & 1) localpatch = kp_feather;
|
||||||
else if (stplyr->kartstuff[k_lightning] == 1) localpatch = kp_lightning;
|
else if (stplyr->kartstuff[k_lightning] == 1) localpatch = kp_lightning;
|
||||||
|
@ -4309,16 +4322,20 @@ static void K_drawKartRetroItem(void)
|
||||||
else if (stplyr->kartstuff[k_star] == 1) localpatch = kp_star;
|
else if (stplyr->kartstuff[k_star] == 1) localpatch = kp_star;
|
||||||
else if (stplyr->kartstuff[k_goldshroom] == 1
|
else if (stplyr->kartstuff[k_goldshroom] == 1
|
||||||
|| (stplyr->kartstuff[k_goldshroomtimer] > 1 && (leveltime & 1))) localpatch = kp_goldshroom;
|
|| (stplyr->kartstuff[k_goldshroomtimer] > 1 && (leveltime & 1))) localpatch = kp_goldshroom;
|
||||||
else if (stplyr->kartstuff[k_goldshroomtimer] > 1 && !(leveltime & 1)) localpatch = kp_noitem;
|
else if (stplyr->kartstuff[k_goldshroomtimer] > 1 && !(leveltime & 1)) localpatch = kp_nodraw;
|
||||||
else if (stplyr->kartstuff[k_megashroom] == 1
|
else if (stplyr->kartstuff[k_megashroom] == 1
|
||||||
|| (stplyr->kartstuff[k_growshrinktimer] > 1 && (leveltime & 1))) localpatch = kp_megashroom;
|
|| (stplyr->kartstuff[k_growshrinktimer] > 1 && (leveltime & 1))) localpatch = kp_megashroom;
|
||||||
else if (stplyr->kartstuff[k_growshrinktimer] > 1 && !(leveltime & 1)) localpatch = kp_noitem;
|
else if (stplyr->kartstuff[k_growshrinktimer] > 1 && !(leveltime & 1)) localpatch = kp_nodraw;
|
||||||
else if (stplyr->kartstuff[k_mushroom] & 4) localpatch = kp_triplemushroom;
|
else if (stplyr->kartstuff[k_mushroom] & 4) localpatch = kp_triplemushroom;
|
||||||
else if (stplyr->kartstuff[k_mushroom] & 2) localpatch = kp_doublemushroom;
|
else if (stplyr->kartstuff[k_mushroom] & 2) localpatch = kp_doublemushroom;
|
||||||
else if (stplyr->kartstuff[k_mushroom] == 1) localpatch = kp_mushroom;
|
else if (stplyr->kartstuff[k_mushroom] == 1) localpatch = kp_mushroom;
|
||||||
else if (stplyr->kartstuff[k_boo] == 1) localpatch = kp_boo;
|
else if (stplyr->kartstuff[k_boo] == 1) localpatch = kp_boo;
|
||||||
else if (stplyr->kartstuff[k_magnet] == 1) localpatch = kp_magnet;
|
else if (stplyr->kartstuff[k_magnet] == 1) localpatch = kp_magnet;
|
||||||
|
|
||||||
|
if (localpatch == kp_nodraw)
|
||||||
|
return;
|
||||||
|
|
||||||
|
V_DrawScaledPatch(X, ITEM_Y, splitflags, localbg);
|
||||||
V_DrawScaledPatch(X, ITEM_Y, splitflags, localpatch);
|
V_DrawScaledPatch(X, ITEM_Y, splitflags, localpatch);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -4427,7 +4444,7 @@ static void K_drawKartTimestamp(void)
|
||||||
// TIME_Y = 6; // 6
|
// TIME_Y = 6; // 6
|
||||||
|
|
||||||
INT32 TIME_XB;
|
INT32 TIME_XB;
|
||||||
INT32 splitflags = K_calcSplitFlags(V_SNAPTOTOP|V_SNAPTORIGHT);
|
INT32 splitflags = K_calcSplitFlags(V_SNAPTOTOP|V_SNAPTOLEFT);
|
||||||
|
|
||||||
V_DrawScaledPatch(TIME_X, TIME_Y, splitflags, kp_timestickerwide);
|
V_DrawScaledPatch(TIME_X, TIME_Y, splitflags, kp_timestickerwide);
|
||||||
|
|
||||||
|
@ -4489,19 +4506,13 @@ static void K_DrawKartPositionNum(INT32 num)
|
||||||
patch_t *localpatch = kp_positionnum[0][0];
|
patch_t *localpatch = kp_positionnum[0][0];
|
||||||
INT32 splitflags = K_calcSplitFlags(V_SNAPTOBOTTOM|V_SNAPTORIGHT);
|
INT32 splitflags = K_calcSplitFlags(V_SNAPTOBOTTOM|V_SNAPTORIGHT);
|
||||||
|
|
||||||
if ((stplyr->kartstuff[k_positiondelay] || stplyr->exiting) && !splitscreen)
|
if (stplyr->kartstuff[k_positiondelay] || stplyr->exiting)
|
||||||
scale *= 2;
|
scale = FixedMul(scale, 3*FRACUNIT/2);
|
||||||
else if (!(stplyr->kartstuff[k_positiondelay] || stplyr->exiting) && splitscreen)
|
if (splitscreen > 1)
|
||||||
scale /= 2;
|
scale /= 2;
|
||||||
|
|
||||||
W = FixedMul(W<<FRACBITS, scale)>>FRACBITS;
|
W = FixedMul(W<<FRACBITS, scale)>>FRACBITS;
|
||||||
|
|
||||||
if ((splitscreen < 2) && !(splitflags & V_HORZSCREEN))
|
|
||||||
{
|
|
||||||
X -= W;
|
|
||||||
splitflags = K_calcSplitFlags(V_SNAPTOBOTTOM|V_SNAPTOLEFT);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Special case for 0
|
// Special case for 0
|
||||||
if (!num)
|
if (!num)
|
||||||
{
|
{
|
||||||
|
@ -4726,12 +4737,24 @@ static void K_drawKartLaps(void)
|
||||||
INT32 splitflags = K_calcSplitFlags(V_SNAPTOBOTTOM|V_SNAPTOLEFT);
|
INT32 splitflags = K_calcSplitFlags(V_SNAPTOBOTTOM|V_SNAPTOLEFT);
|
||||||
INT32 X = LAPS_X;
|
INT32 X = LAPS_X;
|
||||||
|
|
||||||
V_DrawScaledPatch(X, LAPS_Y, splitflags, kp_lapsticker);
|
if (splitscreen > 1)
|
||||||
|
{
|
||||||
|
V_DrawScaledPatch(X, LAPS_Y, splitflags, kp_splitlapflag);
|
||||||
|
|
||||||
if (stplyr->exiting)
|
if (stplyr->exiting)
|
||||||
V_DrawKartString(X+33, LAPS_Y+3, splitflags, "FIN");
|
V_DrawString(X+13, LAPS_Y+1, splitflags, "FIN");
|
||||||
|
else
|
||||||
|
V_DrawString(X+13, LAPS_Y+1, splitflags, va("%d/%d", stplyr->laps+1, cv_numlaps.value));
|
||||||
|
}
|
||||||
else
|
else
|
||||||
V_DrawKartString(X+33, LAPS_Y+3, splitflags, va("%d/%d", stplyr->laps+1, cv_numlaps.value));
|
{
|
||||||
|
V_DrawScaledPatch(X, LAPS_Y, splitflags, kp_lapsticker);
|
||||||
|
|
||||||
|
if (stplyr->exiting)
|
||||||
|
V_DrawKartString(X+33, LAPS_Y+3, splitflags, "FIN");
|
||||||
|
else
|
||||||
|
V_DrawKartString(X+33, LAPS_Y+3, splitflags, va("%d/%d", stplyr->laps+1, cv_numlaps.value));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void K_drawKartSpeedometer(void)
|
static void K_drawKartSpeedometer(void)
|
||||||
|
@ -4888,7 +4911,15 @@ static void K_UnLoadIconGraphics(INT32 skinnum)
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
void K_drawKartMinimap(void)
|
void K_ReloadSkinIconGraphics(void)
|
||||||
|
{
|
||||||
|
INT32 i;
|
||||||
|
|
||||||
|
for (i = 0; i < numskins; i++)
|
||||||
|
K_LoadIconGraphics(skins[i].iconprefix, i);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void K_drawKartMinimap(void)
|
||||||
{
|
{
|
||||||
fixed_t amnumxpos;
|
fixed_t amnumxpos;
|
||||||
fixed_t amnumypos;
|
fixed_t amnumypos;
|
||||||
|
@ -4904,10 +4935,13 @@ void K_drawKartMinimap(void)
|
||||||
if (!(Playing() && gamestate == GS_LEVEL))
|
if (!(Playing() && gamestate == GS_LEVEL))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
if (stplyr != &players[displayplayer])
|
||||||
|
return;
|
||||||
|
|
||||||
lumpnum = W_CheckNumForName(va("%sR", G_BuildMapName(gamemap)));
|
lumpnum = W_CheckNumForName(va("%sR", G_BuildMapName(gamemap)));
|
||||||
|
|
||||||
if (lumpnum != -1)
|
if (lumpnum != -1)
|
||||||
AutomapPic = W_CachePatchName(va("%sR", G_BuildMapName(gamemap)), PU_CACHE);
|
AutomapPic = W_CachePatchName(va("%sR", G_BuildMapName(gamemap)), PU_HUDGFX);
|
||||||
else
|
else
|
||||||
return; // no pic, just get outta here
|
return; // no pic, just get outta here
|
||||||
|
|
||||||
|
@ -4995,6 +5029,7 @@ void K_drawKartMinimap(void)
|
||||||
|
|
||||||
static void K_drawBattleFullscreen(void)
|
static void K_drawBattleFullscreen(void)
|
||||||
{
|
{
|
||||||
|
INT32 x = BASEVIDWIDTH/2;
|
||||||
INT32 y = -64+(stplyr->kartstuff[k_cardanimation]); // card animation goes from 0 to 164, 164 is the middle of the screen
|
INT32 y = -64+(stplyr->kartstuff[k_cardanimation]); // card animation goes from 0 to 164, 164 is the middle of the screen
|
||||||
|
|
||||||
if (splitscreen)
|
if (splitscreen)
|
||||||
|
@ -5004,33 +5039,37 @@ static void K_drawBattleFullscreen(void)
|
||||||
y = 232-(stplyr->kartstuff[k_cardanimation]/2);
|
y = 232-(stplyr->kartstuff[k_cardanimation]/2);
|
||||||
else
|
else
|
||||||
y = -32+(stplyr->kartstuff[k_cardanimation]/2);
|
y = -32+(stplyr->kartstuff[k_cardanimation]/2);
|
||||||
|
|
||||||
|
if (splitscreen > 1)
|
||||||
|
{
|
||||||
|
if (stplyr == &players[secondarydisplayplayer] || stplyr == &players[fourthdisplayplayer])
|
||||||
|
x = 3*BASEVIDWIDTH/4;
|
||||||
|
else
|
||||||
|
x = BASEVIDWIDTH/4;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (stplyr == &players[secondarydisplayplayer])
|
||||||
|
x = BASEVIDWIDTH-96;
|
||||||
|
else
|
||||||
|
x = 96;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else
|
|
||||||
|
if (stplyr == &players[displayplayer])
|
||||||
V_DrawFadeScreen();
|
V_DrawFadeScreen();
|
||||||
|
|
||||||
if (stplyr->exiting)
|
if (stplyr->exiting)
|
||||||
{
|
{
|
||||||
if (splitscreen == 1)
|
if (stplyr->kartstuff[k_balloon])
|
||||||
{
|
V_DrawScaledPatch(x, y, 0, kp_battlewin);
|
||||||
if (stplyr == &players[displayplayer])
|
|
||||||
V_DrawFadeScreen();
|
|
||||||
if (stplyr->kartstuff[k_balloon])
|
|
||||||
V_DrawScaledPatch(96, y, 0, kp_battlewin);
|
|
||||||
else
|
|
||||||
V_DrawScaledPatch(BASEVIDWIDTH-96, y, 0, kp_battlelose);
|
|
||||||
}
|
|
||||||
else
|
else
|
||||||
{
|
V_DrawScaledPatch(x, y, 0, kp_battlelose);
|
||||||
if (stplyr->kartstuff[k_balloon])
|
|
||||||
V_DrawScaledPatch(BASEVIDWIDTH/2, y, 0, kp_battlewin);
|
|
||||||
else
|
|
||||||
V_DrawScaledPatch(BASEVIDWIDTH/2, y, 0, kp_battlelose);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
else if (stplyr->kartstuff[k_balloon] <= 0 && stplyr->kartstuff[k_comebacktimer] && cv_kartcomeback.value)
|
else if (stplyr->kartstuff[k_balloon] <= 0 && stplyr->kartstuff[k_comebacktimer] && cv_kartcomeback.value)
|
||||||
{
|
{
|
||||||
INT32 t = stplyr->kartstuff[k_comebacktimer]/TICRATE;
|
INT32 t = stplyr->kartstuff[k_comebacktimer]/TICRATE;
|
||||||
INT32 x = BASEVIDWIDTH/2;
|
INT32 tx = BASEVIDWIDTH/2;
|
||||||
|
|
||||||
while (t)
|
while (t)
|
||||||
{
|
{
|
||||||
|
@ -5039,12 +5078,12 @@ static void K_drawBattleFullscreen(void)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!stplyr->kartstuff[k_comebackshowninfo] && !splitscreen)
|
if (!stplyr->kartstuff[k_comebackshowninfo] && !splitscreen)
|
||||||
V_DrawScaledPatch(BASEVIDWIDTH/2, y, 0, kp_battleinfo);
|
V_DrawScaledPatch(x, y, 0, kp_battleinfo);
|
||||||
else
|
else
|
||||||
V_DrawScaledPatch(BASEVIDWIDTH/2, y, 0, kp_battlewait);
|
V_DrawScaledPatch(x, y, 0, kp_battlewait);
|
||||||
|
|
||||||
V_DrawScaledPatch(BASEVIDWIDTH/2, (BASEVIDHEIGHT/2) + 66, 0, kp_timeoutsticker);
|
V_DrawScaledPatch(x, (BASEVIDHEIGHT/2) + 66, 0, kp_timeoutsticker);
|
||||||
V_DrawKartString(x, (BASEVIDHEIGHT/2) + 66, 0, va("%d", stplyr->kartstuff[k_comebacktimer]/TICRATE));
|
V_DrawKartString(tx, (BASEVIDHEIGHT/2) + 66, 0, va("%d", stplyr->kartstuff[k_comebacktimer]/TICRATE));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -5236,8 +5275,11 @@ void K_drawKartHUD(void)
|
||||||
// Draw the lap counter
|
// Draw the lap counter
|
||||||
K_drawKartLaps();
|
K_drawKartLaps();
|
||||||
|
|
||||||
// Draw the numerical position
|
if (!modeattacking)
|
||||||
K_DrawKartPositionNum(stplyr->kartstuff[k_position]);
|
{
|
||||||
|
// Draw the numerical position
|
||||||
|
K_DrawKartPositionNum(stplyr->kartstuff[k_position]);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else if (gametype == GT_MATCH) // Battle-only
|
else if (gametype == GT_MATCH) // Battle-only
|
||||||
{
|
{
|
||||||
|
|
|
@ -44,7 +44,7 @@ void K_LoadKartHUDGraphics(void);
|
||||||
fixed_t K_FindCheckX(fixed_t px, fixed_t py, angle_t ang, fixed_t mx, fixed_t my);
|
fixed_t K_FindCheckX(fixed_t px, fixed_t py, angle_t ang, fixed_t mx, fixed_t my);
|
||||||
void K_drawKartHUD(void);
|
void K_drawKartHUD(void);
|
||||||
void K_LoadIconGraphics(char *facestr, INT32 skinnum);
|
void K_LoadIconGraphics(char *facestr, INT32 skinnum);
|
||||||
void K_drawMinimap(void);
|
void K_ReloadSkinIconGraphics(void);
|
||||||
|
|
||||||
// =========================================================================
|
// =========================================================================
|
||||||
#endif // __K_KART__
|
#endif // __K_KART__
|
||||||
|
|
|
@ -3166,6 +3166,7 @@ boolean P_AddWadFile(const char *wadfilename, char **firstmapname)
|
||||||
HU_LoadGraphics();
|
HU_LoadGraphics();
|
||||||
ST_LoadGraphics();
|
ST_LoadGraphics();
|
||||||
ST_ReloadSkinFaceGraphics();
|
ST_ReloadSkinFaceGraphics();
|
||||||
|
K_ReloadSkinIconGraphics();
|
||||||
|
|
||||||
//
|
//
|
||||||
// look for skins
|
// look for skins
|
||||||
|
|
Loading…
Reference in a new issue