mirror of
https://github.com/TerryCavanagh/VVVVVV.git
synced 2024-12-31 22:19:44 +01:00
Don't show next/previous page options if only one page
It's possible to get one page of levels by removing all the built-ins, either by removing them directly from data.zip or by putting files with the same filenames as them in your level folder that don't contain nothing. And hey, there's already a check for if no levels exist at all, so why not check for this too?
This commit is contained in:
parent
254cede905
commit
28e4a155d4
3 changed files with 24 additions and 17 deletions
|
@ -6002,21 +6002,24 @@ void Game::createmenu( enum Menu::MenuName t, bool samemenu/*= false*/ )
|
|||
option(text);
|
||||
}
|
||||
}
|
||||
if((size_t) ((levelpage*8)+8) <ed.ListOfMetaData.size())
|
||||
if (ed.ListOfMetaData.size() > 8)
|
||||
{
|
||||
option("next page");
|
||||
}
|
||||
else
|
||||
{
|
||||
option("first page");
|
||||
}
|
||||
if (levelpage == 0)
|
||||
{
|
||||
option("last page");
|
||||
}
|
||||
else
|
||||
{
|
||||
option("previous page");
|
||||
if((size_t) ((levelpage*8)+8) <ed.ListOfMetaData.size())
|
||||
{
|
||||
option("next page");
|
||||
}
|
||||
else
|
||||
{
|
||||
option("first page");
|
||||
}
|
||||
if (levelpage == 0)
|
||||
{
|
||||
option("last page");
|
||||
}
|
||||
else
|
||||
{
|
||||
option("previous page");
|
||||
}
|
||||
}
|
||||
option("return to menu");
|
||||
|
||||
|
|
|
@ -412,12 +412,14 @@ static void menuactionpress(void)
|
|||
break;
|
||||
#if !defined(NO_CUSTOM_LEVELS)
|
||||
case Menu::levellist:
|
||||
{
|
||||
const bool nextlastoptions = ed.ListOfMetaData.size() > 8;
|
||||
if(game.currentmenuoption==(int)game.menuoptions.size()-1){
|
||||
//go back to menu
|
||||
music.playef(11);
|
||||
game.returnmenu();
|
||||
map.nexttowercolour();
|
||||
}else if(game.currentmenuoption==(int)game.menuoptions.size()-2){
|
||||
}else if(nextlastoptions && game.currentmenuoption==(int)game.menuoptions.size()-2){
|
||||
//previous page
|
||||
music.playef(11);
|
||||
if(game.levelpage==0){
|
||||
|
@ -428,7 +430,7 @@ static void menuactionpress(void)
|
|||
game.createmenu(Menu::levellist, true);
|
||||
game.currentmenuoption=game.menuoptions.size()-2;
|
||||
map.nexttowercolour();
|
||||
}else if(game.currentmenuoption==(int)game.menuoptions.size()-3){
|
||||
}else if(nextlastoptions && game.currentmenuoption==(int)game.menuoptions.size()-3){
|
||||
//next page
|
||||
music.playef(11);
|
||||
if((size_t) ((game.levelpage*8)+8) >= ed.ListOfMetaData.size()){
|
||||
|
@ -457,6 +459,7 @@ static void menuactionpress(void)
|
|||
}
|
||||
}
|
||||
break;
|
||||
}
|
||||
#endif
|
||||
case Menu::quickloadlevel:
|
||||
switch (game.currentmenuoption)
|
||||
|
|
|
@ -173,8 +173,9 @@ static void menurender(void)
|
|||
}
|
||||
int tmp=game.currentmenuoption+(game.levelpage*8);
|
||||
if(INBOUNDS_VEC(tmp, ed.ListOfMetaData)){
|
||||
const bool nextlastoptions = ed.ListOfMetaData.size() > 8;
|
||||
//Don't show next/previous page or return to menu options here!
|
||||
if(game.menuoptions.size() - game.currentmenuoption<=3){
|
||||
if(nextlastoptions && game.menuoptions.size() - game.currentmenuoption<=3){
|
||||
|
||||
}else{
|
||||
graphics.bigprint( -1, 15, ed.ListOfMetaData[tmp].title, tr, tg, tb, true);
|
||||
|
|
Loading…
Reference in a new issue