pof_scene_main.c 3.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. #include "../portal_of_flipper_i.h"
  2. #include "../pof_token.h"
  3. enum SubmenuIndex {
  4. // SubmenuIndexFigure* need to match POF_TOKEN_LIMIT
  5. SubmenuIndexFigure1,
  6. SubmenuIndexFigure2,
  7. SubmenuIndexFigure3,
  8. SubmenuIndexFigure4,
  9. SubmenuIndexFigure5,
  10. SubmenuIndexFigure6,
  11. SubmenuIndexFigure7,
  12. SubmenuIndexLoad,
  13. };
  14. void pof_scene_main_submenu_callback(void* context, uint32_t index) {
  15. PoFApp* pof = context;
  16. view_dispatcher_send_custom_event(pof->view_dispatcher, index);
  17. }
  18. void pof_scene_main_on_update(void* context) {
  19. PoFApp* pof = context;
  20. VirtualPortal* virtual_portal = pof->virtual_portal;
  21. Submenu* submenu = pof->submenu;
  22. submenu_reset(pof->submenu);
  23. if(pof->pof_usb) {
  24. int count = 0;
  25. for(int i = 0; i < POF_TOKEN_LIMIT; i++) {
  26. if(virtual_portal->tokens[i]->loaded) {
  27. PoFToken* pof_token = virtual_portal->tokens[i];
  28. // Unload figure
  29. submenu_add_item(
  30. submenu,
  31. pof_token->dev_name,
  32. SubmenuIndexFigure1 + i,
  33. pof_scene_main_submenu_callback,
  34. pof);
  35. count++;
  36. }
  37. }
  38. if(count < POF_TOKEN_LIMIT) {
  39. submenu_add_item(
  40. submenu, "<Load figure>", SubmenuIndexLoad, pof_scene_main_submenu_callback, pof);
  41. }
  42. submenu_set_selected_item(
  43. submenu, scene_manager_get_scene_state(pof->scene_manager, PoFSceneMain));
  44. } else {
  45. submenu_add_item(
  46. submenu, "Failed to start", SubmenuIndexLoad, pof_scene_main_submenu_callback, pof);
  47. }
  48. view_dispatcher_switch_to_view(pof->view_dispatcher, PoFViewSubmenu);
  49. }
  50. void pof_scene_main_on_enter(void* context) {
  51. pof_scene_main_on_update(context);
  52. }
  53. bool pof_scene_main_on_event(void* context, SceneManagerEvent event) {
  54. PoFApp* pof = context;
  55. VirtualPortal* virtual_portal = pof->virtual_portal;
  56. bool consumed = false;
  57. if(event.type == SceneManagerEventTypeCustom) {
  58. if(event.event == SubmenuIndexLoad) {
  59. if(pof->pof_usb) {
  60. // Explicitly save state so that the correct item is
  61. // reselected if the user cancels loading a file.
  62. scene_manager_set_scene_state(pof->scene_manager, PoFSceneMain, SubmenuIndexLoad);
  63. scene_manager_next_scene(pof->scene_manager, PoFSceneFileSelect);
  64. } else {
  65. // No-op
  66. }
  67. consumed = true;
  68. } else {
  69. pof_token_clear(virtual_portal->tokens[event.event], true);
  70. pof_scene_main_on_update(context);
  71. }
  72. } else if(event.type == SceneManagerEventTypeBack) {
  73. scene_manager_stop(pof->scene_manager);
  74. view_dispatcher_stop(pof->view_dispatcher);
  75. consumed = true;
  76. }
  77. return consumed;
  78. }
  79. void pof_scene_main_on_exit(void* context) {
  80. PoFApp* pof = context;
  81. submenu_reset(pof->submenu);
  82. }