@@ -123,8 +123,6 @@ public:
|
||||
memset(sockets, 0, sizeof(sockets));
|
||||
}
|
||||
|
||||
virtual ~TinyGsmA6() {}
|
||||
|
||||
/*
|
||||
* Basic functions
|
||||
*/
|
||||
|
@@ -40,7 +40,7 @@ enum RegStatus {
|
||||
};
|
||||
|
||||
|
||||
class TinyGsmBG96
|
||||
class TinyGsmBG96: public TinyGsmUTFSMS<TinyGsmBG96>
|
||||
{
|
||||
|
||||
public:
|
||||
@@ -146,7 +146,6 @@ public:
|
||||
{
|
||||
memset(sockets, 0, sizeof(sockets));
|
||||
}
|
||||
virtual ~TinyGsmBG96() {}
|
||||
|
||||
/*
|
||||
* Basic functions
|
||||
@@ -416,33 +415,6 @@ TINY_GSM_MODEM_WAIT_FOR_NETWORK()
|
||||
return waitResponse(60000L) == 1;
|
||||
}
|
||||
|
||||
bool sendSMS_UTF16(const String& number, const void* text, size_t len) {
|
||||
sendAT(GF("+CMGF=1"));
|
||||
waitResponse();
|
||||
sendAT(GF("+CSCS=\"HEX\""));
|
||||
waitResponse();
|
||||
sendAT(GF("+CSMP=17,167,0,8"));
|
||||
waitResponse();
|
||||
|
||||
sendAT(GF("+CMGS=\""), number, GF("\""));
|
||||
if (waitResponse(GF(">")) != 1) {
|
||||
return false;
|
||||
}
|
||||
|
||||
uint16_t* t = (uint16_t*)text;
|
||||
for (size_t i=0; i<len; i++) {
|
||||
uint8_t c = t[i] >> 8;
|
||||
if (c < 0x10) { stream.print('0'); }
|
||||
stream.print(c, HEX);
|
||||
c = t[i] & 0xFF;
|
||||
if (c < 0x10) { stream.print('0'); }
|
||||
stream.print(c, HEX);
|
||||
}
|
||||
stream.write((char)0x1A);
|
||||
stream.flush();
|
||||
return waitResponse(60000L) == 1;
|
||||
}
|
||||
|
||||
|
||||
/*
|
||||
* Location functions
|
||||
|
@@ -141,8 +141,6 @@ public:
|
||||
memset(sockets, 0, sizeof(sockets));
|
||||
}
|
||||
|
||||
virtual ~TinyGsmESP8266() {}
|
||||
|
||||
/*
|
||||
* Basic functions
|
||||
*/
|
||||
|
@@ -121,8 +121,6 @@ public:
|
||||
memset(sockets, 0, sizeof(sockets));
|
||||
}
|
||||
|
||||
virtual ~TinyGsmM590() {}
|
||||
|
||||
/*
|
||||
* Basic functions
|
||||
*/
|
||||
|
@@ -40,7 +40,7 @@ enum RegStatus {
|
||||
};
|
||||
|
||||
|
||||
class TinyGsmM95
|
||||
class TinyGsmM95: public TinyGsmUTFSMS<TinyGsmM95>
|
||||
{
|
||||
|
||||
public:
|
||||
@@ -143,8 +143,6 @@ public:
|
||||
memset(sockets, 0, sizeof(sockets));
|
||||
}
|
||||
|
||||
virtual ~TinyGsmM95() {}
|
||||
|
||||
/*
|
||||
* Basic functions
|
||||
*/
|
||||
@@ -479,33 +477,6 @@ TINY_GSM_MODEM_GET_GPRS_IP_CONNECTED()
|
||||
return waitResponse(60000L) == 1;
|
||||
}
|
||||
|
||||
bool sendSMS_UTF16(const String& number, const void* text, size_t len) {
|
||||
sendAT(GF("+CMGF=1"));
|
||||
waitResponse();
|
||||
sendAT(GF("+CSCS=\"HEX\""));
|
||||
waitResponse();
|
||||
sendAT(GF("+CSMP=17,167,0,8"));
|
||||
waitResponse();
|
||||
|
||||
sendAT(GF("+CMGS=\""), number, GF("\""));
|
||||
if (waitResponse(GF(">")) != 1) {
|
||||
return false;
|
||||
}
|
||||
|
||||
uint16_t* t = (uint16_t*)text;
|
||||
for (size_t i=0; i<len; i++) {
|
||||
uint8_t c = t[i] >> 8;
|
||||
if (c < 0x10) { stream.print('0'); }
|
||||
stream.print(c, HEX);
|
||||
c = t[i] & 0xFF;
|
||||
if (c < 0x10) { stream.print('0'); }
|
||||
stream.print(c, HEX);
|
||||
}
|
||||
stream.write((char)0x1A);
|
||||
stream.flush();
|
||||
return waitResponse(60000L) == 1;
|
||||
}
|
||||
|
||||
/** Delete all SMS */
|
||||
bool deleteAllSMS() {
|
||||
sendAT(GF("+QMGDA=6"));
|
||||
|
@@ -44,7 +44,7 @@ enum RegStatus {
|
||||
};
|
||||
|
||||
|
||||
class TinyGsmMC60
|
||||
class TinyGsmMC60: public TinyGsmUTFSMS<TinyGsmMC60>
|
||||
{
|
||||
|
||||
public:
|
||||
@@ -147,8 +147,6 @@ public:
|
||||
memset(sockets, 0, sizeof(sockets));
|
||||
}
|
||||
|
||||
virtual ~TinyGsmMC60() {}
|
||||
|
||||
/*
|
||||
* Basic functions
|
||||
*/
|
||||
@@ -460,33 +458,6 @@ TINY_GSM_MODEM_GET_GPRS_IP_CONNECTED()
|
||||
return waitResponse(60000L) == 1;
|
||||
}
|
||||
|
||||
bool sendSMS_UTF16(const String& number, const void* text, size_t len) {
|
||||
sendAT(GF("+CMGF=1"));
|
||||
waitResponse();
|
||||
sendAT(GF("+CSCS=\"HEX\""));
|
||||
waitResponse();
|
||||
sendAT(GF("+CSMP=17,167,0,8"));
|
||||
waitResponse();
|
||||
|
||||
sendAT(GF("+CMGS=\""), number, GF("\""));
|
||||
if (waitResponse(GF(">")) != 1) {
|
||||
return false;
|
||||
}
|
||||
|
||||
uint16_t* t = (uint16_t*)text;
|
||||
for (size_t i=0; i<len; i++) {
|
||||
uint8_t c = t[i] >> 8;
|
||||
if (c < 0x10) { stream.print('0'); }
|
||||
stream.print(c, HEX);
|
||||
c = t[i] & 0xFF;
|
||||
if (c < 0x10) { stream.print('0'); }
|
||||
stream.print(c, HEX);
|
||||
}
|
||||
stream.write((char)0x1A);
|
||||
stream.flush();
|
||||
return waitResponse(60000L) == 1;
|
||||
}
|
||||
|
||||
/** Delete all SMS */
|
||||
bool deleteAllSMS() {
|
||||
sendAT(GF("+QMGDA=6"));
|
||||
|
@@ -45,7 +45,7 @@ enum TinyGSMDateTimeFormat {
|
||||
DATE_DATE = 2
|
||||
};
|
||||
|
||||
class TinyGsmSim5360
|
||||
class TinyGsmSim5360: public TinyGsmUTFSMS<TinyGsmSim5360>
|
||||
{
|
||||
|
||||
public:
|
||||
@@ -130,8 +130,6 @@ public:
|
||||
memset(sockets, 0, sizeof(sockets));
|
||||
}
|
||||
|
||||
virtual ~TinyGsmSim5360(){}
|
||||
|
||||
/*
|
||||
* Basic functions
|
||||
*/
|
||||
@@ -522,36 +520,6 @@ TINY_GSM_MODEM_WAIT_FOR_NETWORK()
|
||||
return waitResponse(60000L) == 1;
|
||||
}
|
||||
|
||||
bool sendSMS_UTF16(const String& number, const void* text, size_t len) {
|
||||
// Select message format (1=text)
|
||||
sendAT(GF("+CMGF=1"));
|
||||
waitResponse();
|
||||
// Select TE character set
|
||||
sendAT(GF("+CSCS=\"HEX\""));
|
||||
waitResponse();
|
||||
// Set text mode parameters
|
||||
sendAT(GF("+CSMP=17,167,0,8"));
|
||||
waitResponse();
|
||||
// Send the message
|
||||
sendAT(GF("+CMGS=\""), number, GF("\""));
|
||||
if (waitResponse(GF(">")) != 1) {
|
||||
return false;
|
||||
}
|
||||
|
||||
uint16_t* t = (uint16_t*)text;
|
||||
for (size_t i=0; i<len; i++) {
|
||||
uint8_t c = t[i] >> 8;
|
||||
if (c < 0x10) { stream.print('0'); }
|
||||
stream.print(c, HEX);
|
||||
c = t[i] & 0xFF;
|
||||
if (c < 0x10) { stream.print('0'); }
|
||||
stream.print(c, HEX);
|
||||
}
|
||||
stream.write((char)0x1A);
|
||||
stream.flush();
|
||||
return waitResponse(60000L) == 1;
|
||||
}
|
||||
|
||||
|
||||
/*
|
||||
* Location functions
|
||||
|
@@ -45,7 +45,7 @@ enum TinyGSMDateTimeFormat {
|
||||
DATE_DATE = 2
|
||||
};
|
||||
|
||||
class TinyGsmSim7000
|
||||
class TinyGsmSim7000: public TinyGsmUTFSMS<TinyGsmSim7000>
|
||||
{
|
||||
|
||||
public:
|
||||
@@ -154,8 +154,6 @@ public:
|
||||
memset(sockets, 0, sizeof(sockets));
|
||||
}
|
||||
|
||||
virtual ~TinyGsmSim7000() {}
|
||||
|
||||
/*
|
||||
* Basic functions
|
||||
*/
|
||||
@@ -564,33 +562,6 @@ TINY_GSM_MODEM_WAIT_FOR_NETWORK()
|
||||
return waitResponse(60000L) == 1;
|
||||
}
|
||||
|
||||
bool sendSMS_UTF16(const String& number, const void* text, size_t len) {
|
||||
sendAT(GF("+CMGF=1"));
|
||||
waitResponse();
|
||||
sendAT(GF("+CSCS=\"HEX\""));
|
||||
waitResponse();
|
||||
sendAT(GF("+CSMP=17,167,0,8"));
|
||||
waitResponse();
|
||||
|
||||
sendAT(GF("+CMGS=\""), number, GF("\""));
|
||||
if (waitResponse(GF(">")) != 1) {
|
||||
return false;
|
||||
}
|
||||
|
||||
uint16_t* t = (uint16_t*)text;
|
||||
for (size_t i=0; i<len; i++) {
|
||||
uint8_t c = t[i] >> 8;
|
||||
if (c < 0x10) { stream.print('0'); }
|
||||
stream.print(c, HEX);
|
||||
c = t[i] & 0xFF;
|
||||
if (c < 0x10) { stream.print('0'); }
|
||||
stream.print(c, HEX);
|
||||
}
|
||||
stream.write((char)0x1A);
|
||||
stream.flush();
|
||||
return waitResponse(60000L) == 1;
|
||||
}
|
||||
|
||||
|
||||
/*
|
||||
* Location functions
|
||||
|
@@ -45,7 +45,7 @@ enum TinyGSMDateTimeFormat {
|
||||
DATE_DATE = 2
|
||||
};
|
||||
|
||||
class TinyGsmSim7600
|
||||
class TinyGsmSim7600: public TinyGsmUTFSMS<TinyGsmSim7600>
|
||||
{
|
||||
|
||||
public:
|
||||
@@ -130,8 +130,6 @@ public:
|
||||
memset(sockets, 0, sizeof(sockets));
|
||||
}
|
||||
|
||||
virtual ~TinyGsmSim7600(){}
|
||||
|
||||
/*
|
||||
* Basic functions
|
||||
*/
|
||||
@@ -498,36 +496,6 @@ TINY_GSM_MODEM_WAIT_FOR_NETWORK()
|
||||
return waitResponse(60000L) == 1;
|
||||
}
|
||||
|
||||
bool sendSMS_UTF16(const String& number, const void* text, size_t len) {
|
||||
// Select message format (1=text)
|
||||
sendAT(GF("+CMGF=1"));
|
||||
waitResponse();
|
||||
// Select TE character set
|
||||
sendAT(GF("+CSCS=\"HEX\""));
|
||||
waitResponse();
|
||||
// Set text mode parameters
|
||||
sendAT(GF("+CSMP=17,167,0,8"));
|
||||
waitResponse();
|
||||
// Send the message
|
||||
sendAT(GF("+CMGS=\""), number, GF("\""));
|
||||
if (waitResponse(GF(">")) != 1) {
|
||||
return false;
|
||||
}
|
||||
|
||||
uint16_t* t = (uint16_t*)text;
|
||||
for (size_t i=0; i<len; i++) {
|
||||
uint8_t c = t[i] >> 8;
|
||||
if (c < 0x10) { stream.print('0'); }
|
||||
stream.print(c, HEX);
|
||||
c = t[i] & 0xFF;
|
||||
if (c < 0x10) { stream.print('0'); }
|
||||
stream.print(c, HEX);
|
||||
}
|
||||
stream.write((char)0x1A);
|
||||
stream.flush();
|
||||
return waitResponse(60000L) == 1;
|
||||
}
|
||||
|
||||
|
||||
/*
|
||||
* Location functions
|
||||
|
@@ -46,7 +46,7 @@ enum TinyGSMDateTimeFormat {
|
||||
DATE_DATE = 2
|
||||
};
|
||||
|
||||
class TinyGsmSim800
|
||||
class TinyGsmSim800 : public TinyGsmUTFSMS<TinyGsmSim800>
|
||||
{
|
||||
|
||||
public:
|
||||
@@ -153,8 +153,6 @@ public:
|
||||
memset(sockets, 0, sizeof(sockets));
|
||||
}
|
||||
|
||||
virtual ~TinyGsmSim800() {}
|
||||
|
||||
/*
|
||||
* Basic functions
|
||||
*/
|
||||
@@ -597,34 +595,6 @@ TINY_GSM_MODEM_WAIT_FOR_NETWORK()
|
||||
return waitResponse(60000L) == 1;
|
||||
}
|
||||
|
||||
bool sendSMS_UTF16(const String& number, const void* text, size_t len) {
|
||||
sendAT(GF("+CMGF=1"));
|
||||
waitResponse();
|
||||
sendAT(GF("+CSCS=\"HEX\""));
|
||||
waitResponse();
|
||||
sendAT(GF("+CSMP=17,167,0,8"));
|
||||
waitResponse();
|
||||
|
||||
sendAT(GF("+CMGS=\""), number, GF("\""));
|
||||
if (waitResponse(GF(">")) != 1) {
|
||||
return false;
|
||||
}
|
||||
|
||||
uint16_t* t = (uint16_t*)text;
|
||||
for (size_t i=0; i<len; i++) {
|
||||
uint8_t c = t[i] >> 8;
|
||||
if (c < 0x10) { stream.print('0'); }
|
||||
stream.print(c, HEX);
|
||||
c = t[i] & 0xFF;
|
||||
if (c < 0x10) { stream.print('0'); }
|
||||
stream.print(c, HEX);
|
||||
}
|
||||
stream.write((char)0x1A);
|
||||
stream.flush();
|
||||
return waitResponse(60000L) == 1;
|
||||
}
|
||||
|
||||
|
||||
/*
|
||||
* Location functions
|
||||
*/
|
||||
|
@@ -22,8 +22,6 @@ public:
|
||||
: TinyGsmSim800(stream)
|
||||
{}
|
||||
|
||||
virtual ~TinyGsmSim808(){}
|
||||
|
||||
/*
|
||||
* GPS location functions
|
||||
*/
|
||||
|
@@ -202,8 +202,6 @@ public:
|
||||
memset(sockets, 0, sizeof(sockets));
|
||||
}
|
||||
|
||||
virtual ~TinyGsmSaraR4(){}
|
||||
|
||||
/*
|
||||
* Basic functions
|
||||
*/
|
||||
|
@@ -179,8 +179,6 @@ public:
|
||||
memset(sockets, 0, sizeof(sockets));
|
||||
}
|
||||
|
||||
virtual ~TinyGsmSequansMonarch() {}
|
||||
|
||||
/*
|
||||
* Basic functions
|
||||
*/
|
||||
|
@@ -164,8 +164,6 @@ public:
|
||||
memset(sockets, 0, sizeof(sockets));
|
||||
}
|
||||
|
||||
virtual ~TinyGsmUBLOX() {}
|
||||
|
||||
/*
|
||||
* Basic functions
|
||||
*/
|
||||
|
@@ -287,9 +287,6 @@ public:
|
||||
inCommandMode = false;
|
||||
memset(sockets, 0, sizeof(sockets));
|
||||
}
|
||||
|
||||
virtual ~TinyGsmXBee() {}
|
||||
|
||||
/*
|
||||
* Basic functions
|
||||
*/
|
||||
|
@@ -645,4 +645,77 @@ String TinyGsmDecodeHex16bit(String &instr) {
|
||||
}
|
||||
|
||||
|
||||
//Common methods for UTF8/UTF16 SMS.
|
||||
//Supported by: BG96, M95, MC60, SIM5360, SIM7000, SIM7600, SIM800
|
||||
template<class T>
|
||||
class TinyGsmUTFSMS {
|
||||
public:
|
||||
|
||||
class UTF8Print : public Print {
|
||||
public:
|
||||
UTF8Print(Print& p) : p(p) {}
|
||||
virtual size_t write(const uint8_t c) override {
|
||||
if(prv < 0xC0) {
|
||||
if(c < 0xC0) printHex(c);
|
||||
prv = c;
|
||||
} else {
|
||||
uint16_t v = uint16_t(prv)<<8 | c;
|
||||
v -= (v>>8 == 0xD0)? 0xCC80 : 0xCD40;
|
||||
printHex(v);
|
||||
prv = 0;
|
||||
}
|
||||
return 1;
|
||||
}
|
||||
private:
|
||||
Print& p;
|
||||
uint8_t prv = 0;
|
||||
void printHex(const uint16_t v) {
|
||||
uint8_t c = v >> 8;
|
||||
if (c < 0x10) p.print('0');
|
||||
p.print(c, HEX);
|
||||
c = v & 0xFF;
|
||||
if (c < 0x10) p.print('0');
|
||||
p.print(c, HEX);
|
||||
}
|
||||
};
|
||||
|
||||
bool sendSMS_UTF8_begin(const char* const number) {
|
||||
static_cast<T*>(this)->sendAT(GF("+CMGF=1"));
|
||||
static_cast<T*>(this)->waitResponse();
|
||||
static_cast<T*>(this)->sendAT(GF("+CSCS=\"HEX\""));
|
||||
static_cast<T*>(this)->waitResponse();
|
||||
static_cast<T*>(this)->sendAT(GF("+CSMP=17,167,0,8"));
|
||||
static_cast<T*>(this)->waitResponse();
|
||||
|
||||
static_cast<T*>(this)->sendAT(GF("+CMGS=\""), number, GF("\""));
|
||||
return static_cast<T*>(this)->waitResponse(GF(">")) == 1;
|
||||
}
|
||||
bool sendSMS_UTF8_end() {
|
||||
static_cast<T*>(this)->stream.write((char)0x1A);
|
||||
static_cast<T*>(this)->stream.flush();
|
||||
return static_cast<T*>(this)->waitResponse(60000L) == 1;
|
||||
}
|
||||
UTF8Print sendSMS_UTF8_stream() {
|
||||
return UTF8Print(static_cast<T*>(this)->stream);
|
||||
}
|
||||
|
||||
bool sendSMS_UTF16(const char* const number, const void* text, size_t len) {
|
||||
if (!sendSMS_UTF8_begin(number)) {
|
||||
return false;
|
||||
}
|
||||
|
||||
uint16_t* t = (uint16_t*)text;
|
||||
for (size_t i=0; i<len; i++) {
|
||||
uint8_t c = t[i] >> 8;
|
||||
if (c < 0x10) { static_cast<T*>(this)->stream.print('0'); }
|
||||
static_cast<T*>(this)->stream.print(c, HEX);
|
||||
c = t[i] & 0xFF;
|
||||
if (c < 0x10) { static_cast<T*>(this)->stream.print('0'); }
|
||||
static_cast<T*>(this)->stream.print(c, HEX);
|
||||
}
|
||||
|
||||
return sendSMS_UTF8_end();
|
||||
}
|
||||
};
|
||||
|
||||
#endif
|
||||
|
Reference in New Issue
Block a user