passy_scene_read.c 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. #include "../passy_i.h"
  2. #include "../passy_reader.h"
  3. #include <dolphin/dolphin.h>
  4. #define TAG "PassySceneRead"
  5. static PassyReader* passy_reader = NULL;
  6. void passy_scene_read_on_enter(void* context) {
  7. Passy* passy = context;
  8. dolphin_deed(DolphinDeedNfcRead);
  9. // Setup view
  10. Popup* popup = passy->popup;
  11. popup_set_header(popup, "Reading", 68, 30, AlignLeft, AlignTop);
  12. popup_set_icon(popup, 0, 3, &I_RFIDDolphinReceive_97x61);
  13. passy->poller = nfc_poller_alloc(passy->nfc, NfcProtocolIso14443_4b);
  14. passy_reader = passy_reader_alloc(passy);
  15. nfc_poller_start(passy->poller, passy_reader_poller_callback, passy_reader);
  16. passy->bytes_total = 0;
  17. passy_blink_start(passy);
  18. view_dispatcher_switch_to_view(passy->view_dispatcher, PassyViewPopup);
  19. }
  20. bool passy_scene_read_on_event(void* context, SceneManagerEvent event) {
  21. Passy* passy = context;
  22. bool consumed = false;
  23. Popup* popup = passy->popup;
  24. if(event.type == SceneManagerEventTypeCustom) {
  25. if(event.event == PassyCustomEventReaderSuccess) {
  26. if(passy->read_type == PassyReadCOM) {
  27. scene_manager_next_scene(passy->scene_manager, PassySceneAdvancedMenu);
  28. } else {
  29. scene_manager_next_scene(passy->scene_manager, PassySceneReadSuccess);
  30. }
  31. consumed = true;
  32. } else if(event.event == PassyCustomEventReaderError) {
  33. passy->last_sw = passy_reader->last_sw;
  34. scene_manager_next_scene(passy->scene_manager, PassySceneReadError);
  35. consumed = true;
  36. } else if(event.event == PassyCustomEventReaderDetected) {
  37. popup_set_header(popup, "Detected", 68, 30, AlignLeft, AlignTop);
  38. } else if(event.event == PassyCustomEventReaderAuthenticated) {
  39. popup_set_header(popup, "Authenticated", 68, 30, AlignLeft, AlignTop);
  40. } else if(event.event == PassyCustomEventReaderReading) {
  41. if(passy->bytes_total == 0) {
  42. popup_set_header(popup, "Reading", 68, 30, AlignLeft, AlignTop);
  43. } else {
  44. // Update the header with the current bytes read
  45. char header[32];
  46. snprintf(
  47. header,
  48. sizeof(header),
  49. "Reading\n%d/%dk",
  50. passy->offset,
  51. (passy->bytes_total / 1024));
  52. popup_set_header(popup, header, 68, 30, AlignLeft, AlignTop);
  53. }
  54. }
  55. } else if(event.type == SceneManagerEventTypeBack) {
  56. scene_manager_search_and_switch_to_previous_scene(
  57. passy->scene_manager, PassySceneMainMenu);
  58. consumed = true;
  59. }
  60. return consumed;
  61. }
  62. void passy_scene_read_on_exit(void* context) {
  63. Passy* passy = context;
  64. if(passy_reader) {
  65. passy_reader_free(passy_reader);
  66. passy_reader = NULL;
  67. }
  68. if(passy->poller) {
  69. nfc_poller_stop(passy->poller);
  70. nfc_poller_free(passy->poller);
  71. passy->poller = NULL;
  72. }
  73. // Clear view
  74. popup_reset(passy->popup);
  75. passy_blink_stop(passy);
  76. }