Issue #6: Improve LCD menu and implement function to see safety flags
This commit is contained in:
@@ -27,6 +27,7 @@ void menu_handle(struct lcd_menu *menu, int16_t rotary_encoder_delta, enum butto
|
||||
{
|
||||
menu_func_t tmp;
|
||||
|
||||
|
||||
if (!menu)
|
||||
return;
|
||||
|
||||
@@ -38,6 +39,9 @@ void menu_handle(struct lcd_menu *menu, int16_t rotary_encoder_delta, enum butto
|
||||
|
||||
tmp = menu->active_entry;
|
||||
|
||||
if (menu->active_entry_type == MENU_ENTRY_FIRST_ENTER && push_button != BUTTON_IDLE) {
|
||||
menu->inputs.button_ready = false;
|
||||
}
|
||||
|
||||
if (menu->active_entry_type == MENU_ENTRY_FIRST_ENTER) {
|
||||
menu->active_entry(menu, menu->active_entry_type, menu->init_parent);
|
||||
@@ -48,6 +52,9 @@ void menu_handle(struct lcd_menu *menu, int16_t rotary_encoder_delta, enum butto
|
||||
if (menu->active_entry_type != MENU_ENTRY_CONTINUE && tmp == menu->active_entry) {
|
||||
menu->active_entry_type = MENU_ENTRY_CONTINUE;
|
||||
}
|
||||
|
||||
if (push_button == BUTTON_IDLE)
|
||||
menu->inputs.button_ready = true;
|
||||
}
|
||||
|
||||
void menu_init(struct lcd_menu *menu, menu_func_t root_node, void (*display_update)(uint8_t row, const char *data))
|
||||
@@ -59,6 +66,7 @@ void menu_init(struct lcd_menu *menu, menu_func_t root_node, void (*display_upda
|
||||
menu->active_entry = root_node;
|
||||
menu->init_parent = NULL;
|
||||
menu->inputs.push_button = BUTTON_IDLE;
|
||||
menu->inputs.button_ready = false;
|
||||
menu->inputs.rotary_encoder_delta = 0;
|
||||
menu->active_entry_type = MENU_ENTRY_FIRST_ENTER;
|
||||
menu->update_display = display_update;
|
||||
@@ -243,6 +251,16 @@ enum button_state menu_get_button_state(const struct lcd_menu *menu)
|
||||
return ret;
|
||||
}
|
||||
|
||||
bool menu_get_button_ready_state(const struct lcd_menu *menu)
|
||||
{
|
||||
bool ret = false;
|
||||
|
||||
if (menu)
|
||||
ret = menu->inputs.button_ready;
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
void menu_display_clear(struct lcd_menu *menu)
|
||||
{
|
||||
uint8_t i;
|
||||
|
Reference in New Issue
Block a user