mirror of
https://github.com/TerryCavanagh/VVVVVV.git
synced 2025-01-25 02:04:58 +01:00
Add graphic options and game options to editor settings
This is a small quality-of-life tweak that makes it so if you're in the middle of editing a level, you don't have to save the level, exit to the menu, change whatever setting you wanted, re-enter the editor, and type in the level name, just to change one setting. This is the same as adding Graphic Options and Game Options to the in-game pause menu, except for the editor, too. To do this, I'm reusing Game::returntopausemenu() (because all of its callers are the same callers for returning to editor settings) and renamed it to returntoingame(), then added a variable named ingame_editormode to Game. When we're in the options menus but still in the editor, BOTH ingame_titlemode and ingame_editormode will be true.
This commit is contained in:
parent
fc8c7d034d
commit
2c8d338e47
4 changed files with 49 additions and 10 deletions
|
@ -373,6 +373,9 @@ void Game::init(void)
|
||||||
glitchrunnermode = false;
|
glitchrunnermode = false;
|
||||||
|
|
||||||
ingame_titlemode = false;
|
ingame_titlemode = false;
|
||||||
|
#if !defined(NO_CUSTOM_LEVELS) && !defined(NO_EDITOR)
|
||||||
|
ingame_editormode = false;
|
||||||
|
#endif
|
||||||
kludge_ingametemp = Menu::mainmenu;
|
kludge_ingametemp = Menu::mainmenu;
|
||||||
|
|
||||||
disablepause = false;
|
disablepause = false;
|
||||||
|
@ -6394,6 +6397,8 @@ void Game::createmenu( enum Menu::MenuName t, bool samemenu/*= false*/ )
|
||||||
option("editor ghosts");
|
option("editor ghosts");
|
||||||
option("load level");
|
option("load level");
|
||||||
option("save level");
|
option("save level");
|
||||||
|
option("graphic options");
|
||||||
|
option("game options");
|
||||||
option("quit to main menu");
|
option("quit to main menu");
|
||||||
|
|
||||||
menuyoff = -20;
|
menuyoff = -20;
|
||||||
|
@ -7076,17 +7081,29 @@ void Game::returntoeditor(void)
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
void Game::returntopausemenu(void)
|
void Game::returntoingame(void)
|
||||||
{
|
{
|
||||||
ingame_titlemode = false;
|
ingame_titlemode = false;
|
||||||
|
mapheld = true;
|
||||||
|
#if !defined(NO_CUSTOM_LEVELS) && !defined(NO_EDITOR)
|
||||||
|
if (ingame_editormode)
|
||||||
|
{
|
||||||
|
ingame_editormode = false;
|
||||||
|
returntomenu(Menu::ed_settings);
|
||||||
|
gamestate = EDITORMODE;
|
||||||
|
ed.settingskey = true;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
#endif
|
||||||
|
{
|
||||||
returntomenu(kludge_ingametemp);
|
returntomenu(kludge_ingametemp);
|
||||||
gamestate = MAPMODE;
|
gamestate = MAPMODE;
|
||||||
mapheld = true;
|
|
||||||
graphics.flipmode = graphics.setflipmode;
|
graphics.flipmode = graphics.setflipmode;
|
||||||
if (!map.custommode && !graphics.flipmode)
|
if (!map.custommode && !graphics.flipmode)
|
||||||
{
|
{
|
||||||
obj.flags[73] = true;
|
obj.flags[73] = true;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void Game::unlockAchievement(const char *name) {
|
void Game::unlockAchievement(const char *name) {
|
||||||
|
|
|
@ -442,8 +442,11 @@ public:
|
||||||
bool glitchrunnermode; // Have fun speedrunners! <3 Misa
|
bool glitchrunnermode; // Have fun speedrunners! <3 Misa
|
||||||
|
|
||||||
bool ingame_titlemode;
|
bool ingame_titlemode;
|
||||||
|
#if !defined(NO_CUSTOM_LEVELS) && !defined(NO_EDITOR)
|
||||||
|
bool ingame_editormode;
|
||||||
|
#endif
|
||||||
|
|
||||||
void returntopausemenu(void);
|
void returntoingame(void);
|
||||||
void unlockAchievement(const char *name);
|
void unlockAchievement(const char *name);
|
||||||
|
|
||||||
bool disablepause;
|
bool disablepause;
|
||||||
|
|
|
@ -455,7 +455,7 @@ static void menuactionpress(void)
|
||||||
music.playef(11);
|
music.playef(11);
|
||||||
if (game.ingame_titlemode)
|
if (game.ingame_titlemode)
|
||||||
{
|
{
|
||||||
game.returntopausemenu();
|
game.returntoingame();
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -766,7 +766,7 @@ static void menuactionpress(void)
|
||||||
music.playef(11);
|
music.playef(11);
|
||||||
if (game.ingame_titlemode)
|
if (game.ingame_titlemode)
|
||||||
{
|
{
|
||||||
game.returntopausemenu();
|
game.returntoingame();
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -1634,7 +1634,7 @@ void titleinput(void)
|
||||||
&& (game.currentmenuname == Menu::options
|
&& (game.currentmenuname == Menu::options
|
||||||
|| game.currentmenuname == Menu::graphicoptions))
|
|| game.currentmenuname == Menu::graphicoptions))
|
||||||
{
|
{
|
||||||
game.returntopausemenu();
|
game.returntoingame();
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
|
|
@ -3769,6 +3769,25 @@ static void editormenuactionpress()
|
||||||
graphics.backgrounddrawn=false;
|
graphics.backgrounddrawn=false;
|
||||||
break;
|
break;
|
||||||
case 6:
|
case 6:
|
||||||
|
case 7:
|
||||||
|
/* Graphic options and game options */
|
||||||
|
music.playef(11);
|
||||||
|
game.gamestate = TITLEMODE;
|
||||||
|
game.ingame_titlemode = true;
|
||||||
|
game.ingame_editormode = true;
|
||||||
|
|
||||||
|
if (game.currentmenuoption == 6)
|
||||||
|
{
|
||||||
|
game.createmenu(Menu::graphicoptions);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
game.createmenu(Menu::options);
|
||||||
|
}
|
||||||
|
|
||||||
|
map.nexttowercolour();
|
||||||
|
break;
|
||||||
|
default:
|
||||||
music.playef(11);
|
music.playef(11);
|
||||||
game.createmenu(Menu::ed_quit);
|
game.createmenu(Menu::ed_quit);
|
||||||
map.nexttowercolour();
|
map.nexttowercolour();
|
||||||
|
|
Loading…
Add table
Reference in a new issue