Здравствуйте!
В свой проект на Esp8266 решил добавить управление через telegram для чего использовал библиотеку UniversalTelegramBot. В процессе работы заметил что код начал притормаживать. Подозрение пало на эту библиотеку. В пример идущий с библиотекой добавил пару строк для вычисления времени которое идет на проверку наличия новых сообщений
В результате получил такой ответ
Как видно - на проверку уходит от 2 до 6 секунд. На это время работа остальной части кода останавливается что меня не устраивает. Можно ли как-то избежать этого?
В свой проект на Esp8266 решил добавить управление через telegram для чего использовал библиотеку UniversalTelegramBot. В процессе работы заметил что код начал притормаживать. Подозрение пало на эту библиотеку. В пример идущий с библиотекой добавил пару строк для вычисления времени которое идет на проверку наличия новых сообщений
Код:
#include <ESP8266WiFi.h>
#include <WiFiClientSecure.h>
#include <UniversalTelegramBot.h>
// Wifi network station credentials
#define WIFI_SSID "YOUR_SSID"
#define WIFI_PASSWORD "YOUR_PASSWORD"
// Telegram BOT Token (Get from Botfather)
#define BOT_TOKEN "XXXXXXXXX:XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX"
const unsigned long BOT_MTBS = 1000; // mean time between scan messages
X509List cert(TELEGRAM_CERTIFICATE_ROOT);
WiFiClientSecure secured_client;
UniversalTelegramBot bot(BOT_TOKEN, secured_client);
unsigned long bot_lasttime; // last time messages' scan has been done
const int ledPin = LED_BUILTIN;
int ledStatus = 0;
void handleNewMessages(int numNewMessages)
{
Serial.print("handleNewMessages ");
Serial.println(numNewMessages);
for (int i = 0; i < numNewMessages; i++)
{
String chat_id = bot.messages[i].chat_id;
String text = bot.messages[i].text;
String from_name = bot.messages[i].from_name;
if (from_name == "")
from_name = "Guest";
if (text == "/ledon")
{
digitalWrite(ledPin, LOW); // turn the LED on (HIGH is the voltage level)
ledStatus = 1;
bot.sendMessage(chat_id, "Led is ON", "");
}
if (text == "/ledoff")
{
ledStatus = 0;
digitalWrite(ledPin, HIGH); // turn the LED off (LOW is the voltage level)
bot.sendMessage(chat_id, "Led is OFF", "");
}
if (text == "/status")
{
if (ledStatus)
{
bot.sendMessage(chat_id, "Led is ON", "");
}
else
{
bot.sendMessage(chat_id, "Led is OFF", "");
}
}
if (text == "/start")
{
String welcome = "Welcome to Universal Arduino Telegram Bot library, " + from_name + ".\n";
welcome += "This is Flash Led Bot example.\n\n";
welcome += "/ledon : to switch the Led ON\n";
welcome += "/ledoff : to switch the Led OFF\n";
welcome += "/status : Returns current status of LED\n";
bot.sendMessage(chat_id, welcome, "Markdown");
}
}
}
void setup()
{
Serial.begin(9600);
pinMode(ledPin, OUTPUT); // initialize digital ledPin as an output.
delay(10);
digitalWrite(ledPin, HIGH); // initialize pin as off (active LOW)
WiFi.begin(WIFI_SSID, WIFI_PASSWORD);
while (WiFi.status() != WL_CONNECTED)
{
Serial.print(".");
delay(500);
}
Serial.print("\nWiFi connected. IP address: ");
Serial.println(WiFi.localIP());
}
void loop()
{
if (millis() - bot_lasttime > BOT_MTBS)
{unsigned long b_lasttime=millis();
int numNewMessages = bot.getUpdates(bot.last_message_received + 1);
Serial.print("getUpdates= ");Serial.println(millis()-b_lasttime);
while (numNewMessages)
{
Serial.println("got response");
handleNewMessages(numNewMessages);
numNewMessages = bot.getUpdates(bot.last_message_received + 1);
}
bot_lasttime = millis();
}
}
Код:
etUpdates= 2370
getUpdates= 4347
getUpdates= 2335
getUpdates= 2762
getUpdates= 5120
getUpdates= 3126
getUpdates= 3409
getUpdates= 2345
getUpdates= 2699
getUpdates= 2278
getUpdates= 6890
getUpdates= 3572
getUpdates= 3432
getUpdates= 2627
getUpdates= 2990
getUpdates= 2764
getUpdates= 5426
getUpdates= 3872
getUpdates= 2365
getUpdates= 2537
getUpdates= 3120
getUpdates= 2760