mirror of
https://github.com/krislamo/Trololo
synced 2025-01-07 03:40:34 +00:00
Function MainMenu_survey() fixed logically
Debugging showed that MainMenu_survey() in the core.cpp file under scrns had issues. They are fixed and can be verified by uncommenting lines with //debugline at the end. Rendering for the MainMenu is not yet implemented.
This commit is contained in:
parent
27773ae391
commit
58c3b4e4f2
95
core.cpp
95
core.cpp
@ -250,71 +250,72 @@ namespace scrns
|
|||||||
int MainMenu_survey()
|
int MainMenu_survey()
|
||||||
{
|
{
|
||||||
// Return values
|
// Return values
|
||||||
// 0 -- User wants to quit
|
// 1 -- User wants option 1 (start new game)
|
||||||
// 1 -- User wants option 1
|
// 2 -- User wants to quit
|
||||||
// 2 -- User wants option 2
|
|
||||||
// -1 -- No input
|
|
||||||
|
|
||||||
SDL_Event event;
|
SDL_Event event;
|
||||||
int current, menu_option;
|
|
||||||
|
int menu_option, current;
|
||||||
|
menu_option = current = 1;
|
||||||
|
|
||||||
bool option_wanted = false;
|
bool option_wanted = false;
|
||||||
|
|
||||||
current = menu_option = 1;
|
|
||||||
|
|
||||||
while(SDL_PollEvent(&event))
|
while(!option_wanted)
|
||||||
{
|
{
|
||||||
if(event.type == SDL_QUIT)
|
while(SDL_PollEvent(&event))
|
||||||
return 0;
|
|
||||||
|
|
||||||
else if(event.type == SDL_KEYDOWN)
|
|
||||||
{
|
{
|
||||||
|
|
||||||
if(event.key.keysym.sym == 274) // down arrow key
|
if(event.type == SDL_QUIT)
|
||||||
{
|
return 2;
|
||||||
if(menu_option < 2) // Less than the max amount of options
|
|
||||||
menu_option++;
|
|
||||||
|
|
||||||
cout << "Down Key, menu_option: " << menu_option << endl;
|
else if(event.type == SDL_KEYDOWN)
|
||||||
|
{
|
||||||
|
|
||||||
|
if(event.key.keysym.sym == 274) // down arrow key
|
||||||
|
{
|
||||||
|
if(menu_option < 2) // Less than the max amount of options
|
||||||
|
menu_option++;
|
||||||
|
|
||||||
|
//cout << "INPUT ::: DOWN KEY, menu_option: " << menu_option << "; current: " << current << endl; // debugline
|
||||||
|
}
|
||||||
|
|
||||||
|
else if(event.key.keysym.sym == 273) // up arrow key
|
||||||
|
{
|
||||||
|
if(menu_option > 1)
|
||||||
|
menu_option--;
|
||||||
|
|
||||||
|
//cout << "INPUT ::: UP KEY, menu_option: " << menu_option << "; current: " << current << endl; // debugline
|
||||||
|
}
|
||||||
|
|
||||||
|
else if(event.key.keysym.sym == 13) // enter key
|
||||||
|
option_wanted = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
else if(event.key.keysym.sym == 273) // up arrow key
|
|
||||||
|
|
||||||
|
if(menu_option != current)
|
||||||
{
|
{
|
||||||
if(menu_option > 1)
|
current = menu_option;
|
||||||
menu_option--;
|
|
||||||
|
|
||||||
cout << "Up Key, menu_option: " << menu_option << endl; // debugline
|
switch(menu_option)
|
||||||
|
{
|
||||||
|
case 1:
|
||||||
|
//cout << "Case 1 ::: Menu should change. menu_option: " << menu_option << "; current: " << current << endl; // debugline
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
//cout << "Case 2 ::: Menu should change. menu_option: " << menu_option << "; current: " << current << endl; // debugline
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
cout << "Error: MainMenu_survey didn't update correctly." << endl;
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
else if(event.key.keysym.sym == 13) // enter key
|
|
||||||
option_wanted = true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
if(menu_option != current)
|
|
||||||
{
|
|
||||||
switch(menu_option)
|
|
||||||
{
|
|
||||||
case 1:
|
|
||||||
cout << "Case 1 ::: Menu should change to: " << menu_option << endl; // debugline
|
|
||||||
case 2:
|
|
||||||
cout << "Case 2 ::: Menu should change to: " << menu_option << endl; // debugline
|
|
||||||
}
|
|
||||||
current = menu_option;
|
|
||||||
}
|
|
||||||
|
|
||||||
else if(option_wanted)
|
|
||||||
return menu_option;
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return -1;
|
return menu_option;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
23
main.cpp
23
main.cpp
@ -5,18 +5,27 @@ using namespace std;
|
|||||||
int main(int argc, char* args[])
|
int main(int argc, char* args[])
|
||||||
{
|
{
|
||||||
SDL_Surface *screen;
|
SDL_Surface *screen;
|
||||||
int menu_option = -1;
|
|
||||||
|
|
||||||
|
// Display main menu
|
||||||
screen = scrns::MainMenu();
|
screen = scrns::MainMenu();
|
||||||
|
|
||||||
while(menu_option == -1)
|
// Main menu option return
|
||||||
{
|
int menu_option;
|
||||||
menu_option = scrns::MainMenu_survey();
|
|
||||||
|
|
||||||
if(menu_option == 1)
|
menu_option = scrns::MainMenu_survey();
|
||||||
{
|
|
||||||
|
switch(menu_option)
|
||||||
|
{
|
||||||
|
case 1:
|
||||||
|
// User wants to start a new game
|
||||||
cout << "Starting new game..." << endl;
|
cout << "Starting new game..." << endl;
|
||||||
}
|
break;
|
||||||
|
case 2:
|
||||||
|
// User wants to exit the game
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
cout << "Fatal Error: Main Menu option given was unknown." << endl;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
SDL_FreeSurface(screen);
|
SDL_FreeSurface(screen);
|
||||||
|
Loading…
Reference in New Issue
Block a user