Added menu to challenges screen.
This commit is contained in:
parent
0e159402e9
commit
bf7d6dc921
|
@ -8,5 +8,45 @@
|
||||||
"y" : 680,
|
"y" : 680,
|
||||||
"w" : 250,
|
"w" : 250,
|
||||||
"h": 34
|
"h": 34
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name" : "resume",
|
||||||
|
"group" : "challengesMenu",
|
||||||
|
"type" : "WT_BUTTON",
|
||||||
|
"text" : "Resume",
|
||||||
|
"x" : -1,
|
||||||
|
"y" : 215,
|
||||||
|
"w" : 200,
|
||||||
|
"h": 34
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name" : "stats",
|
||||||
|
"group" : "challengesMenu",
|
||||||
|
"type" : "WT_BUTTON",
|
||||||
|
"text" : "Stats",
|
||||||
|
"x" : -1,
|
||||||
|
"y" : 315,
|
||||||
|
"w" : 200,
|
||||||
|
"h": 34
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name" : "options",
|
||||||
|
"group" : "challengesMenu",
|
||||||
|
"type" : "WT_BUTTON",
|
||||||
|
"text" : "Options",
|
||||||
|
"x" : -1,
|
||||||
|
"y" : 415,
|
||||||
|
"w" : 200,
|
||||||
|
"h": 34
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name" : "quit",
|
||||||
|
"group" : "challengesMenu",
|
||||||
|
"type" : "WT_BUTTON",
|
||||||
|
"text" : "Return to Title",
|
||||||
|
"x" : -1,
|
||||||
|
"y" : 515,
|
||||||
|
"w" : 200,
|
||||||
|
"h": 34
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
|
|
|
@ -27,12 +27,20 @@ static void drawChallenges(void);
|
||||||
static void updateChallengeMissions(void);
|
static void updateChallengeMissions(void);
|
||||||
static void doChallenges(void);
|
static void doChallenges(void);
|
||||||
static void startChallengeMission(void);
|
static void startChallengeMission(void);
|
||||||
|
static void drawMenu(void);
|
||||||
|
static void resume(void);
|
||||||
|
static void stats(void);
|
||||||
|
static void options(void);
|
||||||
|
static void statsOK(void);
|
||||||
|
static void returnFromOptions(void);
|
||||||
|
static void quit(void);
|
||||||
|
|
||||||
static SDL_Texture *background;
|
static SDL_Texture *background;
|
||||||
static int startIndex;
|
static int startIndex;
|
||||||
static Widget *start;
|
static Widget *start;
|
||||||
static int completedChallenges;
|
static int completedChallenges;
|
||||||
static int totalChallenges;
|
static int totalChallenges;
|
||||||
|
static int show;
|
||||||
|
|
||||||
void initChallengeHome(void)
|
void initChallengeHome(void)
|
||||||
{
|
{
|
||||||
|
@ -56,12 +64,21 @@ void initChallengeHome(void)
|
||||||
|
|
||||||
startIndex = 0;
|
startIndex = 0;
|
||||||
|
|
||||||
|
show = SHOW_CHALLENGES;
|
||||||
|
|
||||||
initBackground();
|
initBackground();
|
||||||
|
|
||||||
start = getWidget("start", "challenges");
|
start = getWidget("start", "challenges");
|
||||||
start->enabled = 0;
|
start->enabled = 0;
|
||||||
start->action = startChallengeMission;
|
start->action = startChallengeMission;
|
||||||
|
|
||||||
|
getWidget("resume", "challengesMenu")->action = resume;
|
||||||
|
getWidget("stats", "challengesMenu")->action = stats;
|
||||||
|
getWidget("options", "challengesMenu")->action = options;
|
||||||
|
getWidget("quit", "challengesMenu")->action = quit;
|
||||||
|
|
||||||
|
getWidget("ok", "stats")->action = statsOK;
|
||||||
|
|
||||||
setMouse(SCREEN_WIDTH / 2, SCREEN_HEIGHT / 2);
|
setMouse(SCREEN_WIDTH / 2, SCREEN_HEIGHT / 2);
|
||||||
|
|
||||||
endSectionTransition();
|
endSectionTransition();
|
||||||
|
@ -106,7 +123,21 @@ static void logic(void)
|
||||||
|
|
||||||
doStars(0.5, 0);
|
doStars(0.5, 0);
|
||||||
|
|
||||||
|
switch (show)
|
||||||
|
{
|
||||||
|
case SHOW_CHALLENGES:
|
||||||
doChallenges();
|
doChallenges();
|
||||||
|
break;
|
||||||
|
|
||||||
|
case SHOW_MENU:
|
||||||
|
break;
|
||||||
|
|
||||||
|
case SHOW_STATS:
|
||||||
|
break;
|
||||||
|
|
||||||
|
case SHOW_OPTIONS:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
doWidgets();
|
doWidgets();
|
||||||
}
|
}
|
||||||
|
@ -149,7 +180,24 @@ static void draw(void)
|
||||||
|
|
||||||
drawChallenges();
|
drawChallenges();
|
||||||
|
|
||||||
|
switch (show)
|
||||||
|
{
|
||||||
|
case SHOW_CHALLENGES:
|
||||||
drawWidgets("challenges");
|
drawWidgets("challenges");
|
||||||
|
break;
|
||||||
|
|
||||||
|
case SHOW_MENU:
|
||||||
|
drawMenu();
|
||||||
|
break;
|
||||||
|
|
||||||
|
case SHOW_STATS:
|
||||||
|
drawStats();
|
||||||
|
break;
|
||||||
|
|
||||||
|
case SHOW_OPTIONS:
|
||||||
|
drawOptions();
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void drawChallenges(void)
|
static void drawChallenges(void)
|
||||||
|
@ -216,11 +264,94 @@ static void drawChallenges(void)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void drawMenu(void)
|
||||||
|
{
|
||||||
|
SDL_Rect r;
|
||||||
|
|
||||||
|
SDL_SetRenderDrawBlendMode(app.renderer, SDL_BLENDMODE_BLEND);
|
||||||
|
SDL_SetRenderDrawColor(app.renderer, 0, 0, 0, 128);
|
||||||
|
SDL_RenderFillRect(app.renderer, NULL);
|
||||||
|
SDL_SetRenderDrawBlendMode(app.renderer, SDL_BLENDMODE_NONE);
|
||||||
|
|
||||||
|
r.w = 400;
|
||||||
|
r.h = 400;
|
||||||
|
r.x = (SCREEN_WIDTH / 2) - r.w / 2;
|
||||||
|
r.y = (SCREEN_HEIGHT / 2) - r.h / 2;
|
||||||
|
|
||||||
|
SDL_SetRenderDrawColor(app.renderer, 0, 0, 0, 0);
|
||||||
|
SDL_RenderFillRect(app.renderer, &r);
|
||||||
|
SDL_SetRenderDrawColor(app.renderer, 200, 200, 200, 255);
|
||||||
|
SDL_RenderDrawRect(app.renderer, &r);
|
||||||
|
|
||||||
|
drawWidgets("challengesMenu");
|
||||||
|
}
|
||||||
|
|
||||||
|
static void resume(void)
|
||||||
|
{
|
||||||
|
show = SHOW_CHALLENGES;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void options(void)
|
||||||
|
{
|
||||||
|
show = SHOW_OPTIONS;
|
||||||
|
|
||||||
|
initOptions(returnFromOptions);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void stats(void)
|
||||||
|
{
|
||||||
|
selectWidget("ok", "stats");
|
||||||
|
|
||||||
|
show = SHOW_STATS;
|
||||||
|
|
||||||
|
initStatsDisplay();
|
||||||
|
}
|
||||||
|
|
||||||
|
static void statsOK(void)
|
||||||
|
{
|
||||||
|
selectWidget("resume", "challengesMenu");
|
||||||
|
|
||||||
|
show = SHOW_MENU;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void returnFromOptions(void)
|
||||||
|
{
|
||||||
|
show = SHOW_MENU;
|
||||||
|
|
||||||
|
selectWidget("resume", "challengesMenu");
|
||||||
|
}
|
||||||
|
|
||||||
|
static void quit(void)
|
||||||
|
{
|
||||||
|
initTitle();
|
||||||
|
}
|
||||||
|
|
||||||
static void handleKeyboard(void)
|
static void handleKeyboard(void)
|
||||||
{
|
{
|
||||||
if (app.keyboard[SDL_SCANCODE_ESCAPE])
|
if (app.keyboard[SDL_SCANCODE_ESCAPE])
|
||||||
{
|
{
|
||||||
initTitle();
|
switch (show)
|
||||||
|
{
|
||||||
|
case SHOW_CHALLENGES:
|
||||||
|
selectWidget("resume", "challengesMenu");
|
||||||
|
show = SHOW_MENU;
|
||||||
|
playSound(SND_GUI_CLOSE);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case SHOW_MENU:
|
||||||
|
show = SHOW_CHALLENGES;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case SHOW_OPTIONS:
|
||||||
|
case SHOW_STATS:
|
||||||
|
show = SHOW_MENU;
|
||||||
|
selectWidget("resume", "challengesMenu");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
playSound(SND_GUI_CLOSE);
|
||||||
|
|
||||||
|
memset(app.keyboard, 0, sizeof(int) * MAX_KEYBOARD_KEYS);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -22,6 +22,11 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
|
|
||||||
#define MAX_ITEMS 21
|
#define MAX_ITEMS 21
|
||||||
|
|
||||||
|
#define SHOW_CHALLENGES 0
|
||||||
|
#define SHOW_MENU 1
|
||||||
|
#define SHOW_OPTIONS 2
|
||||||
|
#define SHOW_STATS 3
|
||||||
|
|
||||||
extern void startSectionTransition(void);
|
extern void startSectionTransition(void);
|
||||||
extern void endSectionTransition(void);
|
extern void endSectionTransition(void);
|
||||||
extern void stopMusic(void);
|
extern void stopMusic(void);
|
||||||
|
@ -41,6 +46,12 @@ extern int collision(int x1, int y1, int w1, int h1, int x2, int y2, int w2, int
|
||||||
extern Widget *getWidget(const char *name, const char *group);
|
extern Widget *getWidget(const char *name, const char *group);
|
||||||
extern void saveGame(void);
|
extern void saveGame(void);
|
||||||
extern void initTitle(void);
|
extern void initTitle(void);
|
||||||
|
extern void initStatsDisplay(void);
|
||||||
|
extern void drawOptions(void);
|
||||||
|
extern void initOptions(void (*returnFromOptions)(void));
|
||||||
|
extern void drawStats(void);
|
||||||
|
extern void playSound(int sound);
|
||||||
|
extern void selectWidget(const char *name, const char *group);
|
||||||
|
|
||||||
extern App app;
|
extern App app;
|
||||||
extern Battle battle;
|
extern Battle battle;
|
||||||
|
|
Loading…
Reference in New Issue