From 7c630052e0892e29ca2bded09cdfe0aa5cd4f4f2 Mon Sep 17 00:00:00 2001 From: Xavier Date: Sat, 10 Sep 2016 14:23:03 +0200 Subject: [PATCH] Fixed issue #17: voice call no longer breaking SMS --- aquaMonitor.ino | 35 +++++++++++++++++++++++++++++------ 1 file changed, 29 insertions(+), 6 deletions(-) diff --git a/aquaMonitor.ino b/aquaMonitor.ino index 40fbb3e..e961bd8 100644 --- a/aquaMonitor.ino +++ b/aquaMonitor.ino @@ -6,11 +6,10 @@ #include #include "DS1307.h" - // 'admin' phone number defined outside of open source file haha ! // This file should contain a line in the likes of: // #define ADMIN_NUMBER "+12345678910", which is the international number notation -#include "remoteNumber.h" +#include "aquaMonitorSecret.h" // Compilation directives to enable/disable stuff like IR support // Beware, 'includes' for the matching libraries need to be commented / uncommented @@ -90,6 +89,7 @@ struct displayData { #define PINNUMBER "" // Pin number for the SIM CARD GSM gsmAccess; // include a 'true' parameter for debug enabled GSM_SMS sms; +GSMVoiceCall vcs; // LCD #if WITH_LCD_SUPPORT @@ -135,6 +135,10 @@ unsigned long lastPowerCheck = lastTemperatureCheck; #define SMS_CHECK_PERIOD 30000 unsigned long lastSmsCheck = lastTemperatureCheck; +// Check for incoming voice call: if not handled, will break SMS management +#define CALL_CHECK_PERIOD 10000 +unsigned long lastCallCheck = lastTemperatureCheck; + // Max size of a received SMS #define MAX_SMS_LENGTH 40 boolean gsmEnabled = true; @@ -157,7 +161,7 @@ void setup(void) { pinMode(LEVEL_PIN, INPUT); digitalWrite(LEVEL_PIN, HIGH); // Activate pullup resistor - // Just in case some loop goes crazy, limit the number of EEPROM writes to save it + // During dev and debug, in case some loop goes crazy, limit the number of EEPROM writes to save it // TODO : this should be removed some day EEPROM.setMaxAllowedWrites(100); @@ -190,9 +194,11 @@ void setup(void) { displayTransient(getProgMemMsg(CONNECTING_GSM_MSG)); if(gsmAccess.begin(PINNUMBER)==GSM_READY) { displayTransient(getProgMemMsg(CONNECTED_GSM_MSG)); + // This makes sure the modem notifies correctly incoming events + vcs.hangCall(); } else { displayTransient(getProgMemMsg(NOT_CONNECTED_GSM_MSG)); - delay(20000); + delay(1000); } } #if WITH_LCD_SUPPORT @@ -230,7 +236,7 @@ void loop(void) { } if(checkElapsedDelay(now, lastTemperatureCheck, TEMPERATURE_CHECK_PERIOD)) { statusOK = checkTemperature() && statusOK; - lastTemperatureCheck = millis(); + lastTemperatureCheck = now; } if(checkElapsedDelay(now, lastLevelCheck, LEVEL_CHECK_PERIOD)) { statusOK = checkLevel() && statusOK; @@ -244,6 +250,10 @@ void loop(void) { checkSMS(); lastSmsCheck = millis(); // checkSMS is a bit slow. } + if(checkElapsedDelay(now, lastCallCheck, CALL_CHECK_PERIOD)) { + checkCall(); + lastCallCheck = now; + } if(!statusOK) { sendAlert(); @@ -308,6 +318,7 @@ boolean checkTemperature() { displayTransient(getProgMemMsg(CRC_NOT_VALID_MSG)); } else if ( addr[sensor][0] != 0x28) { displayTransient(getProgMemMsg(FAMILY_MSG)); + sprintf(display.temperatureMsg, getProgMemMsg(TEMPERATURE_MSG_FORMAT), '+', 0 ); } else { ds.reset(); ds.select(addr[sensor]); @@ -415,6 +426,18 @@ boolean checkLight() { return(lightOK); } +// Check for incoming voice call, in order to not break SMS +void checkCall() { + switch (vcs.getvoiceCallStatus()) { + case RECEIVINGCALL: + Serial.println("RECEIVING CALL"); + vcs.answerCall(); + delay(1000); + vcs.hangCall(); + break; + } +} + // Check for incoming SMS, and processes it if any void checkSMS() { char from[PHONE_NUMBER_LENGTH + 1]; @@ -1022,7 +1045,7 @@ void refreshDisplay() { Serial.print(" "); Serial.print(display.lightMsg); Serial.print(" "); - Serial.println(display.levelMsg); + Serial.print(display.levelMsg); Serial.print(" "); Serial.println(display.powerMsg); lastSerialStatus = now;