From 276ac7960dfa5c1949d2865cbf13ea76e7d9e7b0 Mon Sep 17 00:00:00 2001 From: Michael Date: Sun, 9 Feb 2020 17:05:28 +0100 Subject: [PATCH] Pause playback when card is removed --- Tonuino.ino | 78 ++++++++++++++++++++++++++++++++++++++++++----------- 1 file changed, 62 insertions(+), 16 deletions(-) diff --git a/Tonuino.ino b/Tonuino.ino index ac359337..d870116e 100644 --- a/Tonuino.ino +++ b/Tonuino.ino @@ -48,6 +48,9 @@ struct nfcTagObject { // uint8_t special2; }; +bool card_present = false; +bool card_present_prev = false; + // admin settings stored in eeprom struct adminSettings { uint32_t cookie; @@ -944,7 +947,25 @@ void playShortCut(uint8_t shortCut) { } void loop() { + int _rfid_error_counter = 0; + do { + // auf Lesefehler des RFID Moduls prüfen + _rfid_error_counter += 1; + if(_rfid_error_counter > 2){ + card_present = false; + } + + // Ist eine Karte aufgelegt? + byte bufferATQA[2]; + byte bufferSize = sizeof(bufferATQA); + MFRC522::StatusCode result = mfrc522.PICC_RequestA(bufferATQA, &bufferSize); + + if(result == mfrc522.STATUS_OK){ + _rfid_error_counter = 0; + card_present = true; + } + checkStandbyAtMillis(); mp3.loop(); @@ -1088,28 +1109,53 @@ void loop() { } #endif // Ende der Buttons - } while (!mfrc522.PICC_IsNewCardPresent()); - // RFID Karte wurde aufgelegt + // solange keine Karte aufgelegt oder heruntergenommen wird + } while ( !(!card_present && card_present_prev) && !(card_present && !card_present_prev) ); + + // RFID Karte wurde entfernt + if (!card_present && card_present_prev){ + card_present_prev = card_present; + // pausiere + if (activeModifier != NULL) + if (activeModifier->handlePause() == true) + return; + if (ignorePauseButton == false) + if (isPlaying()) { + mp3.pause(); + setstandbyTimer(); + } + else if (knownCard) { + mp3.start(); + disablestandbyTimer(); + } + ignorePauseButton = false; + return; + } - if (!mfrc522.PICC_ReadCardSerial()) - return; + // RFID Karte wurde aufgelegt + if (card_present && !card_present_prev){ + card_present_prev = card_present; - if (readCard(&myCard) == true) { - if (myCard.cookie == cardCookie && myCard.nfcFolderSettings.folder != 0 && myCard.nfcFolderSettings.mode != 0) { - playFolder(); - } + if (!mfrc522.PICC_ReadCardSerial()) + return; - // Neue Karte konfigurieren - else if (myCard.cookie != cardCookie) { - knownCard = false; - mp3.playMp3FolderTrack(300); - waitForTrackToFinish(); - setupCard(); + if (readCard(&myCard) == true) { + if (myCard.cookie == cardCookie && myCard.nfcFolderSettings.folder != 0 && myCard.nfcFolderSettings.mode != 0) { + playFolder(); + } + + // Neue Karte konfigurieren + else if (myCard.cookie != cardCookie) { + knownCard = false; + mp3.playMp3FolderTrack(300); + waitForTrackToFinish(); + setupCard(); + } } + //mfrc522.PICC_HaltA(); + mfrc522.PCD_StopCrypto1(); } - mfrc522.PICC_HaltA(); - mfrc522.PCD_StopCrypto1(); } void adminMenu(bool fromCard = false) {