Keyboard menu navigation
This commit is contained in:
parent
3010dbb6fd
commit
ee26110871
|
@ -187,6 +187,8 @@ initMainMenu(void)
|
||||||
static void
|
static void
|
||||||
resetGame(void)
|
resetGame(void)
|
||||||
{
|
{
|
||||||
|
SDL_FlushEvents(SDL_FIRSTEVENT, SDL_LASTEVENT);
|
||||||
|
|
||||||
if (gMap)
|
if (gMap)
|
||||||
map_destroy(gMap);
|
map_destroy(gMap);
|
||||||
|
|
||||||
|
|
46
src/menu.c
46
src/menu.c
|
@ -10,7 +10,6 @@ typedef struct MenuItems_t {
|
||||||
Sprite *sprite;
|
Sprite *sprite;
|
||||||
Sprite *hsprite;
|
Sprite *hsprite;
|
||||||
GuiButton *button;
|
GuiButton *button;
|
||||||
bool selected;
|
|
||||||
} MenuItem;
|
} MenuItem;
|
||||||
|
|
||||||
Menu *
|
Menu *
|
||||||
|
@ -26,14 +25,54 @@ void
|
||||||
menu_handle_event(Menu *m, SDL_Event *event)
|
menu_handle_event(Menu *m, SDL_Event *event)
|
||||||
{
|
{
|
||||||
LinkedList *items;
|
LinkedList *items;
|
||||||
|
bool reset_buttons = false;
|
||||||
|
bool trigger_button = false;
|
||||||
|
|
||||||
|
if (event->type == SDL_KEYDOWN) {
|
||||||
|
switch (event->key.keysym.sym) {
|
||||||
|
case SDLK_UP:
|
||||||
|
m->selected--;
|
||||||
|
reset_buttons = true;
|
||||||
|
break;
|
||||||
|
case SDLK_DOWN:
|
||||||
|
m->selected++;
|
||||||
|
reset_buttons = true;
|
||||||
|
break;
|
||||||
|
case SDLK_RETURN:
|
||||||
|
trigger_button = true;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
m->selected = m->selected % linkedlist_size(m->items);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (trigger_button) {
|
||||||
|
MenuItem *item = linkedlist_get(&m->items, m->selected);
|
||||||
|
if (item->button->event)
|
||||||
|
item->button->event(item->button->usrdata);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
int current_select = 0;
|
||||||
|
bool mouse_selection = false;
|
||||||
items = m->items;
|
items = m->items;
|
||||||
while (items) {
|
while (items) {
|
||||||
MenuItem *item = items->data;
|
MenuItem *item = items->data;
|
||||||
items = items->next;
|
items = items->next;
|
||||||
|
if (reset_buttons)
|
||||||
|
item->button->hover = false;
|
||||||
|
|
||||||
gui_button_handle_event(item->button, event);
|
gui_button_handle_event(item->button, event);
|
||||||
item->selected = item->button->hover;
|
if (item->button->hover) {
|
||||||
|
m->selected = current_select;
|
||||||
|
mouse_selection = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
current_select++;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!mouse_selection)
|
||||||
|
((MenuItem*) linkedlist_get(&m->items, m->selected))->button->hover = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -42,7 +81,6 @@ menu_item_add(Menu *m, Sprite *s1, Sprite *s2, void (*event)(void*))
|
||||||
MenuItem *item = ec_malloc(sizeof(MenuItem));
|
MenuItem *item = ec_malloc(sizeof(MenuItem));
|
||||||
item->sprite = s1;
|
item->sprite = s1;
|
||||||
item->hsprite = s2;
|
item->hsprite = s2;
|
||||||
item->selected = false;
|
|
||||||
|
|
||||||
SDL_Rect area = {
|
SDL_Rect area = {
|
||||||
item->sprite->pos.x,
|
item->sprite->pos.x,
|
||||||
|
@ -62,7 +100,7 @@ menu_render(Menu *m, Camera *cam)
|
||||||
while (items) {
|
while (items) {
|
||||||
MenuItem *item = items->data;
|
MenuItem *item = items->data;
|
||||||
items = items->next;
|
items = items->next;
|
||||||
if (item->selected)
|
if (item->button->hover)
|
||||||
sprite_render(item->hsprite, cam);
|
sprite_render(item->hsprite, cam);
|
||||||
else
|
else
|
||||||
sprite_render(item->sprite, cam);
|
sprite_render(item->sprite, cam);
|
||||||
|
|
|
@ -9,7 +9,7 @@
|
||||||
|
|
||||||
typedef struct Menu_t {
|
typedef struct Menu_t {
|
||||||
LinkedList *items;
|
LinkedList *items;
|
||||||
unsigned int selected;
|
int selected;
|
||||||
} Menu;
|
} Menu;
|
||||||
|
|
||||||
Menu *
|
Menu *
|
||||||
|
|
Loading…
Reference in New Issue