mirror of
https://git.do.srb2.org/KartKrew/Kart-Public.git
synced 2025-01-14 13:51:31 +00:00
Support playback menu for record attack replays too
This commit is contained in:
parent
1eff7bfbe8
commit
f38d56d4a6
3 changed files with 50 additions and 26 deletions
|
@ -7036,6 +7036,8 @@ void G_DoPlayDemo(char *defdemoname)
|
||||||
pdemoname = ZZ_Alloc(strlen(n)+1);
|
pdemoname = ZZ_Alloc(strlen(n)+1);
|
||||||
strcpy(pdemoname,n);
|
strcpy(pdemoname,n);
|
||||||
|
|
||||||
|
M_SetPlaybackMenuPointer();
|
||||||
|
|
||||||
// Internal if no extension, external if one exists
|
// Internal if no extension, external if one exists
|
||||||
if (FIL_CheckExtension(defdemoname))
|
if (FIL_CheckExtension(defdemoname))
|
||||||
{
|
{
|
||||||
|
|
65
src/m_menu.c
65
src/m_menu.c
|
@ -571,20 +571,20 @@ static menuitem_t PlaybackMenu[] =
|
||||||
{
|
{
|
||||||
{IT_CALL | IT_STRING, "M_PHIDE", "Hide Menu", M_SelectableClearMenus, 0},
|
{IT_CALL | IT_STRING, "M_PHIDE", "Hide Menu", M_SelectableClearMenus, 0},
|
||||||
|
|
||||||
{IT_CALL | IT_STRING, "M_PREW", "Rewind", M_PlaybackRewind, 24},
|
{IT_CALL | IT_STRING, "M_PREW", "Rewind", M_PlaybackRewind, 20},
|
||||||
{IT_CALL | IT_STRING, "M_PPAUSE", "Pause", M_PlaybackPause, 40},
|
{IT_CALL | IT_STRING, "M_PPAUSE", "Pause", M_PlaybackPause, 36},
|
||||||
{IT_CALL | IT_STRING, "M_PRESUM", "Resume", M_PlaybackPause, 40},
|
{IT_CALL | IT_STRING, "M_PRESUM", "Resume", M_PlaybackPause, 36},
|
||||||
{IT_CALL | IT_STRING, "M_PFFWD", "Fast-Foward", M_PlaybackFastForward, 56},
|
{IT_CALL | IT_STRING, "M_PFFWD", "Fast-Foward", M_PlaybackFastForward, 52},
|
||||||
{IT_CALL | IT_STRING, "M_PFADV", "Advance Frame", M_PlaybackAdvance, 56},
|
{IT_CALL | IT_STRING, "M_PFADV", "Advance Frame", M_PlaybackAdvance, 52},
|
||||||
|
|
||||||
{IT_ARROWS | IT_STRING, "M_PVIEWS", "View Count", M_PlaybackSetViews, 80},
|
{IT_ARROWS | IT_STRING, "M_PVIEWS", "View Count", M_PlaybackSetViews, 72},
|
||||||
{IT_ARROWS | IT_STRING, "M_PNVIEW", "Viewpoint", M_PlaybackAdjustView, 96},
|
{IT_ARROWS | IT_STRING, "M_PNVIEW", "Viewpoint", M_PlaybackAdjustView, 88},
|
||||||
{IT_ARROWS | IT_STRING, "M_PNVIEW", "Viewpoint 2", M_PlaybackAdjustView, 112},
|
{IT_ARROWS | IT_STRING, "M_PNVIEW", "Viewpoint 2", M_PlaybackAdjustView, 104},
|
||||||
{IT_ARROWS | IT_STRING, "M_PNVIEW", "Viewpoint 3", M_PlaybackAdjustView, 128},
|
{IT_ARROWS | IT_STRING, "M_PNVIEW", "Viewpoint 3", M_PlaybackAdjustView, 120},
|
||||||
{IT_ARROWS | IT_STRING, "M_PNVIEW", "Viewpoint 4", M_PlaybackAdjustView, 144},
|
{IT_ARROWS | IT_STRING, "M_PNVIEW", "Viewpoint 4", M_PlaybackAdjustView, 136},
|
||||||
|
|
||||||
{IT_CALL | IT_STRING, "M_POPTS", "More Options...", M_ReplayHut, 168},
|
{IT_CALL | IT_STRING, "M_POPTS", "More Options...", M_ReplayHut, 156},
|
||||||
{IT_CALL | IT_STRING, "M_PEXIT", "Stop Playback", M_PlaybackQuit, 184},
|
{IT_CALL | IT_STRING, "M_PEXIT", "Stop Playback", M_PlaybackQuit, 172},
|
||||||
};
|
};
|
||||||
typedef enum
|
typedef enum
|
||||||
{
|
{
|
||||||
|
@ -1702,7 +1702,7 @@ menu_t PlaybackMenuDef = {
|
||||||
NULL,
|
NULL,
|
||||||
PlaybackMenu,
|
PlaybackMenu,
|
||||||
M_DrawPlaybackMenu,
|
M_DrawPlaybackMenu,
|
||||||
BASEVIDWIDTH/2 - 100, 2,
|
BASEVIDWIDTH/2 - 94, 2,
|
||||||
0,
|
0,
|
||||||
NULL
|
NULL
|
||||||
};
|
};
|
||||||
|
@ -3057,14 +3057,6 @@ void M_Drawer(void)
|
||||||
//
|
//
|
||||||
void M_StartControlPanel(void)
|
void M_StartControlPanel(void)
|
||||||
{
|
{
|
||||||
// time attack HACK
|
|
||||||
if (modeattacking && demo.playback)
|
|
||||||
{
|
|
||||||
G_CheckDemoStatus();
|
|
||||||
S_ChangeMusicInternal("racent", true);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// intro might call this repeatedly
|
// intro might call this repeatedly
|
||||||
if (menuactive)
|
if (menuactive)
|
||||||
{
|
{
|
||||||
|
@ -5708,6 +5700,11 @@ static void M_HutStartReplay(INT32 choice)
|
||||||
G_DoPlayDemo(demolist[dir_on[menudepthleft]].filepath);
|
G_DoPlayDemo(demolist[dir_on[menudepthleft]].filepath);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void M_SetPlaybackMenuPointer(void)
|
||||||
|
{
|
||||||
|
itemOn = playback_pause;
|
||||||
|
}
|
||||||
|
|
||||||
static void M_DrawPlaybackMenu(void)
|
static void M_DrawPlaybackMenu(void)
|
||||||
{
|
{
|
||||||
INT16 i;
|
INT16 i;
|
||||||
|
@ -5725,11 +5722,30 @@ static void M_DrawPlaybackMenu(void)
|
||||||
PlaybackMenu[playback_pause].status = PlaybackMenu[playback_fastforward].status = IT_CALL|IT_STRING;
|
PlaybackMenu[playback_pause].status = PlaybackMenu[playback_fastforward].status = IT_CALL|IT_STRING;
|
||||||
PlaybackMenu[playback_resume].status = PlaybackMenu[playback_advanceframe].status = IT_DISABLED;
|
PlaybackMenu[playback_resume].status = PlaybackMenu[playback_advanceframe].status = IT_DISABLED;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (modeattacking)
|
||||||
|
{
|
||||||
|
for (i = playback_viewcount; i <= playback_view4; i++)
|
||||||
|
PlaybackMenu[i].status = IT_DISABLED;
|
||||||
|
|
||||||
|
PlaybackMenu[playback_moreoptions].alphaKey = 72;
|
||||||
|
PlaybackMenu[playback_quit].alphaKey = 88;
|
||||||
|
|
||||||
|
currentMenu->x = BASEVIDWIDTH/2 - 52;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
for (i = 0; i <= splitscreen; i++)
|
for (i = 0; i <= splitscreen; i++)
|
||||||
PlaybackMenu[playback_view1+i].status = IT_ARROWS|IT_STRING;
|
PlaybackMenu[playback_view1+i].status = IT_ARROWS|IT_STRING;
|
||||||
for (i = splitscreen+1; i < 4; i++)
|
for (i = splitscreen+1; i < 4; i++)
|
||||||
PlaybackMenu[playback_view1+i].status = IT_DISABLED;
|
PlaybackMenu[playback_view1+i].status = IT_DISABLED;
|
||||||
|
|
||||||
|
PlaybackMenu[playback_moreoptions].alphaKey = 156;
|
||||||
|
PlaybackMenu[playback_quit].alphaKey = 172;
|
||||||
|
|
||||||
|
currentMenu->x = BASEVIDWIDTH/2 - 94;
|
||||||
|
}
|
||||||
|
|
||||||
// wip
|
// wip
|
||||||
//M_DrawTextBox(currentMenu->x-68, currentMenu->y-7, 15, 15);
|
//M_DrawTextBox(currentMenu->x-68, currentMenu->y-7, 15, 15);
|
||||||
//M_DrawCenteredMenu();
|
//M_DrawCenteredMenu();
|
||||||
|
@ -5740,6 +5756,8 @@ static void M_DrawPlaybackMenu(void)
|
||||||
|
|
||||||
if (i >= playback_view1 && i <= playback_view4)
|
if (i >= playback_view1 && i <= playback_view4)
|
||||||
{
|
{
|
||||||
|
if (modeattacking) continue;
|
||||||
|
|
||||||
if (splitscreen >= i - playback_view1)
|
if (splitscreen >= i - playback_view1)
|
||||||
{
|
{
|
||||||
INT32 ply = *G_GetDisplayplayerPtr(i - playback_view1 + 1);
|
INT32 ply = *G_GetDisplayplayerPtr(i - playback_view1 + 1);
|
||||||
|
@ -5873,7 +5891,10 @@ static void M_PlaybackQuit(INT32 choice)
|
||||||
if (demo.inreplayhut)
|
if (demo.inreplayhut)
|
||||||
M_ReplayHut(choice);
|
M_ReplayHut(choice);
|
||||||
else if (modeattacking)
|
else if (modeattacking)
|
||||||
S_ChangeMusicInternal("racent", true); // ???
|
{
|
||||||
|
M_EndModeAttackRun();
|
||||||
|
S_ChangeMusicInternal("racent", true);
|
||||||
|
}
|
||||||
else
|
else
|
||||||
D_StartTitle();
|
D_StartTitle();
|
||||||
}
|
}
|
||||||
|
|
|
@ -236,6 +236,7 @@ void Screenshot_option_Onchange(void);
|
||||||
void Addons_option_Onchange(void);
|
void Addons_option_Onchange(void);
|
||||||
|
|
||||||
void M_ReplayHut(INT32 choice);
|
void M_ReplayHut(INT32 choice);
|
||||||
|
void M_SetPlaybackMenuPointer(void);
|
||||||
|
|
||||||
INT32 HU_GetHighlightColor(void);
|
INT32 HU_GetHighlightColor(void);
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue