1
0
Fork 0
mirror of https://github.com/TerryCavanagh/VVVVVV.git synced 2025-01-10 19:09:45 +01:00

Add option to re-enable 1-frame input delay

This is an option for speedrunners whose muscle memory is precisely
trained and used to the 1-frame input delay that existed in 2.2 and
below. It is located in Game Options -> Advanced Options, and is off by
default.

To re-add the 1-frame input delay, we simply move the key.Poll() to the
start of the frame, instead of before an input function gets ran -
undoing what #535 did.

There is a frame ordering-sensitive issue here, where toggling
game.inputdelay at the wrong time could cause double-polling. However,
we only toggle it in an input function, which regardless is always
guaranteed to be ran after key.Poll() (it either happened at the start
of the frame or just before the input function got ran), so this is not
an issue. But, in case we ever need to toggle this variable in the
future, we can just use the defer callbacks system to defer the toggle
to the end of the frame - also added by #535.

Added at the request of Habeechee on the VVVVVV speedrunning Discord
server.
This commit is contained in:
Misa 2021-04-01 15:39:56 -07:00 committed by Ethan Lee
parent 4b3409e2e8
commit f8f6f3b96e
5 changed files with 35 additions and 1 deletions

View file

@ -385,6 +385,7 @@ void Game::init(void)
kludge_ingametemp = Menu::mainmenu; kludge_ingametemp = Menu::mainmenu;
disablepause = false; disablepause = false;
inputdelay = false;
} }
void Game::lifesequence(void) void Game::lifesequence(void)
@ -4173,6 +4174,11 @@ void Game::deserializesettings(tinyxml2::XMLElement* dataNode, ScreenSettings* s
over30mode = help.Int(pText); over30mode = help.Int(pText);
} }
if (SDL_strcmp(pKey, "inputdelay") == 0)
{
inputdelay = help.Int(pText);
}
if (SDL_strcmp(pKey, "glitchrunnermode") == 0) if (SDL_strcmp(pKey, "glitchrunnermode") == 0)
{ {
glitchrunnermode = help.Int(pText); glitchrunnermode = help.Int(pText);
@ -4423,6 +4429,8 @@ void Game::serializesettings(tinyxml2::XMLElement* dataNode, const ScreenSetting
xml::update_tag(dataNode, "over30mode", (int) over30mode); xml::update_tag(dataNode, "over30mode", (int) over30mode);
xml::update_tag(dataNode, "inputdelay", (int) inputdelay);
xml::update_tag(dataNode, "glitchrunnermode", (int) glitchrunnermode); xml::update_tag(dataNode, "glitchrunnermode", (int) glitchrunnermode);
xml::update_tag(dataNode, "vsync", (int) screen_settings->useVsync); xml::update_tag(dataNode, "vsync", (int) screen_settings->useVsync);
@ -6017,6 +6025,7 @@ void Game::createmenu( enum Menu::MenuName t, bool samemenu/*= false*/ )
option("fake load screen"); option("fake load screen");
option("room name background"); option("room name background");
option("glitchrunner mode"); option("glitchrunner mode");
option("input delay");
option("return"); option("return");
menuyoff = 0; menuyoff = 0;
break; break;

View file

@ -452,6 +452,7 @@ public:
void unlockAchievement(const char *name); void unlockAchievement(const char *name);
bool disablepause; bool disablepause;
bool inputdelay;
}; };
#ifndef GAME_DEFINITION #ifndef GAME_DEFINITION

View file

@ -578,6 +578,12 @@ static void menuactionpress(void)
game.savestatsandsettings_menu(); game.savestatsandsettings_menu();
break; break;
case 5: case 5:
/* Input delay */
music.playef(11);
game.inputdelay = !game.inputdelay;
game.savestatsandsettings_menu();
break;
default:
//back //back
music.playef(11); music.playef(11);
game.returnmenu(); game.returnmenu();

View file

@ -518,6 +518,19 @@ static void menurender(void)
graphics.Print( -1, 95, "Glitchrunner mode is OFF", tr/2, tg/2, tb/2, true); graphics.Print( -1, 95, "Glitchrunner mode is OFF", tr/2, tg/2, tb/2, true);
} }
break; break;
case 5:
graphics.bigprint(-1, 30, "Input Delay", tr, tg, tb, true);
graphics.Print(-1, 65, "Re-enable the 1-frame input delay", tr, tg, tb, true);
graphics.Print(-1, 75, "from previous versions of the game.", tr, tg, tb, true);
if (game.inputdelay)
{
graphics.Print(-1, 95, "Input delay is ON", tr, tg, tb, true);
}
else
{
graphics.Print(-1, 95, "Input delay is OFF", tr/2, tg/2, tb/2, true);
}
break;
} }
break; break;
case Menu::accessibility: case Menu::accessibility:

View file

@ -302,7 +302,7 @@ static enum LoopCode loop_run_active_funcs(void)
const struct ImplFunc* implfunc = &(*active_funcs)[*active_func_index]; const struct ImplFunc* implfunc = &(*active_funcs)[*active_func_index];
enum IndexCode index_code; enum IndexCode index_code;
if (implfunc->type == Func_input) if (implfunc->type == Func_input && !game.inputdelay)
{ {
key.Poll(); key.Poll();
} }
@ -721,6 +721,11 @@ static void inline deltaloop(void)
static enum LoopCode loop_begin(void) static enum LoopCode loop_begin(void)
{ {
if (game.inputdelay)
{
key.Poll();
}
// Update network per frame. // Update network per frame.
NETWORK_update(); NETWORK_update();