pvorobei писал(а): 27 фев 2019, 10:10[ref]Timmy101[/ref],
По поводу зависания - есть идея, но на это нужно время поковыряться в библиотеке. Здесь [ref=#aa0000]Anydy[/ref], мыслит в верном направлении, мне кажется, работать нужно примерно так - каждые n сек проверка подключения если нет - вызываем reconnect. Если соединение есть - запускаем cayenne.loop. Это не избавит от мелких подвисаний во время реконекта, но, должно помочь с зависанием наглухо.
Со временем сейчас напряг, как появится - попробую побороть.
Но если у кого-то есть время и желание.
Вот нашёл на вскидку решение аналогичной проблемы с blynk.
https://electronic-crafts.blogspot.com/ ... t.html?m=1
Можно попробовать по аналогии запилить.
А мне кажется нужно действовать вот так (Почти как вы написали )
1) Нужно запихнуть все что касается cayenne в отдельный модуль.
2) Проверять коннект с сервером mydevices раз в 10 сек. Если есть коннект, то запускать модуль cayenne если нет то ждать когда коннект появится и только потом делать реконнет.
3) кастрировать настройку wifi из блока cayenne чтоб он не мешал настрйокам из дерева проекта flprog
Сейчас вроде нашел вариант который надо попробовать:
111.PNG
Простейший пример в flprog тупо только cayennе с передачей только одной переменной
Посмотрите что создает компилятор
Код: Выделить всё
#include <ESP8266WiFi.h>
#include <CayenneMQTTESP8266.h>
extern "C" {
#include "user_interface.h";
}
char username[] = "USERNAME_MQTT" ;
char password[] = "PASS_MQTT" ;
char clientID[] = "APKEY_MQTT" ;
int in_230823610_1;
bool ESP8266ControllerWifiClient_HRD = 0;
bool ESP8266ControllerWifiClient_status = 1;
bool ESP8266ControllerWifiClient_isDHCP = 1;
bool ESP8266ControllerWifiClient_IsNeedReconect = 0;
bool ESP8266ControllerWifiClient_workStatus = 1;
char ESP8266ControllerWifiClient_SSID[40] = "TEST";
char ESP8266ControllerWifiClient_password[40] = "123456789";
IPAddress ESP8266ControllerWifiClient_ip(0, 0, 0, 0);
IPAddress ESP8266ControllerWifiClient_dns (0, 0, 0, 1);
IPAddress ESP8266ControllerWifiClient_gateway (0, 0, 0, 1);
IPAddress ESP8266ControllerWifiClient_subnet (255, 255, 255, 0);
uint8_t ESP8266ControllerWifiClient_mac[6] = {0x0, 0x0, 0x0, 0x0, 0x0, 0x0};
int _gtv1 = 25; //Temp
void setup()
{
WiFi.mode(WIFI_STA);
_esp8266WifiModuleClientReconnect();
Cayenne.begin(username, password, clientID);
}
void loop()
{if(ESP8266ControllerWifiClient_IsNeedReconect) {_esp8266WifiModuleClientReconnect(); ESP8266ControllerWifiClient_IsNeedReconect = 0; }
ESP8266ControllerWifiClient_status = WiFi.status() == WL_CONNECTED;
if (ESP8266ControllerWifiClient_status) { if ( ! ESP8266ControllerWifiClient_HRD) { ESP8266ControllerWifiClient_ip = WiFi.localIP();
ESP8266ControllerWifiClient_subnet = WiFi.subnetMask();
ESP8266ControllerWifiClient_gateway = WiFi.gatewayIP();
ESP8266ControllerWifiClient_dns = WiFi.dnsIP();
WiFi.macAddress(ESP8266ControllerWifiClient_mac);
ESP8266ControllerWifiClient_HRD = 1;
}} else {ESP8266ControllerWifiClient_HRD = 0;}
//Плата:1
Cayenne.loop();
//Плата:2
in_230823610_1 = _gtv1;
}
CAYENNE_OUT(0)
{
Cayenne.virtualWrite(0, in_230823610_1);
}
bool _isTimer(unsigned long startTime, unsigned long period )
{
unsigned long currentTime;
currentTime = millis();
if (currentTime>= startTime) {return (currentTime>=(startTime + period));} else {return (currentTime >=(4294967295-startTime+period));}
}
int hexStrToInt(String instring)
{
byte len = instring.length();
if (len == 0) return 0;
int result = 0;
for (byte i = 0; i < 8; i++) // только первые 8 цыфар влезуть в uint32
{
char ch = instring[i];
if (ch == 0) break;
result <<= 4;
if (isdigit(ch))
result = result | (ch - '0');
else result = result | (ch - 'A' + 10);
}
return result;
}
void _esp8266WifiModuleClientReconnect()
{
if( _checkMacAddres(ESP8266ControllerWifiClient_mac)) { wifi_set_macaddr(0, const_cast<uint8*>(ESP8266ControllerWifiClient_mac));}
if( ESP8266ControllerWifiClient_isDHCP) { WiFi.config(0U, 0U, 0U, 0U, 0U); } else {
WiFi.config(ESP8266ControllerWifiClient_ip, ESP8266ControllerWifiClient_gateway, ESP8266ControllerWifiClient_subnet, ESP8266ControllerWifiClient_dns , ESP8266ControllerWifiClient_dns );
}
WiFi.begin(ESP8266ControllerWifiClient_SSID, ESP8266ControllerWifiClient_password);
}
bool _checkMacAddres(byte array[])
{
bool result = 0;
for (byte i = 0; i < 6; i++)
{
if (array[i] == 255) {
return 0;
}
if (array[i] > 0 ) {
result = 1;
}
}
return result;
}
Так вот моими тестами выяснилось, что проблема кроется в блоках передачи / приема данных.
Данные блоки при добавлении их в проект создают указанные функции с соответсвующими именами каналов.
Код: Выделить всё
CAYENNE_OUT(0)
{
Cayenne.virtualWrite(0, in_230823610_1);
}
Причем если обратите внимание, данные функции сидят не в цикле void loop().
Как они вызываются и кто их вызывает мне пока неизвестно...
Так давайте в эту функцию cayenne out передавать параметр Enable, если 1 - выполнять, 0 - break из функции. Чтобы прошивка из функции выходила, так как она насколько я понял зацикливается именно в ней.
Кто сможет синтаксис поправить? Сам на работе только если вечером...
Отправлено спустя 18 минут 9 секунд:
А если того проще. Есть у кого возможность проверить. Если создать переменную ENABLE - признак доступа в инет. Потом руками уже в IDE прописать в блоках передачи:
Код: Выделить всё
CAYENNE_OUT(0)
{
if (ENABLE=true){Cayenne.virtualWrite(0, in_230823610_1);}
}
Отправлено спустя 4 минуты 45 секунд:
При этом если сделать это же самое "по принципу" в условиях платы. То как это бы поуму б было, то посмотрите как компилирует код Flprog
переменная gtv2 = Читать как Enable.
Компилятор все делает правильно, он вставляет условие на выполнение платы, но прикол заключается в том, что блоки передачи/прием данных находятся ВНЕ цикла void loop и поэтому это все работает некорректно. Необходимо условие выполнения платы по условию запихивать внутрь функций передачи. А еще лучше - на вызов самой функции, но кто ее вызывает я не нашел....
Но это предположение. Надо проверять. Опять же это решает только вопрос работы основной прошивке в момент пропадания интренета. Но остается вопрос реконнекта.... хотя возможно что решив этот вопрос реконнект шаттно будет работать, ибо железка уже не будет зациклена... кто может проверить?
Код: Выделить всё
/Плата:2
if (_gtv2 == 1) {
in_230823610_1 = _gtv1;
}
CAYENNE_OUT(0)
{
Cayenne.virtualWrite(0, in_230823610_1);
}
Отправлено спустя 11 часов 39 минут 15 секунд:
Ну что ребятушки!!! Это фигня помогла!!! Если ручками вписывать условие! Единственное, не стартует при отсутствии интернета, но это мне нужно проверить, возможно это у меня из-за этапности....а так работает) Железка не виснет)
Отправлено спустя 3 минуты :
И точка доступа заработала!!! Юхху! В общем лекарство действенное!!! Осталось победить старт без интернета!
У вас нет необходимых прав для просмотра вложений в этом сообщении.