mirror of
https://github.com/Polprzewodnikowy/N64FlashcartMenu.git
synced 2024-11-22 10:39:20 +01:00
Added hide delay to context menu
This commit is contained in:
parent
de97bedc00
commit
5f6b006a1b
@ -40,6 +40,7 @@ void component_file_list_draw (entry_t *list, int entries, int selected);
|
|||||||
typedef struct {
|
typedef struct {
|
||||||
int count;
|
int count;
|
||||||
int selected;
|
int selected;
|
||||||
|
bool hide_pending;
|
||||||
struct {
|
struct {
|
||||||
const char *text;
|
const char *text;
|
||||||
void (*action) (menu_t *menu);
|
void (*action) (menu_t *menu);
|
||||||
|
@ -6,6 +6,7 @@
|
|||||||
void component_context_menu_init (component_context_menu_t *cm) {
|
void component_context_menu_init (component_context_menu_t *cm) {
|
||||||
cm->selected = -1;
|
cm->selected = -1;
|
||||||
cm->count = 0;
|
cm->count = 0;
|
||||||
|
cm->hide_pending = false;
|
||||||
for (int i = 0; (cm->list[i].text) != NULL; i++) {
|
for (int i = 0; (cm->list[i].text) != NULL; i++) {
|
||||||
cm->count += 1;
|
cm->count += 1;
|
||||||
}
|
}
|
||||||
@ -21,11 +22,11 @@ bool component_context_menu_process (menu_t *menu, component_context_menu_t *cm)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (menu->actions.back) {
|
if (menu->actions.back) {
|
||||||
cm->selected = -1;
|
cm->hide_pending = true;
|
||||||
} else if (menu->actions.enter) {
|
} else if (menu->actions.enter) {
|
||||||
if (cm->list[cm->selected].action) {
|
if (cm->list[cm->selected].action) {
|
||||||
cm->list[cm->selected].action(menu);
|
cm->list[cm->selected].action(menu);
|
||||||
cm->selected = -1;
|
cm->hide_pending = true;
|
||||||
}
|
}
|
||||||
} else if (menu->actions.go_up) {
|
} else if (menu->actions.go_up) {
|
||||||
cm->selected -= 1;
|
cm->selected -= 1;
|
||||||
@ -89,4 +90,9 @@ void component_context_menu_draw (component_context_menu_t *cm) {
|
|||||||
rdpq_paragraph_render(layout, VISIBLE_AREA_X0, VISIBLE_AREA_Y0);
|
rdpq_paragraph_render(layout, VISIBLE_AREA_X0, VISIBLE_AREA_Y0);
|
||||||
|
|
||||||
rdpq_paragraph_free(layout);
|
rdpq_paragraph_free(layout);
|
||||||
|
|
||||||
|
if (cm->hide_pending) {
|
||||||
|
cm->hide_pending = false;
|
||||||
|
cm->selected = -1;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user