Lampa ws2812B DIY

radzik_r
Posty: 390
Rejestracja: ndz sie 11, 2019 5:32 pm

Kod: Zaznacz cały

#include <FastLED.h>
#include <Adafruit_NeoPixel.h>


#define NUM_LEDS 60
#define DATA_PIN 4


#define BRIGHTNESS  50
#define FRAMES_PER_SECOND 60
CRGB leds[NUM_LEDS];



#define supla_lib_config_h_  // silences debug messages
#include "LittleFS.h"
#include <Wire.h>
#include <WiFiManager.h>
#include <EEPROM.h>
#include <ESP8266WebServer.h>
#include <ESP8266HTTPUpdateServer.h>
#include <ESP8266TrueRandom.h>
#include <WiFiClientSecure.h>
#include <ArduinoJson.h>
#include <Ticker.h>

#include <SuplaDevice.h>
#include <supla/action_handler.h>
#include <supla/control/dimmer_base.h>
#include <supla/control/rgb_base.h>
#include <supla/control/relay.h>
#include <supla/control/button.h>

#include <supla/network/esp_wifi.h>
Supla::ESPWifi wifi("SSID", "PASS");  //------ Do not change----wifimanager takes care------
#define STORAGE_OFFSET 512
#include <supla/storage/eeprom.h>
Supla::Eeprom eeprom(STORAGE_OFFSET);



//#define D0 16  //no internal pullup resistor
//#define D1  5
//#define D2  4
//#define D3  0  //must not be pulled low during power on/reset, toggles value during boot
//#define D4  2  //must not be pulled low during power on/reset, toggles value during boot
//#define D5 14
//#define D6 12
//#define D7 13
//#define D8 15  //must not be pulled high during power on/reset
//#define RX  3  //High at boot
//#define TX  1  //must not be pulled low during power on/reset


#define LED_PIN 2        //D4
#define button_0_pin  0  //D3
#define button_5_pin  5  //D1

int DIODES = -1;

bool statusLedOn = LOW;


const int  relay_1_pin = 201;
const int  relay_2_pin = 202;
const int  relay_3_pin = 203;
const int  relay_4_pin = 204;
const int  relay_5_pin = 205;
const int  relay_6_pin = 206;

bool relay_1_state = false;
bool relay_2_state = false;
bool relay_3_state = false;
bool relay_4_state = false;
bool relay_5_state = false;
bool relay_6_state = false;

uint32_t redWSLED ;
uint32_t greenWSLED;
uint32_t blueWSLED;
uint32_t colorBrightnessWSLED;
uint32_t brightnessWSLED;


int SEToff = -1;

bool setupEnd = false;
bool setOff = false;
int offTriger = -1;

int C_W_state = HIGH;
int last_C_W_state = HIGH;
unsigned long time_last_C_W_change = 0;
long C_W_delay = 10000;               // ---------------------- config delay 10 seconds ---------------------------
char Supla_server[81] = ("wpisz adres serwera");
char Email[81] = ("wpisz adres email");
char Supla_name[81] = ("SuplaPixelControlerWS2815LED");
char Router_SSID[32];
char Router_Pass[64];
char Supla_status[51];
bool shouldSaveConfig = false;
bool initialConfig = false;
bool starting = true;
bool tikOn = true;
int s;
char GUID[SUPLA_GUID_SIZE];
char AUTHKEY[SUPLA_AUTHKEY_SIZE];
byte uuidNumber[16];
static const char logo[] PROGMEM = "<style>html{ background-color: #01DF3A;}</style><div class='s'><svg version='1.1' id='l' x='0' y='0' viewBox='0 0 200 200' xml:space='preserve'><path d='M59.3,2.5c18.1,0.6,31.8,8,40.2,23.5c3.1,5.7,4.3,11.9,4.1,18.3c-0.1,3.6-0.7,7.1-1.9,10.6c-0.2,0.7-0.1,1.1,0.6,1.5c12.8,7.7,25.5,15.4,38.3,23c2.9,1.7,5.8,3.4,8.7,5.3c1,0.6,1.6,0.6,2.5-0.1c4.5-3.6,9.8-5.3,15.7-5.4c12.5-0.1,22.9,7.9,25.2,19c1.9,9.2-2.9,19.2-11.8,23.9c-8.4,4.5-16.9,4.5-25.5,0.2c-0.7-0.3-1-0.2-1.5,0.3c-4.8,4.9-9.7,9.8-14.5,14.6c-5.3,5.3-10.6,10.7-15.9,16c-1.8,1.8-3.6,3.7-5.4,5.4c-0.7,0.6-0.6,1,0,1.6c3.6,3.4,5.8,7.5,6.2,12.2c0.7,7.7-2.2,14-8.8,18.5c-12.3,8.6-30.3,3.5-35-10.4c-2.8-8.4,0.6-17.7,8.6-22.8c0.9-0.6,1.1-1,0.8-2c-2-6.2-4.4-12.4-6.6-18.6c-6.3-17.6-12.7-35.1-19-52.7c-0.2-0.7-0.5-1-1.4-0.9c-12.5,0.7-23.6-2.6-33-10.4c-8-6.6-12.9-15-14.2-25c-1.5-11.5,1.7-21.9,9.6-30.7C32.5,8.9,42.2,4.2,53.7,2.7c0.7-0.1,1.5-0.2,2.2-0.2C57,2.4,58.2,2.5,59.3,2.5z M76.5,81c0,0.1,0.1,0.3,0.1,0.6c1.6,6.3,3.2,12.6,4.7,18.9c4.5,17.7,8.9,35.5,13.3,53.2c0.2,0.9,0.6,1.1,1.6,0.9c5.4-1.2,10.7-0.8,15.7,1.6c0.8,0.4,1.2,0.3,1.7-0.4c11.2-12.9,22.5-25.7,33.4-38.7c0.5-0.6,0.4-1,0-1.6c-5.6-7.9-6.1-16.1-1.3-24.5c0.5-0.8,0.3-1.1-0.5-1.6c-9.1-4.7-18.1-9.3-27.2-14c-6.8-3.5-13.5-7-20.3-10.5c-0.7-0.4-1.1-0.3-1.6,0.4c-1.3,1.8-2.7,3.5-4.3,5.1c-4.2,4.2-9.1,7.4-14.7,9.7C76.9,80.3,76.4,80.3,76.5,81z M89,42.6c0.1-2.5-0.4-5.4-1.5-8.1C83,23.1,74.2,16.9,61.7,15.8c-10-0.9-18.6,2.4-25.3,9.7c-8.4,9-9.3,22.4-2.2,32.4c6.8,9.6,19.1,14.2,31.4,11.9C79.2,67.1,89,55.9,89,42.6z M102.1,188.6c0.6,0.1,1.5-0.1,2.4-0.2c9.5-1.4,15.3-10.9,11.6-19.2c-2.6-5.9-9.4-9.6-16.8-8.6c-8.3,1.2-14.1,8.9-12.4,16.6C88.2,183.9,94.4,188.6,102.1,188.6z M167.7,88.5c-1,0-2.1,0.1-3.1,0.3c-9,1.7-14.2,10.6-10.8,18.6c2.9,6.8,11.4,10.3,19,7.8c7.1-2.3,11.1-9.1,9.6-15.9C180.9,93,174.8,88.5,167.7,88.5z'/></svg>";





ESP8266WebServer httpServer(81);
ESP8266HTTPUpdateServer httpUpdater;
WiFiManager wifiManager;
Ticker ticker;

#define MY_BUTTON_ACTION_1 1
#define MY_BUTTON_ACTION_2 2
#define MY_BUTTON_ACTION_3 3
#define MY_CONFIG_ACTION   4

Supla::Control::RGBBase *miRgb = nullptr;
Supla::Control::DimmerBase *miDim = nullptr;

Supla::Control::Relay *relay_1 = nullptr;
Supla::Control::Relay *relay_2 = nullptr;
Supla::Control::Relay *relay_3 = nullptr;
Supla::Control::Relay *relay_4 = nullptr;
Supla::Control::Relay *relay_5 = nullptr;
Supla::Control::Relay *relay_6 = nullptr;


class MyAction : public Supla::ActionHandler {
  public:
    void handleAction(int event, int action) {

      Serial.print("\t event "); Serial.print(event); Serial.print("\t action "); Serial.print(action);

      if (action == MY_BUTTON_ACTION_1) {
        int LOS = random(1, 6);
        switch (LOS) {
          case 1: relay_1->turnOn(); break;
          case 2: relay_2->turnOn(); break;
          case 3: relay_3->turnOn(); break;
          case 4: relay_4->turnOn(); break;
          case 5: relay_5->turnOn(); break;
          case 6: relay_6->turnOn(); break;
        }
      }



      else if (action == MY_BUTTON_ACTION_2) {
        relay_1->turnOff();
        relay_2->turnOff();
        relay_3->turnOff();
        relay_4->turnOff();
        relay_5->turnOff();
        relay_6->turnOff();
      }
      else if (action == MY_BUTTON_ACTION_3) {
      }

      else if (action == MY_CONFIG_ACTION) {
        initialConfig = true;
      }

    }
}; MyAction action;




class RgbLeds : public Supla::Control::RGBBase {
  public:
    RgbLeds(int Channel)
      : Channel(Channel) {
    }
    void setRGBWValueOnDevice( uint32_t  red,
                               uint32_t  green,
                               uint32_t  blue,
                               uint32_t  colorBrightness,
                               uint32_t  brightness) {

      if ( Channel == 0) {
        redWSLED             = map(red,             0, 1023, 0, 127);
        greenWSLED           = map(green,           0, 1023, 0, 127);
        blueWSLED            = map(blue,            0, 1023, 0, 127);
        colorBrightnessWSLED = map(colorBrightness, 0, 1023, 0, 127);

        DIODES = -1;
        offTriger = 10;

        for (int i = 0; i < NUM_LEDS; i++) {
          leds[i].r = redWSLED;
          leds[i].g = greenWSLED;
          leds[i].b = blueWSLED ;
        }
        FastLED.setBrightness( colorBrightnessWSLED );
        FastLED.show();
      }
    }
  protected:
    int Channel;
};

class Dimm : public Supla::Control::DimmerBase {
  public:
    Dimm(int Channel)
      : Channel(Channel) {
    }
    void setRGBWValueOnDevice(uint32_t red,
                              uint32_t green,
                              uint32_t blue,
                              uint32_t colorBrightness,
                              uint32_t brightness) {

      if ( Channel == 1) {
        brightnessWSLED = map(brightness, 0, 1023, 0, 127);
        FastLED.setBrightness( brightnessWSLED );
        FastLED.show();
      }
    }
  protected:
    int Channel;
};

class CustomControl : public Supla::Io {
  public:
    void customDigitalWrite(int channelNumber, uint8_t pin, uint8_t val) {

      if ((pin == relay_1_pin) && (setupEnd)) {
        if (val == 1) {
          relay_1_state = true;
          if (setOff == false) {
            setOff = true;
            offTriger = 1;
            Serial.println("\tKANAL 1 DIODES ON");
            DIODES = 1;
            SEToff = 1;
          }
        }
        else if ((val == 0) && (setupEnd)) {
          relay_1_state = false;
          if (setOff == false) {
            setOff = true;
            offTriger = 1;
            Serial.println("\tKANAL 1 DIODES OFF");
            DIODES = 0;
            SEToff = 0;
          }
        }
      }
      else if ((pin == relay_2_pin) && (setupEnd)) {
        if (val == 1) {
          relay_2_state = true;
          if (setOff == false) {
            setOff = true;
            offTriger = 2;
            Serial.println("\tKANAL 2 DIODES ON");
            DIODES = 2;
            SEToff = 1;
          }

        }
        if (val == 0) {
          relay_2_state = false;
          if (setOff == false) {
            setOff = true;
            offTriger = 2;
            Serial.println("\tKANAL 2 DIODES OFF");
            DIODES = 0;
            SEToff = 0;
          }
        }
      }
      else if ((pin == relay_3_pin) && (setupEnd)) {
        if (val == 1) {
          relay_3_state = true;
          if (setOff == false) {
            setOff = true;
            offTriger = 3;
            Serial.println("\tKANAL 3 DIODES ON");
            DIODES = 3;
            SEToff = 1;
          }

        }
        if (val == 0) {
          relay_3_state = false;
          if (setOff == false) {
            setOff = true;
            offTriger = 3;
            Serial.println("\tKANAL 3 DIODES OFF");
            DIODES = 0;
            SEToff = 0;
          }
        }
      }
      else if ((pin == relay_4_pin) && (setupEnd)) {
        if (val == 1) {
          relay_4_state = true;
          if (setOff == false) {
            setOff = true;
            offTriger = 4;
            Serial.println("\tKANAL 4 DIODES ON");
            DIODES = 4;
            SEToff = 1;
          }

        }
        if (val == 0) {
          relay_4_state = false;
          if (setOff == false) {
            setOff = true;
            offTriger = 4;
            Serial.println("\tKANAL 4 DIODES OFF");
            DIODES = 0;
            SEToff = 0;
          }
        }
      }
      else if ((pin == relay_5_pin) && (setupEnd)) {
        if (val == 1) {
          relay_5_state = true;
          if (setOff == false) {
            setOff = true;
            offTriger = 5;
            Serial.println("\tKANAL 5 DIODES ON");
            DIODES = 5;
            SEToff = 1;
          }

        }
        if (val == 0) {
          relay_5_state = false;
          if (setOff == false) {
            setOff = true;
            offTriger = 5;
            Serial.println("\tKANAL 5 DIODES OFF");
            DIODES = 0;
            SEToff = 0;
          }
        }
      }


      else if ((pin == relay_6_pin) && (setupEnd)) {
        if (val == 1) {
          relay_6_state = true;
          if (setOff == false) {
            setOff = true;
            offTriger = 6;
            Serial.println("\tKANAL 6 DIODES ON");
            DIODES = 6;
            SEToff = 1;
          }

        }
        if (val == 0) {
          relay_6_state = false;
          if (setOff == false) {
            setOff = true;
            offTriger = 6;
            Serial.println("\tKANAL 6 DIODES OFF");
            DIODES = 0;
            SEToff = 0;
          }
        }
      }


      else {
        return ::digitalWrite(pin, val);
      }
    }

    int customDigitalRead(int channelNumber, uint8_t pin) {
      if (pin == relay_1_pin) {
        return relay_1_state;
      } else if (pin == relay_2_pin) {
        return relay_2_state;
      } else if (pin == relay_3_pin) {
        return relay_3_state;
      } else if (pin == relay_4_pin) {
        return relay_4_state;
      } else if (pin == relay_5_pin) {
        return relay_5_state;
      } else if (pin == relay_6_pin) {
        return relay_6_state;

      } else {
        return ::digitalRead(pin);
      }
    }
} CustomControl;






void tick() {
  int state = digitalRead(LED_PIN);
  digitalWrite(LED_PIN, !state);
}


void saveConfigCallback () {
  Serial.println("Should save config");
  shouldSaveConfig = true;
}

void ondemandwifiCallback () {
  ticker.detach();
  digitalWrite(LED_PIN, statusLedOn);
  tikOn = false;

  WiFiManagerParameter custom_Supla_server("server", "supla server", Supla_server, 81, "required");
  WiFiManagerParameter custom_Email("email", "Email", Email, 81, "required");
  WiFiManagerParameter custom_Supla_name("name", "Supla Nazwa urządzenia", Supla_name, 81, "required");
  WiFiManagerParameter custom_html_id21("<div><h4> - Supla Status -   ");
  WiFiManagerParameter custom_html_id22( Supla_status);
  WiFiManagerParameter custom_html_id23( "</h4></div>");

  wifiManager.setBreakAfterConfig(true);
  wifiManager.setSaveConfigCallback(saveConfigCallback);

  wifiManager.addParameter(&custom_Supla_server);
  wifiManager.addParameter(&custom_Email);
  wifiManager.addParameter(&custom_Supla_name);
  wifiManager.addParameter(&custom_html_id21);
  wifiManager.addParameter(&custom_html_id22);
  wifiManager.addParameter(&custom_html_id23);

  wifiManager.setCustomHeadElement(logo);
  wifiManager.setMinimumSignalQuality(8);
  wifiManager.setConfigPortalTimeout(300);

  std::vector<const char *> menu = {"wifi", "wifinoscan", "sep", "info", "update", "restart", "exit"};
  wifiManager.setMenu(menu);           // custom menu, pass vector
  wifiManager.setTitle("by..kedar");   // name displayed on the main page

  if (!wifiManager.startConfigPortal("SuplaPixelControlerWS2815LED")) {
    Serial.println("Not connected to WiFi but continuing anyway.");
  } else {
    Serial.println("connected...yeey :)");
  }
  strcpy(Supla_server, custom_Supla_server.getValue());
  strcpy(Email, custom_Email.getValue());
  strcpy(Supla_name, custom_Supla_name.getValue());
  wifiManager.getWiFiSSID().toCharArray(Router_SSID, 33);
  wifiManager.getWiFiPass().toCharArray(Router_Pass, 65);
  if (strcmp(Supla_server, "get_new_guid_and_authkey") == 0) {
    Serial.println("new guid & authkey.");
    EEPROM.write(300, 0);
    EEPROM.commit();
    delay(100);
    ESP.reset();
  }
  if (shouldSaveConfig == true) {
    Serial.println(" config...");
    DynamicJsonDocument json(1024);
    json["Supla_server"] = Supla_server;
    json["Email"]        = Email;
    json["Supla_name"]   = Supla_name;
    json["Router_SSID"]  = Router_SSID;
    json["Router_Pass"]  = Router_Pass;
    File configFile = LittleFS.open("/config.json", "w");
    if (!configFile) {
      Serial.println("failed to open config file for writing");
    }
    serializeJsonPretty(json, Serial);
    serializeJson(json, configFile);
    configFile.close();
    Serial.println("Config written successfully");
    shouldSaveConfig = false;
    initialConfig = false;
    WiFi.mode(WIFI_STA);
    delay(5000);
    ESP.restart();
  }
  WiFi.softAPdisconnect(true);
  initialConfig = false;
}

void status_func(int status, const char *msg) {
  if (s != status) {
    s = status;
    if (s != 10) {
      strcpy(Supla_status, msg);
    }
  }
}

void guid_authkey(void) {
  if (EEPROM.read(300) != 60) {
    int eep_gui = 301;
    ESP8266TrueRandom.uuid(uuidNumber);
    String uuidString = "";
    for (int i = 0; i < 16; i++) {
      int topDigit = uuidNumber[i] >> 4;
      int bottomDigit = uuidNumber[i] & 0x0f;
      uuidString += "0123456789abcdef"[topDigit];
      uuidString += "0123456789abcdef"[bottomDigit];
    }
    int length_uuid = uuidString.length();
    for (int i = 0; i < length_uuid; ++i) {
      EEPROM.put(eep_gui + i, uuidString[i]);
    }
    int eep_aut = 341;
    ESP8266TrueRandom.uuid(uuidNumber);
    String uuidString2 = "";
    for (int i = 0; i < 16; i++) {
      int topDigit = uuidNumber[i] >> 4;
      int bottomDigit = uuidNumber[i] & 0x0f;
      uuidString2 += "0123456789abcdef"[topDigit];
      uuidString2 += "0123456789abcdef"[bottomDigit];
    }
    int length_uuid2 = uuidString2.length();
    for (int i = 0; i < length_uuid2; ++i) {
      EEPROM.put(eep_aut + i, uuidString2[i]);
    }
    EEPROM.write(300, 60);
    EEPROM.commit();
    delay(0);
  }
  read_guid();
  read_authkey();
  Serial.print("GUID : "); Serial.println(read_guid());
  Serial.print("AUTHKEY : "); Serial.println(read_authkey());
}

String read_guid(void) {
  String read_eeprom = "";
  int i, ii = 0;
  int eep_star = 301;
  int end_guid = eep_star + SUPLA_GUID_SIZE;
  String temp_read = "0x";
  for (i = eep_star; i < end_guid + 16;  i = i + 1) {
    temp_read += char(EEPROM.read(i));
    read_eeprom += char(EEPROM.read(i));
    if ( (i % 2) == 0) {
      char *_guid = strcpy((char*)malloc(temp_read.length() + 1), temp_read.c_str());
      GUID[ii] = strtoul( _guid, NULL, 16);
      temp_read = "0x";
      ii++;
    }
  }
  return read_eeprom;
}

String read_authkey(void) {
  String read_eeprom = "";
  int i, ii = 0;
  int eep_star = 341;
  int end_authkey = eep_star + SUPLA_AUTHKEY_SIZE;
  String temp_read = "0x";
  for (i = eep_star; i < end_authkey + 16;  i = i + 1) {
    temp_read += char(EEPROM.read(i));
    read_eeprom += char(EEPROM.read(i));
    if ( (i % 2) == 0) {
      char *_authkey = strcpy((char*)malloc(temp_read.length() + 1), temp_read.c_str());
      AUTHKEY[ii] = strtoul( _authkey, NULL, 16);
      temp_read = "0x";
      ii++;
    }
  }
  return read_eeprom;
}

void setup() {

  Serial.begin(115200, SERIAL_8N1, SERIAL_TX_ONLY, 1);
  delay(10);
  Serial.println(" ");
  Serial.println(" ");
  pinMode(button_0_pin, INPUT_PULLUP);
  pinMode(button_5_pin, INPUT_PULLUP);




  ticker.attach(0.5, tick);
  EEPROM.begin(1024);

  if (EEPROM.read(300) != 60) {
    initialConfig = true;
  }

  guid_authkey();

  if (WiFi.SSID() == "") {
    initialConfig = true;
  }
  if (LittleFS.begin()) {
    Serial.println("mounted file system");
    if (LittleFS.exists("/config.json")) {
      Serial.println("reading config file");
      File configFile = LittleFS.open("/config.json", "r");
      if (configFile) {
        Serial.println("opened config file");
        size_t size = configFile.size();
        std::unique_ptr<char[]> buf(new char[size]);
        configFile.readBytes(buf.get(), size);
        DynamicJsonDocument json(1024);
        DeserializationError deserializeError = deserializeJson(json, buf.get());
        serializeJsonPretty(json, Serial);
        if (!deserializeError) {
          Serial.println("\nparsed json");
          if (json.containsKey("Supla_server")) strcpy(Supla_server, json["Supla_server"]);
          if (json.containsKey("Email"))        strcpy(Email, json["Email"]);
          if (json.containsKey("Supla_name"))   strcpy(Supla_name, json["Supla_name"]);
          if (json.containsKey("Router_SSID"))  strcpy(Router_SSID, json["Router_SSID"]);
          if (json.containsKey("Router_Pass"))  strcpy(Router_Pass, json["Router_Pass"]);


        } else {
          Serial.println("failed to load json config");
          initialConfig = true;
        }
        configFile.close();
      }
    }
  } else {
    Serial.println("failed to mount FS");
  }

  FastLED.addLeds<NEOPIXEL, DATA_PIN>(leds, NUM_LEDS);
  FastLED.setBrightness(BRIGHTNESS);



  wifi_station_set_hostname(Supla_name);
  WiFi.mode(WIFI_STA);


  miRgb = new RgbLeds(0);
  miDim = new Dimm(1);


  relay_1 = new Supla::Control::Relay(relay_1_pin, true, 192);
  relay_1->getChannel()->setDefault(SUPLA_CHANNELFNC_STAIRCASETIMER);
  relay_1->keepTurnOnDuration();
  relay_1->disableChannelState();

  relay_2 = new Supla::Control::Relay(relay_2_pin, true, 192);
  relay_2->getChannel()->setDefault(SUPLA_CHANNELFNC_STAIRCASETIMER);
  relay_2->keepTurnOnDuration();
  relay_2->disableChannelState();

  relay_3 = new Supla::Control::Relay(relay_3_pin, true, 192);
  relay_3->getChannel()->setDefault(SUPLA_CHANNELFNC_STAIRCASETIMER);
  relay_3->keepTurnOnDuration();
  relay_3->disableChannelState();

  relay_4 = new Supla::Control::Relay(relay_4_pin, true, 192);
  relay_4->getChannel()->setDefault(SUPLA_CHANNELFNC_STAIRCASETIMER);
  relay_4->keepTurnOnDuration();
  relay_4->disableChannelState();

  relay_5 = new Supla::Control::Relay(relay_5_pin, true, 192);
  relay_5->getChannel()->setDefault(SUPLA_CHANNELFNC_STAIRCASETIMER);
  relay_5->keepTurnOnDuration();
  relay_5->disableChannelState();

  relay_6 = new Supla::Control::Relay(relay_6_pin, true, 192);
  relay_6->getChannel()->setDefault(SUPLA_CHANNELFNC_STAIRCASETIMER);
  relay_6->keepTurnOnDuration();
  relay_6->disableChannelState();




  auto button1 = new Supla::Control::Button(button_5_pin, true, true);  //  new Supla::Control::Button(pin, pullup, invertLogic);

  button1->setMulticlickTime(800);
  button1->addAction(MY_BUTTON_ACTION_1, action, Supla::ON_CLICK_1);
  button1->addAction(MY_BUTTON_ACTION_2, action, Supla::ON_CLICK_2);
  button1->addAction(MY_CONFIG_ACTION,   action, Supla::ON_CLICK_5);







  SuplaDevice.setName(Supla_name);
  SuplaDevice.setStatusFuncImpl(&status_func);
  wifi.enableSSL(false);
  wifi.setSsid(Router_SSID);
  wifi.setPassword(Router_Pass);
  SuplaDevice.begin(GUID, Supla_server, Email, AUTHKEY);

  if (initialConfig == true) {
    ondemandwifiCallback();
  }


  setupEnd = true;

}



void loop() {

  if (initialConfig == true) {
    ondemandwifiCallback();
  }


  int C_W_read = digitalRead(button_0_pin); {
    if (C_W_read != last_C_W_state) {
      time_last_C_W_change = millis();
      Serial.println("\t CONFIG PIN ");
    }
    if ((millis() - time_last_C_W_change) > C_W_delay) {
      if (C_W_read != C_W_state) {
        C_W_state = C_W_read;
        if (C_W_state == LOW) {
          Serial.println("\t ondemandwifiCallback()");
          ondemandwifiCallback();
        }
      }
    }
    last_C_W_state = C_W_read;

  }

  SuplaDevice.iterate();

  delay(25);

  if (WiFi.status() == WL_CONNECTED) {
    if (starting) {
      httpUpdater.setup(&httpServer, "/update", "admin", "pass");
      httpServer.begin();
      starting = false;
    }
    httpServer.handleClient();
  }
  if (s == STATUS_REGISTERED_AND_READY) {
    if (tikOn) {
      ticker.detach();
      digitalWrite(LED_PIN, !statusLedOn);
      tikOn = false;
    }
  } else if (!tikOn) {
    ticker.attach(0.5, tick);
    tikOn = true;
  }




  if (setOff) {
    switch (offTriger) {
      case 1:
        if (relay_2->isOn())relay_2->turnOff();
        if (relay_3->isOn())relay_3->turnOff();
        if (relay_4->isOn())relay_4->turnOff();
        if (relay_5->isOn())relay_5->turnOff();
        if (relay_6->isOn())relay_6->turnOff();
        break;
      case 2:
        if (relay_1->isOn())relay_1->turnOff();
        if (relay_3->isOn())relay_3->turnOff();
        if (relay_4->isOn())relay_4->turnOff();
        if (relay_5->isOn())relay_5->turnOff();
        if (relay_6->isOn())relay_6->turnOff();
        break;
      case 3:
        if (relay_1->isOn())relay_1->turnOff();
        if (relay_2->isOn())relay_2->turnOff();
        if (relay_4->isOn())relay_4->turnOff();
        if (relay_5->isOn())relay_5->turnOff();
        if (relay_5->isOn())relay_5->turnOff();
        if (relay_6->isOn())relay_6->turnOff();
        break;
      case 4:
        if (relay_1->isOn())relay_1->turnOff();
        if (relay_2->isOn())relay_2->turnOff();
        if (relay_3->isOn())relay_3->turnOff();
        if (relay_5->isOn())relay_5->turnOff();
        if (relay_6->isOn())relay_6->turnOff();
        break;
      case 5:
        if (relay_1->isOn())relay_1->turnOff();
        if (relay_2->isOn())relay_2->turnOff();
        if (relay_3->isOn())relay_3->turnOff();
        if (relay_4->isOn())relay_4->turnOff();
        if (relay_6->isOn())relay_6->turnOff();
        break;
      case 6:
        if (relay_1->isOn())relay_1->turnOff();
        if (relay_2->isOn())relay_2->turnOff();
        if (relay_3->isOn())relay_3->turnOff();
        if (relay_4->isOn())relay_4->turnOff();
        if (relay_5->isOn())relay_5->turnOff();
        break;
      case 10:
        if (relay_1->isOn())relay_1->turnOff();
        if (relay_2->isOn())relay_2->turnOff();
        if (relay_3->isOn())relay_3->turnOff();
        if (relay_4->isOn())relay_4->turnOff();
        if (relay_5->isOn())relay_5->turnOff();
        if (relay_6->isOn())relay_6->turnOff();
        break;
    }
    offTriger = -1;
    setOff = false;
  }


  switch (SEToff) {
    case 0:
      if ( !relay_1->isOn() && !relay_2->isOn() && !relay_3->isOn() && !relay_4->isOn() && !relay_5->isOn()) {
        miDim->setRGBW(-1, -1, -1, -1, 0);
      }
      SEToff = -1;
      break;
    case 1:
      if (brightnessWSLED == 0) {
        miDim->setRGBW(-1, -1, -1, -1, 50);
      }
      SEToff = -1;
      break;
  }

  switch (DIODES) {
    case 0:
      OFF();
      DIODES = -1;
      break;
    case 1:
      RANDOM_WHITE();
      break;
    case 2:
      COLOR_TEMPERATURE();
      break;
    case 3:
      PACIFICA_LOOP();
      break;
    case 4:
      CONFETTI();
      break;
    case 5:
      CYLON();
      break;
    case 6:
      CYLON2();
      break;

  }



}




void OFF() {
  for (int i = NUM_LEDS; i >= 0 ; i--) {
    leds[i] = CRGB::Black;
  }
  FastLED.show();
  delay(10);
}


void WHITE() {
  for (int i = 0; i < NUM_LEDS; i++) {
    leds[i] = CRGB::White;
  }
  FastLED.show();
  delay(10);
}



void RANDOM_WHITE() {
  int random_1  = random(0, NUM_LEDS);
  int random_2  = random(0, NUM_LEDS);
  int random_3  = random(0, NUM_LEDS);
  int random_4  = random(0, NUM_LEDS);

  leds[random_1]  = CRGB::White;
  leds[random_2]  = CRGB::White;
  leds[random_3]  = CRGB::White;
  leds[random_4]  = CRGB::White;

  //  leds[random3]  = CRGB::Black;
  //  leds[random4]  = CRGB::Black;


  FastLED.show();
  FastLED.delay(150);
  fadeall(200);
}


#define TEMPERATURE_1 Tungsten100W
#define TEMPERATURE_2 OvercastSky
#define DISPLAYTIME 20
void COLOR_TEMPERATURE() {
  static uint8_t starthue = 0;
  fill_rainbow( leds , NUM_LEDS , --starthue, 20);
  FastLED.show();
  FastLED.delay(20);
}


void CONFETTI()
{
  // random colored speckles that blink in and fade smoothly
  fadeToBlackBy( leds, NUM_LEDS, 10);
  int pos = random16(NUM_LEDS);
  leds[pos] += CHSV(random8(64), 200, 255);
  FastLED.show();
  FastLED.delay(15);
}

void PACIFICA_LOOP() {
  EVERY_N_MILLISECONDS( 20) {
    pacifica_loop();
    FastLED.show();
  }
}

CRGBPalette16 pacifica_palette_1 =
{ 0x000507, 0x000409, 0x00030B, 0x00030D, 0x000210, 0x000212, 0x000114, 0x000117,
  0x000019, 0x00001C, 0x000026, 0x000031, 0x00003B, 0x000046, 0x14554B, 0x28AA50
};
CRGBPalette16 pacifica_palette_2 =
{ 0x000507, 0x000409, 0x00030B, 0x00030D, 0x000210, 0x000212, 0x000114, 0x000117,
  0x000019, 0x00001C, 0x000026, 0x000031, 0x00003B, 0x000046, 0x0C5F52, 0x19BE5F
};
CRGBPalette16 pacifica_palette_3 =
{ 0x000208, 0x00030E, 0x000514, 0x00061A, 0x000820, 0x000927, 0x000B2D, 0x000C33,
  0x000E39, 0x001040, 0x001450, 0x001860, 0x001C70, 0x002080, 0x1040BF, 0x2060FF
};
void pacifica_loop()
{
  // Increment the four "color index start" counters, one for each wave layer.
  // Each is incremented at a different speed, and the speeds vary over time.
  static uint16_t sCIStart1, sCIStart2, sCIStart3, sCIStart4;
  static uint32_t sLastms = 0;
  uint32_t ms = GET_MILLIS();
  uint32_t deltams = ms - sLastms;
  sLastms = ms;
  uint16_t speedfactor1 = beatsin16(3, 179, 269);
  uint16_t speedfactor2 = beatsin16(4, 179, 269);
  uint32_t deltams1 = (deltams * speedfactor1) / 256;
  uint32_t deltams2 = (deltams * speedfactor2) / 256;
  uint32_t deltams21 = (deltams1 + deltams2) / 2;
  sCIStart1 += (deltams1 * beatsin88(1011, 10, 13));
  sCIStart2 -= (deltams21 * beatsin88(777, 8, 11));
  sCIStart3 -= (deltams1 * beatsin88(501, 5, 7));
  sCIStart4 -= (deltams2 * beatsin88(257, 4, 6));

  // Clear out the LED array to a dim background blue-green
  fill_solid( leds, NUM_LEDS, CRGB( 2, 6, 10));

  // Render each of four layers, with different scales and speeds, that vary over time
  pacifica_one_layer( pacifica_palette_1, sCIStart1, beatsin16( 3, 11 * 256, 14 * 256), beatsin8( 10, 70, 130), 0 - beat16( 301) );
  pacifica_one_layer( pacifica_palette_2, sCIStart2, beatsin16( 4,  6 * 256,  9 * 256), beatsin8( 17, 40,  80), beat16( 401) );
  pacifica_one_layer( pacifica_palette_3, sCIStart3, 6 * 256, beatsin8( 9, 10, 38), 0 - beat16(503));
  pacifica_one_layer( pacifica_palette_3, sCIStart4, 5 * 256, beatsin8( 8, 10, 28), beat16(601));

  // Add brighter 'whitecaps' where the waves lines up more
  pacifica_add_whitecaps();

  // Deepen the blues and greens a bit
  pacifica_deepen_colors();
}

// Add one layer of waves into the led array
void pacifica_one_layer( CRGBPalette16 & p, uint16_t cistart, uint16_t wavescale, uint8_t bri, uint16_t ioff)
{
  uint16_t ci = cistart;
  uint16_t waveangle = ioff;
  uint16_t wavescale_half = (wavescale / 2) + 20;
  for ( uint16_t i = 0; i < NUM_LEDS; i++) {
    waveangle += 250;
    uint16_t s16 = sin16( waveangle ) + 32768;
    uint16_t cs = scale16( s16 , wavescale_half ) + wavescale_half;
    ci += cs;
    uint16_t sindex16 = sin16( ci) + 32768;
    uint8_t sindex8 = scale16( sindex16, 240);
    CRGB c = ColorFromPalette( p, sindex8, bri, LINEARBLEND);
    leds[i] += c;
  }
}

// Add extra 'white' to areas where the four layers of light have lined up brightly
void pacifica_add_whitecaps()
{
  uint8_t basethreshold = beatsin8( 9, 55, 65);
  uint8_t wave = beat8( 7 );

  for ( uint16_t i = 0; i < NUM_LEDS; i++) {
    uint8_t threshold = scale8( sin8( wave), 20) + basethreshold;
    wave += 7;
    uint8_t l = leds[i].getAverageLight();
    if ( l > threshold) {
      uint8_t overage = l - threshold;
      uint8_t overage2 = qadd8( overage, overage);
      leds[i] += CRGB( overage, overage2, qadd8( overage2, overage2));
    }
  }
}

// Deepen the blues and greens
void pacifica_deepen_colors()
{
  for ( uint16_t i = 0; i < NUM_LEDS; i++) {
    leds[i].blue  = scale8(leds[i].blue,  145);
    leds[i].green = scale8(leds[i].green, 200);
    leds[i] |= CRGB( 2, 5, 7);
  }
}


void CYLON() {
  static uint8_t hue = 0;
  // First slide the led in one direction

  static int licznik = 1;
  static bool LICZNIK = 0;


  if (licznik == 0) {
    LICZNIK = 0;
  }
  if (licznik == NUM_LEDS) {
    LICZNIK = 1;
  }

  if (LICZNIK == 0) {
    licznik++;
  }
  if (LICZNIK == 1) {
    licznik--;
  }

  leds[licznik] = CHSV(hue++, 255, 255);
  FastLED.show();
  fadeall(500);


  /*

    for (int i = 0; i < NUM_LEDS; i++) {
      // Set the i'th led to red
      leds[i] = CHSV(hue++, 255, 255);
      // Show the leds
      FastLED.show();
      // now that we've shown the leds, reset the i'th led to black
      // leds[i] = CRGB::Black;
      fadeall(222);
      //    for (int i = 0; i < NUM_LEDS; i++) {
      //      leds[i].nscale8(250);
      //    }
      // Wait a little bit before we loop around and do it again
      delay(22);
    }


    // Now go in the other direction.
    for (int i = (NUM_LEDS) - 1; i >= 0; i--) {
      // Set the i'th led to red
      leds[i] = CHSV(hue++, 255, 255);
      // Show the leds
      FastLED.show();
      // now that we've shown the leds, reset the i'th led to black
      // leds[i] = CRGB::Black;
      fadeall(222);
      //    for (int i = 0; i < NUM_LEDS; i++) {
      //      leds[i].nscale8(250);
      //    }
      // Wait a little bit before we loop around and do it again
      delay(22);
    }
  */
}



void CYLON2() {
  static uint8_t hue = 0;

  static int licznik = 1;
  static bool LICZNIK = 0;

  if (licznik == 0) {
    LICZNIK = 0;
  }
  if (licznik == NUM_LEDS) {
    LICZNIK = 1;
  }

  if (LICZNIK == 0) {
    licznik++;
  }
  if (LICZNIK == 1) {
    licznik--;
  }

  leds[licznik] =  CHSV(255, 0, 255);
  FastLED.show();
  fadeall(500);
}




void fadeall(int gaszenie) {
  for (int i = 0; i < NUM_LEDS; i++) {
    leds[i].nscale8(gaszenie);
  }
}
Rysiu
Posty: 52
Rejestracja: wt lut 06, 2018 6:57 am

Cześć,
Wgrałem powyższy program i mam mały problem. Po połączeniu z modułem przez wifi zaczyna się resetować. Jakiś pomysł co robię źle?
radzik_r
Posty: 390
Rejestracja: ndz sie 11, 2019 5:32 pm

Rysiu pisze: pt lut 18, 2022 12:01 pm Cześć,
Wgrałem powyższy program i mam mały problem. Po połączeniu z modułem przez wifi zaczyna się resetować. Jakiś pomysł co robię źle?
czyściłeś wemosa?

z jakimi ustawieniami wgrywasz?
Rysiu
Posty: 52
Rejestracja: wt lut 06, 2018 6:57 am

Ustawienia w załączniku. Postaram się wyczyścić i zrobić test jeszcze raz.
Załączniki
Zrzut ekranu 2022-02-18 150758.jpg
Zrzut ekranu 2022-02-18 150758.jpg (23.85 KiB) Przejrzano 1137 razy
radzik_r
Posty: 390
Rejestracja: ndz sie 11, 2019 5:32 pm

Rysiu pisze: pt lut 18, 2022 2:12 pm Ustawienia w załączniku. Postaram się wyczyścić i zrobić test jeszcze raz.
ustaw na Wemos D1 R1
Załączniki
wemosd1.png
wemosd1.png (75.77 KiB) Przejrzano 1132 razy
Awatar użytkownika
shimano73
Posty: 1968
Rejestracja: ndz lut 28, 2016 12:27 pm
Lokalizacja: Orzesze
Kontakt:

Ja bym jeszcze zwiększył ilość flash'a dla OTA, bo jak nie dziś to kiedyś braknie miejsca na soft podczas aktualizacji
W elektronice jak nie wiadomo o co chodzi to zwykle chodzi o zasilanie

Wezmę udział w Supla Offline Party 2024 :)
Rysiu
Posty: 52
Rejestracja: wt lut 06, 2018 6:57 am

Moduł wyczyszczony blankiem. Opcję którą zaznaczyłeś zmieniłem. Ja mam LOLIN(WeMos) D1 R1. Niestety wciąż to samo :( Połączę się z siecią, lecz w momencie przekierowania na stronę logowania następuje reset.

Kod: Zaznacz cały

15:58:08.467 -> *wm:[2] Portal Timeout In 270 seconds
15:58:20.620 -> *wm:[2] <- Request redirected to captive portal 
15:58:22.162 -> *wm:[2] <- Request redirected to captive portal 
15:58:22.208 -> *wm:[2] <- HTTP Root 
15:58:22.208 -> 
15:58:22.208 -> --------------- CUT HERE FOR EXCEPTION DECODER ---------------
15:58:22.208 -> 
15:58:22.208 -> Exception (3):
15:58:22.208 -> epc1=0x4000bf64 epc2=0x00000000 epc3=0x00000000 excvaddr=0x40271391 depc=0x00000000
15:58:22.208 -> 
15:58:22.208 -> >>>stack>>>
15:58:22.208 -> 
15:58:22.208 -> ctx: cont
15:58:22.208 -> sp: 3ffff9c0 end: 3fffffc0 offset: 0190
15:58:22.208 -> 3ffffb50:  3fff51d4 00000c9e 00000000 00000000  
15:58:22.208 -> 3ffffb60:  40271391 00000001 401002bd 00000000  
15:58:22.208 -> 3ffffb70:  00000000 3ffefb68 3ffffbec 4020f333  
15:58:22.208 -> 3ffffb80:  00000000 3fff21bc 3ffffbb0 4021fdf0  
15:58:22.208 -> 3ffffb90:  3ffffbb0 3ffefcb0 3ffefb68 4021fe19  
15:58:22.208 -> 3ffffba0:  3ffefc68 3ffefcb0 3ffefb68 4021428a  
15:58:22.255 -> 3ffffbb0:  2e2e7962 6164656b 09000072 40209b10  
15:58:22.255 -> 3ffffbc0:  00000000 69746365 00000000 00000030  
15:58:22.255 -> 3ffffbd0:  4021107c 00000030 0000001c 00000000  
15:58:22.255 -> 3ffffbe0:  3fff3f0c 3fff3058 00000000 3fff51d4  
15:58:22.255 -> 3ffffbf0:  0c9e0c9f 80000000 00000000 00000000  
15:58:22.255 -> 3ffffc00:  3ffefc68 00000001 3fff1f7c 40223bf8  
15:58:22.255 -> 3ffffc10:  00000001 00000000 00000000 401000e9  
15:58:22.255 -> 3ffffc20:  00000000 00000000 d0609af5 402073ed  
15:58:22.255 -> 3ffffc30:  00000000 3fff3f0c 3fff3ec4 4020a250  
15:58:22.255 -> 3ffffc40:  00000000 00000000 00000000 69746365  
15:58:22.302 -> 3ffffc50:  00000000 3ffefc68 401002bd 00000000  
15:58:22.302 -> 3ffffc60:  0000aab6 00000000 00000000 00000001  
15:58:22.302 -> 3ffffc70:  00000000 00000000 3fff3ec4 00000000  
15:58:22.302 -> 3ffffc80:  3ffefc68 3fff3ee8 3fff3ec4 4020d0ea  
15:58:22.302 -> 3ffffc90:  4022522c 00000000 00001388 40219467  
15:58:22.302 -> 3ffffca0:  00000000 00000000 3fff49a4 00000000  
15:58:22.302 -> 3ffffcb0:  3ffefc68 3ffefc68 3ffefb68 40214d70  
15:58:22.302 -> 3ffffcc0:  3ffefc68 00000001 3ffefb68 402110b7  
15:58:22.302 -> 3ffffcd0:  00000000 00000000 00000001 401001a8  
15:58:22.302 -> 3ffffce0:  000b000f 00000000 3ffefb68 00000000  
15:58:22.302 -> 3ffffcf0:  3ffefc68 00000001 3ffefb68 00000000  
15:58:22.349 -> 3ffffd00:  3ffefc68 00000001 3ffefb68 402150b0  
15:58:22.349 -> 3ffffd10:  00000000 000b000f 00000000 00000000  
15:58:22.349 -> 3ffffd20:  73646e6f 00000000 00000000 000b000f  
15:58:22.349 -> 3ffffd30:  00000000 00000009 3ffefcb0 4021fce4  
15:58:22.349 -> 3ffffd40:  3ffe8c2b 3ffffd70 3ffefcb0 4021fdf0  
15:58:22.349 -> 3ffffd50:  3ffe8678 00000000 3ffefb68 3ffe8627  
15:58:22.349 -> 3ffffd60:  3ffe8678 00000000 3ffefb68 4020bbbd  
15:58:22.349 -> 3ffffd70:  00000000 6164656b 00000000 3ffe8934  
15:58:22.349 -> 3ffffd80:  3ffe8de4 3ffe8939 3ffe8941 00000001  
15:58:22.349 -> 3ffffd90:  4021d890 3ffe8ba7 3fff1254 4021d89c  
15:58:22.395 -> 3ffffda0:  00000251 00000251 3ffe8704 40100883  
15:58:22.395 -> 3ffffdb0:  3ffe958c 0000002b 3fff1254 00000001  
15:58:22.395 -> 3ffffdc0:  3ffe958c 00000020 3fff2ec4 40225204  
15:58:22.395 -> 3ffffdd0:  00000000 00000000 00000000 00000001  
15:58:22.395 -> 3ffffde0:  00000001 3ffe8c15 40225204 00000000  
15:58:22.395 -> 3ffffdf0:  00000000 00000000 00000001 00000001  
15:58:22.395 -> 3ffffe00:  3ffefee2 40225204 00000000 00000000  
15:58:22.395 -> 3ffffe10:  00000000 00000001 00000001 3ffe8bf7  
15:58:22.395 -> 3ffffe20:  40225204 3ffe8cd4 3ffe8bdf 3fff2f74  
15:58:22.395 -> 3ffffe30:  00000051 00000001 3ffe8bc3 40225204  
15:58:22.440 -> 3ffffe40:  3ffe98ff 3ffe8bd9 3fff2f1c 00000051  
15:58:22.440 -> 3ffffe50:  00000001 3ffe8bc3 40225204 3ffe9737  
15:58:22.440 -> 3ffffe60:  3ffe8bcc 3fff2ec4 00000051 00000001  
15:58:22.440 -> 3ffffe70:  3ffe8bc3 3fff3e7c 3fff3e98 3fff3e98  
15:58:22.440 -> 3ffffe80:  3ffefebc 00000010 3fff02e8 4021a110  
15:58:22.440 -> 3ffffe90:  3fff3e98 4020c2e9 00000020 00000000  
15:58:22.440 -> 3ffffea0:  3fff2da4 3ffe85d6 3fff02e8 00000000  
15:58:22.440 -> 3ffffeb0:  3fff2da4 3fff2dac 3fff02e8 4020c383  
15:58:22.440 -> 3ffffec0:  00000000 0000000a 00000000 4021eb24  
15:58:22.440 -> 3ffffed0:  feefeffe feefeffe feefeffe feefeffe  
15:58:22.487 -> 3ffffee0:  feefeffe feefeffe feefeffe feefeffe  
15:58:22.487 -> 3ffffef0:  feefeffe feefeffe feefeffe feefeffe  
15:58:22.487 -> 3fffff00:  feefeffe feefeffe feefeffe feefeffe  
15:58:22.487 -> 3fffff10:  feefeffe feefeffe feefeffe feefeffe  
15:58:22.487 -> 3fffff20:  feefeffe feefeffe feefeffe feefeffe  
15:58:22.487 -> 3fffff30:  feefeffe feefeffe feefeffe feefeffe  
15:58:22.487 -> 3fffff40:  feefeffe feefeffe feefeffe feefeffe  
15:58:22.487 -> 3fffff50:  feefeffe feefeffe feefeffe feefeffe  
15:58:22.487 -> 3fffff60:  feefeffe feefeffe feefeffe feefeffe  
15:58:22.487 -> 3fffff70:  feefeffe feefeffe feefeffe feefeffe  
15:58:22.534 -> 3fffff80:  3ffe85d6 feefeffe feefeffe feefeffe  
15:58:22.534 -> 3fffff90:  feefeffe feefeffe feefeffe 3fff13e0  
15:58:22.534 -> 3fffffa0:  3fffdad0 00000000 3fff13cc 40221108  
15:58:22.534 -> 3fffffb0:  feefeffe feefeffe 3ffe8700 40100d29  
15:58:22.534 -> <<<stack<<<
15:58:22.534 -> 
15:58:22.534 -> --------------- CUT HERE FOR EXCEPTION DECODER ---------------
15:58:22.534 -> 
15:58:22.534 ->  ets Jan  8 2013,rst cause:2, boot mode:(3,6)
15:58:22.534 -> 
15:58:22.579 -> load 0x4010f000, len 3460, room 16 
15:58:22.579 -> tail 4
15:58:22.579 -> chksum 0xcc
15:58:22.579 -> load 0x3fff20b8, len 40, room 4 
15:58:22.579 -> tail 4
15:58:22.579 -> chksum 0xc9
15:58:22.579 -> csum 0xc9
15:58:22.579 -> v00084c80
15:58:22.579 -> ~ld
15:58:22.626 ->  
15:58:22.626 ->  
15:58:22.626 -> GUID : 92f38208063f41a9aec4e9eb3e466bd9
15:58:22.626 -> AUTHKEY : f0e22add0dcc444398386ccc1407ffe5
15:58:22.626 -> mounted file system
15:58:22.673 -> Supla - starting initialization
15:58:22.673 -> Storage initialization
15:58:22.673 -> readStorage: 8; Read: [53 55 50 4C 41 1 0 0 ]
15:58:22.673 -> Storage: Number of sections 0
15:58:22.673 -> Validating storage state section with current device configuration
15:58:22.673 -> Element state section size doesn't match current device configuration
15:58:22.673 ->  **** Digital write[2], pin: 201; value: 0
15:58:22.673 ->  **** Digital write[3], pin: 202; value: 0
15:58:22.673 ->  **** Digital write[4], pin: 203; value: 0
15:58:22.720 ->  **** Digital write[5], pin: 204; value: 0
15:58:22.720 ->  **** Digital write[6], pin: 205; value: 0
15:58:22.720 ->  **** Digital write[7], pin: 206; value: 0
15:58:22.720 -> Initializing network layer
15:58:22.720 -> WiFi: establishing connection with SSID: ""
15:58:22.720 -> Using Supla protocol version 16
15:58:22.720 -> Current status: [5] SuplaDevice initialized
15:58:22.720 -> *wm:[2] Added Parameter: server
15:58:22.720 -> *wm:[2] Added Parameter: email
15:58:22.720 -> *wm:[2] Added Parameter: name
15:58:22.720 -> *wm:[2] Added Parameter:
15:58:22.720 -> *wm:[2] Added Parameter:
15:58:22.720 -> *wm:[2] Added Parameter:
15:58:22.720 -> *wm:[2] Starting Config Portal 
15:58:22.720 -> *wm:[2] Disabling STA 
15:58:22.720 -> *wm:[2] Enabling AP 
15:58:22.766 -> *wm:[1] StartAP with SSID:  SuplaPixelControlerWS2815LED
15:58:23.234 -> *wm:[2] AP has anonymous access! 
15:58:23.749 -> *wm:[1] AP IP address: 192.168.4.1
15:58:23.749 -> *wm:[1] Starting Web Portal 
15:58:23.749 -> *wm:[2] HTTP server started 
15:58:23.749 -> *wm:[2] Config Portal Running, blocking, waiting for clients... 
15:58:23.749 -> *wm:[2] Portal Timeout In 300 seconds
15:58:41.743 -> *wm:[2] <- Request redirected to captive portal 
15:58:46.603 -> *wm:[2] <- Request redirected to captive portal 
15:58:46.650 -> *wm:[2] <- HTTP Root 
15:58:46.650 -> 
15:58:46.650 -> --------------- CUT HERE FOR EXCEPTION DECODER ---------------
15:58:46.650 -> 
15:58:46.650 -> Exception (3):
15:58:46.650 -> epc1=0x4000bf64 epc2=0x00000000 epc3=0x00000000 excvaddr=0x40271391 depc=0x00000000
15:58:46.650 -> 
15:58:46.650 -> >>>stack>>>
15:58:46.650 -> 
15:58:46.650 -> ctx: cont
15:58:46.650 -> sp: 3ffff9c0 end: 3fffffc0 offset: 0190
15:58:46.650 -> 3ffffb50:  3fff4ff4 00000c9e 00000000 00000000  
15:58:46.650 -> 3ffffb60:  40271391 00000001 401002bd 00000000  
15:58:46.650 -> 3ffffb70:  00000000 3ffefb68 3ffffbec 4020f333  
15:58:46.650 -> 3ffffb80:  00000000 3fff21bc 3ffffbb0 4021fdf0  
15:58:46.650 -> 3ffffb90:  3ffffbb0 3ffefcb0 3ffefb68 4021fe19  
15:58:46.697 -> 3ffffba0:  3ffefc68 3ffefcb0 3ffefb68 4021428a  
15:58:46.697 -> 3ffffbb0:  2e2e7962 6164656b 09000072 40209b10  
15:58:46.697 -> 3ffffbc0:  00000000 69746365 00000000 ffffffff  
15:58:46.697 -> 3ffffbd0:  40214d6b 3fff3ec4 000001f4 00000000  
15:58:46.697 -> 3ffffbe0:  3fff3f0c 3fff3058 00000000 3fff4ff4  
15:58:46.697 -> 3ffffbf0:  0c9e0c9f 80000000 00000000 00000000  
15:58:46.697 -> 3ffffc00:  3ffefc68 00000001 3fff1f7c 40223bf8  
15:58:46.697 -> 3ffffc10:  40211131 00000000 00000000 401000e9  
15:58:46.697 -> 3ffffc20:  00000000 00000000 00007530 402073ed  
15:58:46.697 -> 3ffffc30:  00000000 3fff3f0c 3fff3ec4 4020a250  
15:58:46.697 -> 3ffffc40:  00000000 00000000 00000000 69746365  
15:58:46.742 -> 3ffffc50:  00000000 3ffefc68 401002bd 00000000  
15:58:46.742 -> 3ffffc60:  00005dff 00000000 00000000 00000001  
15:58:46.742 -> 3ffffc70:  00000000 00000000 3fff3ec4 00000000  
15:58:46.742 -> 3ffffc80:  3ffefc68 3fff3ee8 3fff3ec4 4020d0ea  
15:58:46.742 -> 3ffffc90:  4022522c 00000000 00001388 40219467  
15:58:46.742 -> 3ffffca0:  00000000 00000000 3fff4e7c 00000000  
15:58:46.742 -> 3ffffcb0:  3ffefc68 3ffefc68 3ffefb68 40214d70  
15:58:46.742 -> 3ffffcc0:  3ffefc68 00000001 3ffefb68 402110b7  
15:58:46.742 -> 3ffffcd0:  00000000 00000000 00000001 401001a8  
15:58:46.742 -> 3ffffce0:  3ffefc68 00000020 3ffefb68 00000000  
15:58:46.789 -> 3ffffcf0:  3ffefc68 00000001 3ffefb68 00000000  
15:58:46.789 -> 3ffffd00:  3ffefc68 00000001 3ffefb68 402150b0  
15:58:46.789 -> 3ffffd10:  00000000 000b000f 00000000 00000000  
15:58:46.789 -> 3ffffd20:  73646e6f 00000000 00000000 000b000f  
15:58:46.789 -> 3ffffd30:  00000000 00000009 3ffefcb0 4021fce4  
15:58:46.789 -> 3ffffd40:  3ffe8c2b 3ffffd70 3ffefcb0 4021fdf0  
15:58:46.789 -> 3ffffd50:  3ffe8678 00000000 3ffefb68 3ffe8627  
15:58:46.789 -> 3ffffd60:  3ffe8678 00000000 3ffefb68 4020bbbd  
15:58:46.789 -> 3ffffd70:  00000000 6164656b 00000000 3ffe8934  
15:58:46.789 -> 3ffffd80:  3ffe8de4 3ffe8939 3ffe8941 00000001  
15:58:46.836 -> 3ffffd90:  4021d890 3ffe8ba7 3fff1254 4021d89c  
15:58:46.836 -> 3ffffda0:  00000251 00000251 3ffe8704 40100883  
15:58:46.836 -> 3ffffdb0:  3ffe958c 0000002b 3fff1254 00000001  
15:58:46.836 -> 3ffffdc0:  3ffe958c 00000020 3fff2ec4 40225204  
15:58:46.836 -> 3ffffdd0:  00000000 00000000 00000000 00000001  
15:58:46.836 -> 3ffffde0:  00000001 3ffe8c15 40225204 00000000  
15:58:46.836 -> 3ffffdf0:  00000000 00000000 00000001 00000001  
15:58:46.836 -> 3ffffe00:  3ffefee2 40225204 00000000 00000000  
15:58:46.836 -> 3ffffe10:  00000000 00000001 00000001 3ffe8bf7  
15:58:46.836 -> 3ffffe20:  40225204 3ffe8cd4 3ffe8bdf 3fff2f74  
15:58:46.836 -> 3ffffe30:  00000051 00000001 3ffe8bc3 40225204  
15:58:46.882 -> 3ffffe40:  3ffe98ff 3ffe8bd9 3fff2f1c 00000051  
15:58:46.882 -> 3ffffe50:  00000001 3ffe8bc3 40225204 3ffe9737  
15:58:46.882 -> 3ffffe60:  3ffe8bcc 3fff2ec4 00000051 00000001  
15:58:46.882 -> 3ffffe70:  3ffe8bc3 3fff3e7c 3fff3e98 3fff3e98  
15:58:46.882 -> 3ffffe80:  3ffefebc 00000010 3fff02e8 4021a110  
15:58:46.882 -> 3ffffe90:  3fff3e98 4020c2e9 00000020 00000000  
15:58:46.882 -> 3ffffea0:  3fff2da4 3ffe85d6 3fff02e8 00000000  
15:58:46.882 -> 3ffffeb0:  3fff2da4 3fff2dac 3fff02e8 4020c383  
15:58:46.882 -> 3ffffec0:  00000000 0000000a 00000000 4021eb24  
15:58:46.882 -> 3ffffed0:  feefeffe feefeffe feefeffe feefeffe  
15:58:46.929 -> 3ffffee0:  feefeffe feefeffe feefeffe feefeffe  
15:58:46.929 -> 3ffffef0:  feefeffe feefeffe feefeffe feefeffe  
15:58:46.929 -> 3fffff00:  feefeffe feefeffe feefeffe feefeffe  
15:58:46.929 -> 3fffff10:  feefeffe feefeffe feefeffe feefeffe  
15:58:46.929 -> 3fffff20:  feefeffe feefeffe feefeffe feefeffe  
15:58:46.929 -> 3fffff30:  feefeffe feefeffe feefeffe feefeffe  
15:58:46.929 -> 3fffff40:  feefeffe feefeffe feefeffe feefeffe  
15:58:46.929 -> 3fffff50:  feefeffe feefeffe feefeffe feefeffe  
15:58:46.929 -> 3fffff60:  feefeffe feefeffe feefeffe feefeffe  
15:58:46.929 -> 3fffff70:  feefeffe feefeffe feefeffe feefeffe  
15:58:46.977 -> 3fffff80:  3ffe85d6 feefeffe feefeffe feefeffe  
15:58:46.977 -> 3fffff90:  feefeffe feefeffe feefeffe 3fff13e0  
15:58:46.977 -> 3fffffa0:  3fffdad0 00000000 3fff13cc 40221108  
15:58:46.977 -> 3fffffb0:  feefeffe feefeffe 3ffe8700 40100d29  
15:58:46.977 -> <<<stack<<<
15:58:46.977 -> 
15:58:46.977 -> --------------- CUT HERE FOR EXCEPTION DECODER ---------------
15:58:46.977 -> 
15:58:46.977 ->  ets Jan  8 2013,rst cause:2, boot mode:(3,6)
15:58:46.977 -> 
15:58:47.023 -> load 0x4010f000, len 3460, room 16 
15:58:47.023 -> tail 4
15:58:47.023 -> chksum 0xcc
15:58:47.023 -> load 0x3fff20b8, len 40, room 4 
15:58:47.023 -> tail 4
15:58:47.023 -> chksum 0xc9
15:58:47.023 -> csum 0xc9
15:58:47.023 -> v00084c80
15:58:47.023 -> ~ld
15:58:47.070 ->  
15:58:47.070 ->  
15:58:47.070 -> GUID : 92f38208063f41a9aec4e9eb3e466bd9
15:58:47.070 -> AUTHKEY : f0e22add0dcc444398386ccc1407ffe5
15:58:47.070 -> mounted file system
15:58:47.070 -> Supla - starting initialization
15:58:47.115 -> Storage initialization
15:58:47.115 -> readStorage: 8; Read: [53 55 50 4C 41 1 0 0 ]
15:58:47.115 -> Storage: Number of sections 0
15:58:47.115 -> Validating storage state section with current device configuration
15:58:47.115 -> Element state section size doesn't match current device configuration
15:58:47.115 ->  **** Digital write[2], pin: 201; value: 0
15:58:47.115 ->  **** Digital write[3], pin: 202; value: 0
15:58:47.115 ->  **** Digital write[4], pin: 203; value: 0
15:58:47.115 ->  **** Digital write[5], pin: 204; value: 0
15:58:47.162 ->  **** Digital write[6], pin: 205; value: 0
15:58:47.162 ->  **** Digital write[7], pin: 206; value: 0
15:58:47.162 -> Initializing network layer
15:58:47.162 -> WiFi: establishing connection with SSID: ""
15:58:47.162 -> Using Supla protocol version 16
15:58:47.162 -> Current status: [5] SuplaDevice initialized
15:58:47.162 -> *wm:[2] Added Parameter: server
15:58:47.162 -> *wm:[2] Added Parameter: email
15:58:47.162 -> *wm:[2] Added Parameter: name
15:58:47.162 -> *wm:[2] Added Parameter:
15:58:47.162 -> *wm:[2] Added Parameter:
15:58:47.162 -> *wm:[2] Added Parameter:
15:58:47.162 -> *wm:[2] Starting Config Portal 
15:58:47.162 -> *wm:[2] Disabling STA 
15:58:47.162 -> *wm:[2] Enabling AP 
15:58:47.209 -> *wm:[1] StartAP with SSID:  SuplaPixelControlerWS2815LED
15:58:47.677 -> *wm:[2] AP has anonymous access! 
15:58:48.189 -> *wm:[1] AP IP address: 192.168.4.1
15:58:48.189 -> *wm:[1] Starting Web Portal 
15:58:48.189 -> *wm:[2] HTTP server started 
15:58:48.189 -> *wm:[2] Config Portal Running, blocking, waiting for clients... 
15:58:48.189 -> *wm:[2] Portal Timeout In 300 seconds

Awatar użytkownika
shimano73
Posty: 1968
Rejestracja: ndz lut 28, 2016 12:27 pm
Lokalizacja: Orzesze
Kontakt:

Zmień ustawienia Narzędzia -> Erase Flash -> All Flash Contens - wówczas podczas wgrywania będzie czyścił całego flash'a
Pojawił się jakiś wyjątek "Exception (3)" albo to coś namieszałeś w programie i czyta adres który nie istnieje albo źle wyczyszczony flash
W elektronice jak nie wiadomo o co chodzi to zwykle chodzi o zasilanie

Wezmę udział w Supla Offline Party 2024 :)
elmaya
Posty: 1482
Rejestracja: śr cze 27, 2018 5:48 pm
Lokalizacja: El Saucejo - Sevilla

compile with ESP Boards Manager 2.7.4
Rysiu
Posty: 52
Rejestracja: wt lut 06, 2018 6:57 am

Wielkie dzięki Panowie!
Nie wiem która opcja pomogła, wgrałem starszy menadżer płytek oraz zaznaczyłem opcję którą wskazał shimano73 i ruszyło.
ODPOWIEDZ

Wróć do „Projekty użytkowników”