mirror of
https://github.com/DarkFlippers/unleashed-firmware
synced 2025-01-24 18:45:00 +00:00
a024e470b7
* SubGhz: the functions of saving loading KeeLog have been modified, saving KeeLog is prohibited * SubGhz: Fix displaying Nice FlorS in the Raed scene * SubGhz: Fix displaying Faac SLH in the Raed scene * SubGhz: Fix displaying iDo in the Raed scene * SubGhz: Fix displaying Star Line in the Raed scene * SubGhz: Fix displaying Nice Flo in the Raed scene, added save and load functions. (testing needed, no remote control) * SubGhz: subghz_beginadded common encoder upload signal * SubGhz: add Came encoder * SubGhz: modified pricenton encoder, fix view transmitter hide the "Send" button if there is no encoder * SubGhz: add nice flo encoder, need testing no remote control * SubGhz: add gate_tx encoder * SubGhz: add nero_sketch encoder * SubGhz: add keelog encoder * SubGhz: add long upload upload while the button is pressed while releasing the transfer is over, with a check for sticking (maximum 200 upload repetitions) * SubGhz: fix max upload * SubGhz: Fix structure subghz add encoder * SubGhz: add generating and sending a dynamic keelog key, refactoring the code * SubGhz: add notifications * SubGhz: add creating a new remote control (Pricenton, Nice Flo 12bit, Nice Flo 24bit, CAME 12bit, CAME 24bit, Gate TX, DoorHan) * SubGhz: Fix load file, fix scene start * Subghz: Fix show key * SubGhz: Fix subghz_cli * SubGhz: Fix furi-hal-subghz * Format sources * SubGhz: standard notification scheme, fix broken assert in DMA. * SubGhz: move level alignment logic to furi-hal-subghz, fix spelling, cleanup. Co-authored-by: Aleksandr Kutuzov <alleteam@gmail.com>
91 lines
3.5 KiB
C
91 lines
3.5 KiB
C
#include "../subghz_i.h"
|
|
|
|
enum SubmenuIndex {
|
|
SubmenuIndexAnalyze,
|
|
SubmenuIndexRead,
|
|
SubmenuIndexSaved,
|
|
SubmenuIndexStatic,
|
|
SubmenuIndexTest,
|
|
SubmenuIndexAddManualy,
|
|
};
|
|
|
|
void subghz_scene_start_submenu_callback(void* context, uint32_t index) {
|
|
SubGhz* subghz = context;
|
|
view_dispatcher_send_custom_event(subghz->view_dispatcher, index);
|
|
}
|
|
|
|
const void subghz_scene_start_on_enter(void* context) {
|
|
SubGhz* subghz = context;
|
|
if(subghz->state_notifications == NOTIFICATION_STARTING_STATE) {
|
|
subghz->state_notifications = NOTIFICATION_IDLE_STATE;
|
|
}
|
|
submenu_add_item(
|
|
subghz->submenu,
|
|
"Analyze",
|
|
SubmenuIndexAnalyze,
|
|
subghz_scene_start_submenu_callback,
|
|
subghz);
|
|
submenu_add_item(
|
|
subghz->submenu, "Read", SubmenuIndexRead, subghz_scene_start_submenu_callback, subghz);
|
|
submenu_add_item(
|
|
subghz->submenu, "Saved", SubmenuIndexSaved, subghz_scene_start_submenu_callback, subghz);
|
|
submenu_add_item(
|
|
subghz->submenu,
|
|
"Add manually",
|
|
SubmenuIndexAddManualy,
|
|
subghz_scene_start_submenu_callback,
|
|
subghz);
|
|
submenu_add_item(
|
|
subghz->submenu, "Static", SubmenuIndexStatic, subghz_scene_start_submenu_callback, subghz);
|
|
submenu_add_item(
|
|
subghz->submenu, "Test", SubmenuIndexTest, subghz_scene_start_submenu_callback, subghz);
|
|
|
|
submenu_set_selected_item(
|
|
subghz->submenu, scene_manager_get_scene_state(subghz->scene_manager, SubGhzSceneStart));
|
|
|
|
view_dispatcher_switch_to_view(subghz->view_dispatcher, SubGhzViewMenu);
|
|
}
|
|
|
|
const bool subghz_scene_start_on_event(void* context, SceneManagerEvent event) {
|
|
SubGhz* subghz = context;
|
|
|
|
if(event.type == SceneManagerEventTypeCustom) {
|
|
if(event.event == SubmenuIndexAnalyze) {
|
|
scene_manager_set_scene_state(
|
|
subghz->scene_manager, SubGhzSceneStart, SubmenuIndexAnalyze);
|
|
scene_manager_next_scene(subghz->scene_manager, SubGhzSceneAnalyze);
|
|
return true;
|
|
} else if(event.event == SubmenuIndexRead) {
|
|
scene_manager_set_scene_state(
|
|
subghz->scene_manager, SubGhzSceneStart, SubmenuIndexRead);
|
|
scene_manager_next_scene(subghz->scene_manager, SubGhzSceneRead);
|
|
return true;
|
|
} else if(event.event == SubmenuIndexSaved) {
|
|
scene_manager_set_scene_state(
|
|
subghz->scene_manager, SubGhzSceneStart, SubmenuIndexSaved);
|
|
scene_manager_next_scene(subghz->scene_manager, SubGhzSceneSaved);
|
|
return true;
|
|
} else if(event.event == SubmenuIndexAddManualy) {
|
|
scene_manager_set_scene_state(
|
|
subghz->scene_manager, SubGhzSceneStart, SubmenuIndexAddManualy);
|
|
scene_manager_next_scene(subghz->scene_manager, SubGhzSceneSetType);
|
|
return true;
|
|
} else if(event.event == SubmenuIndexStatic) {
|
|
scene_manager_set_scene_state(
|
|
subghz->scene_manager, SubGhzSceneStart, SubmenuIndexStatic);
|
|
scene_manager_next_scene(subghz->scene_manager, SubGhzSceneStatic);
|
|
return true;
|
|
} else if(event.event == SubmenuIndexTest) {
|
|
scene_manager_set_scene_state(
|
|
subghz->scene_manager, SubGhzSceneStart, SubmenuIndexTest);
|
|
scene_manager_next_scene(subghz->scene_manager, SubGhzSceneTest);
|
|
return true;
|
|
}
|
|
}
|
|
return false;
|
|
}
|
|
|
|
const void subghz_scene_start_on_exit(void* context) {
|
|
SubGhz* subghz = context;
|
|
submenu_clean(subghz->submenu);
|
|
}
|