#include "input_event.h" #include "diskop.h" void overwrite_file_widget_yes_input_callback(GuiButtonType result, InputType type, void* ctx) { UNUSED(result); FlizzerTrackerApp* tracker = (FlizzerTrackerApp*)ctx; if(type == InputTypeShort) { tracker->is_saving = true; view_dispatcher_switch_to_view(tracker->view_dispatcher, VIEW_TRACKER); //save_song(tracker, tracker->filepath); static FlizzerTrackerEvent event = {.type = EventTypeSaveSong, .input = {0}, .period = 0}; furi_message_queue_put(tracker->event_queue, &event, FuriWaitForever); } } void overwrite_file_widget_no_input_callback(GuiButtonType result, InputType type, void* ctx) { UNUSED(result); FlizzerTrackerApp* tracker = (FlizzerTrackerApp*)ctx; if(type == InputTypeShort) { tracker->is_saving = false; furi_string_free(tracker->filepath); view_dispatcher_switch_to_view(tracker->view_dispatcher, VIEW_TRACKER); } } void submenu_callback(void *context, uint32_t index) { FlizzerTrackerApp *tracker = (FlizzerTrackerApp *)context; switch (tracker->mode) { case PATTERN_VIEW: { switch (index) { case SUBMENU_PATTERN_RETURN: { view_dispatcher_switch_to_view(tracker->view_dispatcher, VIEW_TRACKER); break; } case SUBMENU_PATTERN_EXIT: { tracker->quit = true; static InputEvent inevent = {.sequence = 0, .key = InputKeyLeft, .type = InputTypeMAX}; FlizzerTrackerEvent event = {.type = EventTypeInput, .input = inevent, .period = 0}; // making an event so tracker does not wait for next keypress and exits immediately furi_message_queue_put(tracker->event_queue, &event, FuriWaitForever); view_dispatcher_switch_to_view(tracker->view_dispatcher, VIEW_TRACKER); break; } case SUBMENU_PATTERN_SAVE_SONG: { text_input_set_header_text(tracker->text_input, "Song filename:"); memset(&tracker->filename, 0, FILE_NAME_LEN); text_input_set_result_callback(tracker->text_input, return_from_keyboard_callback, tracker, (char *)&tracker->filename, FILE_NAME_LEN, true); tracker->is_saving = true; view_dispatcher_switch_to_view(tracker->view_dispatcher, VIEW_KEYBOARD); } default: break; } break; } case INST_EDITOR_VIEW: { switch (index) { case SUBMENU_INSTRUMENT_RETURN: { view_dispatcher_switch_to_view(tracker->view_dispatcher, VIEW_TRACKER); break; } case SUBMENU_INSTRUMENT_EXIT: { tracker->quit = true; static InputEvent inevent = {.sequence = 0, .key = InputKeyLeft, .type = InputTypeMAX}; FlizzerTrackerEvent event = {.type = EventTypeInput, .input = inevent, .period = 0}; // making an event so tracker does not wait for next keypress and exits immediately furi_message_queue_put(tracker->event_queue, &event, FuriWaitForever); view_dispatcher_switch_to_view(tracker->view_dispatcher, VIEW_TRACKER); break; } default: break; } break; } default: break; } } void cycle_focus(FlizzerTrackerApp *tracker) { switch (tracker->mode) { case PATTERN_VIEW: { tracker->focus++; if (tracker->focus > EDIT_SONGINFO) { tracker->focus = EDIT_PATTERN; } break; } case INST_EDITOR_VIEW: { tracker->focus++; if (tracker->focus > EDIT_PROGRAM) { tracker->focus = EDIT_INSTRUMENT; } break; } default: break; } } void cycle_view(FlizzerTrackerApp *tracker) { if (tracker->mode == PATTERN_VIEW) { tracker->mode = INST_EDITOR_VIEW; tracker->focus = EDIT_INSTRUMENT; tracker->selected_param = 0; tracker->current_digit = 0; return; } if (tracker->mode == INST_EDITOR_VIEW) { tracker->mode = PATTERN_VIEW; tracker->focus = EDIT_PATTERN; if (tracker->tracker_engine.song == NULL) { stop_song(tracker); tracker_engine_set_song(&tracker->tracker_engine, &tracker->song); } tracker->selected_param = 0; tracker->current_digit = 0; return; } } void process_input_event(FlizzerTrackerApp *tracker, FlizzerTrackerEvent *event) { if (event->input.key == InputKeyBack && event->input.type == InputTypeShort && event->period > 0 && event->period < 300 && !(tracker->editing)) { cycle_view(tracker); return; } else if (event->input.key == InputKeyBack && event->input.type == InputTypeShort && !(tracker->editing)) { cycle_focus(tracker); return; } // Если нажата кнопка "назад", то выходим из цикла, а следовательно и из приложения if (event->input.key == InputKeyBack && event->input.type == InputTypeLong) { switch (tracker->mode) { case PATTERN_VIEW: { submenu_set_selected_item(tracker->pattern_submenu, SUBMENU_PATTERN_RETURN); view_dispatcher_switch_to_view(tracker->view_dispatcher, VIEW_SUBMENU_PATTERN); break; } case INST_EDITOR_VIEW: { submenu_set_selected_item(tracker->instrument_submenu, SUBMENU_INSTRUMENT_RETURN); view_dispatcher_switch_to_view(tracker->view_dispatcher, VIEW_SUBMENU_INSTRUMENT); break; } default: break; } return; } switch (tracker->focus) { case EDIT_PATTERN: { pattern_edit_event(tracker, event); break; } case EDIT_SEQUENCE: { sequence_edit_event(tracker, event); break; } case EDIT_SONGINFO: { songinfo_edit_event(tracker, event); break; } case EDIT_INSTRUMENT: { instrument_edit_event(tracker, event); break; } case EDIT_PROGRAM: { instrument_program_edit_event(tracker, event); break; } default: break; } }