mirror of
https://git.do.srb2.org/STJr/SRB2.git
synced 2025-01-18 15:32:33 +00:00
Significant improvements to the Character select screen in preperation of implementing unlockable characters.
* Characters disabled through SOC are outright removed. No awkward gap in scrolling - no hint they were ever there in the first place. * Vertical loop - the character select images are visually continuous. No matter where you are in the chain, you'll always see a hint of the character above or below your current selection in the chain. * Smooth scrolling - Moto and Prime showed me a gfy from back during 2.1 development where it was super smooth. I didn't make it as slow as that one, but the smoothness was easy to add and the reason it was removed previously - gaps in the character select leading to varying speeds - is no longer relevant.
This commit is contained in:
parent
214cd404bd
commit
8ab32ca93a
1 changed files with 59 additions and 19 deletions
78
src/m_menu.c
78
src/m_menu.c
|
@ -170,6 +170,7 @@ static saveinfo_t savegameinfo[MAXSAVEGAMES]; // Extra info about the save games
|
|||
INT16 startmap; // Mario, NiGHTS, or just a plain old normal game?
|
||||
|
||||
static INT16 itemOn = 1; // menu item skull is on, Hack by Tails 09-18-2002
|
||||
static boolean lastdirection = true; // toaster - Only You Can Prevent Hacks - true is for forward, false is for backwards
|
||||
static INT16 skullAnimCounter = 10; // skull animation counter
|
||||
|
||||
static boolean setupcontrols_secondaryplayer;
|
||||
|
@ -2036,6 +2037,7 @@ static boolean M_ChangeStringCvar(INT32 choice)
|
|||
static void M_NextOpt(void)
|
||||
{
|
||||
INT16 oldItemOn = itemOn; // prevent infinite loop
|
||||
lastdirection = true;
|
||||
|
||||
do
|
||||
{
|
||||
|
@ -2049,6 +2051,7 @@ static void M_NextOpt(void)
|
|||
static void M_PrevOpt(void)
|
||||
{
|
||||
INT16 oldItemOn = itemOn; // prevent infinite loop
|
||||
lastdirection = false;
|
||||
|
||||
do
|
||||
{
|
||||
|
@ -4794,7 +4797,7 @@ static void M_DrawSetupChoosePlayerMenu(void)
|
|||
{
|
||||
const INT32 my = 24;
|
||||
patch_t *patch;
|
||||
INT32 i, o, j;
|
||||
INT32 i, o, j, prev, next;
|
||||
char *picname;
|
||||
|
||||
// Black BG
|
||||
|
@ -4804,29 +4807,55 @@ static void M_DrawSetupChoosePlayerMenu(void)
|
|||
// Character select profile images!1
|
||||
M_DrawTextBox(0, my, 16, 20);
|
||||
|
||||
if (abs(itemOn*128*FRACUNIT - char_scroll) > 256*FRACUNIT)
|
||||
char_scroll = itemOn*128*FRACUNIT;
|
||||
else if (itemOn*128*FRACUNIT - char_scroll > 128*FRACUNIT)
|
||||
char_scroll += 48*FRACUNIT;
|
||||
else if (itemOn*128*FRACUNIT - char_scroll < -128*FRACUNIT)
|
||||
char_scroll -= 48*FRACUNIT;
|
||||
else if (itemOn*128*FRACUNIT > char_scroll+16*FRACUNIT)
|
||||
char_scroll += 16*FRACUNIT;
|
||||
else if (itemOn*128*FRACUNIT < char_scroll-16*FRACUNIT)
|
||||
char_scroll -= 16*FRACUNIT;
|
||||
i = (itemOn*128 - char_scroll/FRACUNIT);
|
||||
|
||||
if (abs(i) > 128)
|
||||
{
|
||||
o = (lastdirection) ? -1 : 1;
|
||||
char_scroll = (itemOn+o)*128*FRACUNIT;
|
||||
}
|
||||
|
||||
i = (itemOn*128 - char_scroll/FRACUNIT);
|
||||
|
||||
if (abs(i) > 1)
|
||||
char_scroll += i*FRACUNIT>>2;
|
||||
else // close enough.
|
||||
char_scroll = itemOn*128*FRACUNIT; // just be exact now.
|
||||
i = (char_scroll+16*FRACUNIT)/(128*FRACUNIT);
|
||||
o = ((char_scroll/FRACUNIT)+16)%128;
|
||||
|
||||
o = ((char_scroll / FRACUNIT) + 16);
|
||||
if (lastdirection)
|
||||
o += 128; // This one-directional hack is to prevent visual glitches when going from the (currentMenu->numitems)nd character to the 1st character.
|
||||
i = (o / 128);
|
||||
o = (o % 128);
|
||||
|
||||
// subtract 1 from i to counteract the +128 from the prior hack, if we made it happen
|
||||
if (lastdirection)
|
||||
{
|
||||
j = i;
|
||||
do
|
||||
{
|
||||
i--;
|
||||
if (i < 0)
|
||||
i = (currentMenu->numitems - 1);
|
||||
} while (i != j && PlayerMenu[i].status == IT_DISABLED); // Skip over all disabled characters.
|
||||
}
|
||||
|
||||
// prev character
|
||||
if (i-1 >= 0 && PlayerMenu[i-1].status != IT_DISABLED
|
||||
prev = i;
|
||||
do
|
||||
{
|
||||
prev--;
|
||||
if (prev < 0)
|
||||
prev = (currentMenu->numitems - 1);
|
||||
} while (prev != i && PlayerMenu[prev].status == IT_DISABLED); // Skip over all disabled characters.
|
||||
|
||||
if (prev >= 0 && PlayerMenu[prev].status != IT_DISABLED
|
||||
&& o < 32)
|
||||
{
|
||||
picname = description[i-1].picname;
|
||||
picname = description[prev].picname;
|
||||
if (picname[0] == '\0')
|
||||
{
|
||||
picname = strtok(Z_StrDup(description[i-1].skinname), "&");
|
||||
picname = strtok(Z_StrDup(description[prev].skinname), "&");
|
||||
for (j = 0; j < numskins; j++)
|
||||
if (stricmp(skins[j].name, picname) == 0)
|
||||
{
|
||||
|
@ -4846,13 +4875,21 @@ static void M_DrawSetupChoosePlayerMenu(void)
|
|||
}
|
||||
|
||||
// next character
|
||||
if (i+1 < currentMenu->numitems && PlayerMenu[i+1].status != IT_DISABLED
|
||||
next = i;
|
||||
do
|
||||
{
|
||||
next++;
|
||||
if (next >= currentMenu->numitems)
|
||||
next = 0;
|
||||
} while (next != i && PlayerMenu[next].status == IT_DISABLED); // Skip over all disabled characters.
|
||||
|
||||
if (next < currentMenu->numitems && PlayerMenu[next].status != IT_DISABLED
|
||||
&& o < 128)
|
||||
{
|
||||
picname = description[i+1].picname;
|
||||
picname = description[next].picname;
|
||||
if (picname[0] == '\0')
|
||||
{
|
||||
picname = strtok(Z_StrDup(description[i+1].skinname), "&");
|
||||
picname = strtok(Z_StrDup(description[next].skinname), "&");
|
||||
for (j = 0; j < numskins; j++)
|
||||
if (stricmp(skins[j].name, picname) == 0)
|
||||
{
|
||||
|
@ -4872,6 +4909,9 @@ static void M_DrawSetupChoosePlayerMenu(void)
|
|||
}
|
||||
|
||||
// current character
|
||||
if (PlayerMenu[i].status == IT_DISABLED) // Prevent flickering.
|
||||
i = (lastdirection) ? prev : next;
|
||||
|
||||
if (i < currentMenu->numitems && PlayerMenu[i].status != IT_DISABLED)
|
||||
{
|
||||
picname = description[i].picname;
|
||||
|
|
Loading…
Reference in a new issue