Community Forum
    • Blog
    • Categories
    • Recent
    • Tags
    • Popular
    • Users
    • Groups
    • Register
    • Login

    Remora V1.3 NodeMCU Nouvelle Version Logicielle + API Locale

    Scheduled Pinned Locked Moved Remora
    remoralocaleapinodemcuesp8266
    119 Posts 17 Posters 112.6k Views
    Loading More Posts
    • Oldest to Newest
    • Newest to Oldest
    • Most Votes
    Reply
    • Reply as topic
    Log in to reply
    This topic has been deleted. Only users with topic management privileges can see it.
    • S Offline
      seb
      last edited by

      Re
      J'ai teste avec 3 cables differents
      Cable de scanner portable, cable de telephonex2 sony
      Je veux bien acheter un autre cable que me conseilles tu?
      Merci
      Seb

      1 Reply Last reply Reply Quote
      • S Offline
        seb
        last edited by seb

        Salut,

        pour rebondir, après diverses recherches dont celle-ci : http://hpclab.blogspot.mx/2015/06/esp8266-arduino-ide-on-mac-os-x.html, iol semble que mac os n'aime pas
        tout en suivant le auto, je me retrouve avec un souci de port série non reconnu car le port défini sous arduino est USBtoUART, mais j'ai a nouveau un message d'erreur, la il semble que cela soit une simple config au niveau de esptool.py ::: fichier /Users/$USER/Library/Arduino15/packages/esp8266/hardware/esp8266/1.6.4-673-g8cd3697/platform.txt modifie
        Arduino/esptool-master/esptool.py", line 22, in <module> import serial
        ImportError: No module named serial

        j'avance doucement
        En fait je n'ai plus de windows, je ne peux faire l'installe avec, j'utilise windows sous mac, c'est pourquoi j'ai le meme souci en utilisant arduino sous windows.

        Merci de votre aide
        Seb

        Je confirme linux meme pb
        La je sache

        M F 2 Replies Last reply Reply Quote
        • O Offline
          omyxcol
          last edited by

          Bonsoir,
          Suite aux resets du node mcu lors de l'activation du chauffeau en HC, je pensais à une perturbation du wifi ou autre problème de CEM de la puce. Et cela semble se confirmer car depuis la mise en place du capot en pla de 2mm d épaisseur imprimé en 3d plus de reset. Avant la carte était à nu dans le tableau électrique afin de visualiser les leds et l'écran.

          1 Reply Last reply Reply Quote
          • M Offline
            manu12 @seb
            last edited by

            @seb Perso, sous OSX 10.11.2, pas eu de soucis, j'ai pu téléviser sans soucis. J'ai suivi un conseil de Charles à propos des drivers, par contre, il y a un topic où le cas Arduino est évoqué, et il y a un lien vers des drivers spécifiques OSX...
            Les as-tu essayé ?

            @+

            1 Reply Last reply Reply Quote
            • F Offline
              francky50 @seb
              last edited by

              @seb
              salut, j'ai aussi galéré au début depuis mon mac et j'ai trouvé ce driver CP210x Macintosh OS X VCP Driver v4 et téléchargé le fichier SiLabsUSBDriverDisk.dmg que j'ai installé et depuis çà fonctionne bien, l'adruino 1.6.5 voit bien mon port série et mon nodeMCU. Je suis aussi en OSX 10.11.2.
              J'ai eu aussi un problème avec un cable USB qui ne fonctionnait pas (il devait juste servir pour recharger un téléphone) mais j'ai pris celui d'un téléphone Samsung S4 mini et avec lui çà fonctionne bien.

              1 Reply Last reply Reply Quote
              • CharlesC Offline
                Charles
                last edited by

                @Seb,
                tu as peut être un pb avec ton NodeMCU, ça arrive, si tu veux tu peux me le renvoyer, je peux essayer d'y regarder ?

                1 Reply Last reply Reply Quote
                • S Offline
                  seb
                  last edited by

                  ok on fait ça car meme avec l'idée de manu12 pas moyen
                  Tu me confirmes ton adresse
                  Merci BEAUCOUP
                  Seb

                  1 Reply Last reply Reply Quote
                  • Dany21000D Offline
                    Dany21000
                    last edited by

                    Il y a une évolution que j'essaye d'apporter à remora.
                    Je souhaite que la remora se reconnecte automatiquement quand le reseau wifi n'est pas disponible, reboot du point d'accès, demarrage du remora avant le point d'accès, etc ...

                    Dans la boucle de loop, je rajoute ceci qui fonctionne :

                    	// Si perte de la connection au reseau wifi, redemarrage automatique
                    	if (WiFi.status() != WL_CONNECTED) {
                    		Serial.println("Perte de la connection au reseau Wifi");
                    		Serial.println("Redemarrage automatique");
                    		ESP.wdtDisable();
                    		ESP.restart();
                          }
                    

                    Parce que je voulais aussi essayer de ne pas rebooter la remora mais mon code ici ne fonctionne pas ... :

                    	IPAddress ip(192,168,50,251);
                        IPAddress gateway(192,168,50,254);
                        IPAddress subnet(255,255,255,0);
                        WiFi.config(ip, gateway, subnet);	
                    	WiFi.begin(DEFAULT_WIFI_SSID, DEFAULT_WIFI_PASS);
                    	Serial.print("Reconnexion au reseau Wifi en cours");
                    	while (WiFi.status() != WL_CONNECTED) {		// Attente de la connexion au reseau Wifi, redemarrage automatique
                    		delay(500);
                    		Serial.print(".");			
                    	}
                    

                    Note, je test en redémarrant le point d'accès logicielement.

                    1 Reply Last reply Reply Quote
                    • CharlesC Offline
                      Charles
                      last edited by Charles

                      @Dany21000
                      C'est curieux, j'ai 5 NodeMCU sur un autre projet et je ne rencontre pas ce soucis, les reconnexion aux WiFi se font toutes seules, je vais copier/coller le code dans Remora et WifInfo prochainement mais voici le code que j'apelle une seule fois dans le setup()
                      Ah oui, pour info Arduino-ESP8266 version git (toujours) plus IDE 1.6.7

                      /* ======================================================================
                      Function: WifiHandleConn
                      Purpose : Handle Wifi connection / reconnection and OTA updates
                      Input   : setup true if we're called 1st Time from setup
                      Output  : state of the wifi status
                      Comments: -
                      ====================================================================== */
                      int WifiHandleConn(boolean setup = false) 
                      {
                        int ret = WiFi.status();
                      
                        if (setup) {
                          WiFi.mode(WIFI_AP_STA);
                      
                          DebuglnF("========== SDK Saved parameters Start"); 
                          WiFi.printDiag(DEBUG_SERIAL);
                          DebuglnF("========== SDK Saved parameters End"); 
                          Debugflush();
                      
                          // no correct SSID
                          if (!*config.ssid) {
                            DebugF("no Wifi SSID in config, set to AP Only!"); 
                            WiFi.mode(WIFI_AP);
                      
                          } else {
                            DebugF("Connecting to: "); 
                            Debug(config.ssid);
                            Debugflush();
                      
                            // Do wa have a PSK ?
                            if (*config.psk) {
                              // protected network
                              Debug(F(" with key '"));
                              Debug(config.psk);
                              Debug(F("'..."));
                              Debugflush();
                              WiFi.begin(config.ssid, config.psk);
                            } else {
                              // Open network
                              Debug(F("unsecure AP"));
                              Debugflush();
                              WiFi.begin(config.ssid);
                            }
                      
                            uint8_t timeout = 50; // 50 * 200 ms = 10 sec time out
                            while ( ((ret = WiFi.status()) != WL_CONNECTED) && timeout )
                            {
                              // Orange LED
                              LedRGBON(COLOR_ORANGE);
                              delay(50);
                              LedRGBOFF();
                              delay(150);
                              --timeout;
                            }
                          }
                      
                          // connected ? default to disable AP, client mode only
                          if (ret == WL_CONNECTED)
                          {
                            DebuglnF("connected!");
                            DebugF("IP address   : "); Debugln(WiFi.localIP());
                            DebugF("MAC address  : "); Debugln(WiFi.macAddress());
                      
                          // not connected ? start AP
                          } else {
                            DebuglnF("Wifi client unable to connect!");
                          }
                      
                          // connected and not AP defined in config, remove AP
                          if ( ret == WL_CONNECTED && !(config.config & CFG_AP) ) {
                            WiFi.mode(WIFI_STA);
                          } else {
                            // Need Access point configuration 
                            // SSID = hostname
                            DebugF("Starting AP  : ");
                            Debug(config.ap_ssid);
                            Debugflush();
                      
                            // protected network
                            if (*config.ap_psk) {
                              DebugF(" with key '");
                              Debug(config.ap_psk);
                              DebugF("'");
                              WiFi.softAP(config.ap_ssid, config.ap_psk);
                            // Open network
                            } else {
                              DebugF(" with no password");
                              WiFi.softAP(config.ap_ssid);
                            }
                      
                            DebugF("\r\nIP address   : "); Debugln(WiFi.softAPIP());
                            DebugF("MAC address  : "); Debugln(WiFi.softAPmacAddress());
                          } 
                      
                          // Set OTA parameters
                          ArduinoOTA.setPort(config.ota_port);
                          ArduinoOTA.setHostname(config.host);
                          ArduinoOTA.setPassword(config.ota_auth);
                          ArduinoOTA.begin();
                      
                      
                          WiFiMode_t con_type = WiFi.getMode();
                      
                          // just in case your sketch sucks, keep update OTA Available
                          // Trust me, when coding and testing it happens, this could save
                          // the need to connect FTDI to reflash
                          // Usefull just after 1st connexion when called from setup() before
                          // launching potentially buggy main()
                          for (uint8_t i=0; i<= 10; i++) {
                            if (con_type == WIFI_STA) {
                              LedRGBON(COLOR_GREEN);
                            } else if (con_type == WIFI_AP_STA) {
                              LedRGBON(COLOR_CYAN);
                            } else if (con_type == WIFI_AP) {
                              LedRGBON(COLOR_PURPLE);
                            } else {
                              LedRGBON(COLOR_RED);
                            }
                      
                            delay(100);
                            LedRGBOFF();
                            delay(200);
                            ArduinoOTA.handle();
                          }
                      
                          // Wifi is activated
                          wifi_state = true;
                      
                        } // if setup
                      
                        return WiFi.status();
                      }
                      
                      
                      1 Reply Last reply Reply Quote
                      • Dany21000D Offline
                        Dany21000
                        last edited by Dany21000

                        Merci Charles de ta réponse.
                        Je dispose de 3 autres nodemcu (pas de lua mais du c) que j'exploite comme sondes à base de DHT22. Pour le moment, ce projet de sonde est en standby car j'attends les DHT22.

                        C'est en travaillant sur ce projet, qui sera partagé, que j'ai été confronté à ce problème de non-reconnexion au réseau wifi.
                        Je me suis basé sur un mix de code du remora et d'un exemple de lecture du DHT22 pour réaliser mon système.

                        Et du coup, au départ, je pensais que c'était mon code des sondes qui n'était pas bon.
                        Alors j'ai flashé mes 3 nodemcu avec le code remora 1.3.1.
                        Chacun avec une IP Fixe.
                        Le PC en client DHCP est connecté en filaire sur un commutateur lui même relié au routeur, qui fait aussi point d'accès wifi.

                        Tests effectués :
                        1 - lancer un ping sur les 3 nodemcu
                        2 - renommer le nom du réseau Wifi...
                        3 - les nodemcu ne pingent plus, tout va bien.
                        4 - apres quelques minutes, des réseaux Wifi Remora220, 221 et 222 (hostname = 4eme octet de l'IP fixe) apparaissent
                        5 - 5 minutes apres, je remet le nom initial du réseau Wifi
                        6 - ... rien ne se passe, les remora restent en mode AP autonome
                        7 - inutile, mais je redémarra le routeur/ap wifi ... idem, rien ne se passe
                        8 - redemarrage d'une des remora (la 220) ... et elle se reconnecte bien et reping bien
                        9 - je redemarre le routeur, et pendant qu'il redémarrage, un nouveau réseau Wifi apparait Remora220
                        10 - malgrès quelques minutes après le routeur du réseau Wifi du routeur ... retour au point N°6

                        Donc j'en au conclus qu'une fois basculé en mode softAP... ils y restent.
                        D'ailleurs pendant ces tests, ma vraie remora elle est aussi revenue en mode softAP et j'ai été contraint de la redémarrer manuellement aussi.

                        Voici pourquoi j'ai effectué les modifications que je vous présente ci-dessous :
                        **
                        Fonction WifiHandleConn : **

                        int WifiHandleConn(boolean setup = false) 
                        {
                          int ret = WiFi.status();
                          uint8_t timeout ;
                        
                          if (setup) {
                        
                            Serial.print(F("========== SDK Saved parameters Start")); 
                            WiFi.printDiag(Serial);
                            Serial.println(F("========== SDK Saved parameters End")); 
                        	
                        
                        	///////////////////////// AJOUT DANY
                        	IPAddress ip(192,168,50,251);
                        	IPAddress gateway(192,168,50,254);
                        	IPAddress subnet(255,255,255,0);
                        	WiFi.config(ip, gateway, subnet);  	
                        	///////////////////////// AJOUT DANY
                        	
                        
                            #if defined (DEFAULT_WIFI_SSID) && defined (DEFAULT_WIFI_PASS)
                              Serial.print(F("Connection au Wifi : ")); 
                              Serial.print(DEFAULT_WIFI_SSID); 
                              Serial.print(F(" avec la clé '"));
                              Serial.print(DEFAULT_WIFI_PASS);
                              Serial.print(F("'..."));
                              Serial.flush();
                              WiFi.begin(DEFAULT_WIFI_SSID, DEFAULT_WIFI_PASS);
                            #else
                              Serial.print(F("Connection Wifi avec les parametres sauvegardes ")); 
                            #endif
                        
                            timeout = 25; // 25 * 200 ms = 5 sec time out
                        
                            // 200 ms loop
                            while ( ((ret = WiFi.status()) != WL_CONNECTED) && timeout )
                            {
                              // Orange LED
                              LedRGBON(COLOR_ORANGE);
                              delay(50);
                              LedRGBOFF();
                              delay(150);
                              --timeout;
                            }
                        
                            // connected ? disable AP, client mode only
                            if (ret == WL_CONNECTED)
                            {
                              Serial.println(F("connecte!"));
                              WiFi.mode(WIFI_STA);
                        
                              Serial.print(F("IP address   : ")); Serial.println(WiFi.localIP());
                              Serial.print(F("MAC address  : ")); Serial.println(WiFi.macAddress());
                            
                            // not connected ? start AP
                            } else {
                        
                        
                        
                        	 ///////////////////////// AJOUT DANY	
                              Serial.println("");
                        	  Serial.println("Connexion Wifi impossible, Redemarrage automatque");
                        	  ESP.wdtDisable();
                        	  ESP.restart();
                        	///////////////////////// AJOUT DANY
                        	 
                        	///////////////////////// SUPPRESSION DANY	  
                        	/*
                              char ap_ssid[32];
                              Serial.print(F("Erreur, passage en point d'acces "));
                              Serial.println(DEFAULT_HOSTNAME);
                        
                              // protected network
                              Serial.print(F(" avec la clé '"));
                              Serial.print(DEFAULT_WIFI_AP_PASS);
                              Serial.println("'");
                              Serial.flush();
                              WiFi.softAP(DEFAULT_HOSTNAME, DEFAULT_WIFI_AP_PASS);
                              WiFi.mode(WIFI_AP_STA);
                        
                              Serial.print(F("IP address   : ")); Serial.println(WiFi.softAPIP());
                              Serial.print(F("MAC address  : ")); Serial.println(WiFi.softAPmacAddress());
                        	*/
                        	///////////////////////// SUPPRESSION DANY
                        
                        
                        
                            }
                        
                            // Set OTA parameters
                            ArduinoOTA.setPort(DEFAULT_OTA_PORT);
                            ArduinoOTA.setHostname(DEFAULT_HOSTNAME);
                            ArduinoOTA.setPassword(DEFAULT_OTA_PASS);
                            ArduinoOTA.begin();
                        
                            // just in case your sketch sucks, keep update OTA Available
                            // Trust me, when coding and testing it happens, this could save
                            // the need to connect FTDI to reflash
                            // Usefull just after 1st connexion when called from setup() before
                            // launching potentially buggy main()
                            for (uint8_t i=0; i<= 10; i++) {
                              LedRGBON(COLOR_MAGENTA);
                              delay(100);
                              LedRGBOFF();
                              delay(200);
                              ArduinoOTA.handle();
                            }
                        
                          } // if setup
                        
                          return WiFi.status();
                        }
                        

                        Fonction loop

                        /* ======================================================================
                        Function: loop
                        Purpose : boucle principale du programme
                        Input   : -
                        Output  : -
                        Comments: -
                        ====================================================================== */
                        void loop()
                        {
                          static bool refreshDisplay = false;
                          static bool lastcloudstate;
                          static unsigned long previousMillis = 0;  // last time update
                          unsigned long currentMillis = millis();
                          bool currentcloudstate ;
                        
                          // our own setup
                          if (first_setup) {
                            mysetup();
                            first_setup = false;
                          }
                        
                          // Gérer notre compteur de secondes
                          if ( millis()-previousMillis > 1000) {
                            // Ceci arrive toute les secondes écoulées
                            previousMillis = currentMillis;
                            uptime++;
                            refreshDisplay = true ;
                          }
                        
                          #ifdef MOD_TELEINFO
                            // Vérification de la reception d'une 1ere trame téléinfo
                            tinfo_loop();
                            _yield();
                          #endif
                        
                          #ifdef MOD_RF69
                            // Vérification de la reception d'une trame RF
                            if (status & STATUS_RFM)
                              rfm_loop();
                              _yield();
                          #endif
                        
                          #ifdef MOD_OLED
                            // pour le moment on se contente d'afficher la téléinfo
                            screen_state = screen_teleinfo;
                        
                            // Modification d'affichage et afficheur présent ?
                            if (refreshDisplay && (status & STATUS_OLED))
                              display_loop();
                              _yield();
                          #endif
                        
                          // çà c'est fait
                          refreshDisplay = false;
                        
                          #if defined (SPARK)
                          // recupération de l'état de connexion au cloud SPARK
                          currentcloudstate = Spark.connected();
                          #elif defined (ESP8266)
                          // recupération de l'état de connexion au Wifi
                          currentcloudstate = WiFi.status()==WL_CONNECTED ? true:false;
                          #endif
                        
                          // La connexion cloud vient de chager d'état ?
                          if (lastcloudstate != currentcloudstate)
                          {
                            // Mise à jour de l'état
                            lastcloudstate=currentcloudstate;
                        
                            // on vient de se reconnecter ?
                            if (currentcloudstate)
                            {
                              // on pubie à nouveau nos affaires
                              // Plus necessaire
                              #ifdef SPARK
                              // spark_expose_cloud();
                              #endif
                        
                              // led verte
                              LedRGBON(COLOR_GREEN);
                            }
                            else
                            {
                              // on compte la deconnexion led rouge
                              my_cloud_disconnect++;
                              Serial.print("Perte de conexion au cloud #");
                              Serial.println(my_cloud_disconnect);
                              LedRGBON(COLOR_RED);
                        	  
                        
                        
                        	  ///////////////////////// AJOUT DANY
                        	  Serial.println("");
                        	  Serial.println("Redemarrage automatque");
                        	  ESP.wdtDisable();
                        	  ESP.restart();
                        	  ///////////////////////// AJOUT DANY
                        
                        
                            }
                          }
                        
                          //#ifdef SPARK
                          //char buff[64];
                          //int len = 64;
                        
                          // process incoming connections one at a time forever
                          //server.processConnection(buff, &len);
                          //#endif
                        
                        
                          // Connection au Wifi ou Vérification
                          #ifdef ESP8266
                            // Webserver 
                            server.handleClient();
                            ArduinoOTA.handle();
                        
                            if (task_emoncms) { 
                              emoncmsPost(); 
                              task_emoncms=false; 
                            } else if (task_jeedom) { 
                              jeedomPost();  
                              task_jeedom=false;
                            }
                          #endif
                        
                        }
                        

                        J'utilise l'Arduino IDE 1.6.7, je vais essayer et étudier ta nouvelle version du WifiHandleConn ce soir.

                        1 Reply Last reply Reply Quote
                        • CharlesC Offline
                          Charles
                          last edited by

                          @Dany21000
                          Merci pour le partage 🙂

                          Ah oui je ne sais plus trop, peut être le remora bascule en softAP si il perd le Wifi je me souviens plus ce que j'ai fait (en plus mixé avec le code particle, ça devient plus trop lisible)

                          Question bête pourquoi le choix des DHT22 ?J'ai le même projet que toi en fait, mais pour de l'indus, j'ai pris des SI7021 qui sont plus petits, plus précis avec un temps de mesure plus rapide, mais surtout I2C et donc pas de blocage à cause de timing précis ;). Mais moins pratique à souder, quoi que regarde ici

                          J"ai ajouté le clignotement de la onboard LED aussi dans le loop ça me permet de voir direct si le nodeMCU est connecté au Wifi ou en AP/Deconnecté, super pratique et aussi de detecter l'appui sur le bouton "flash" pour faire des actions par exemple

                          dans le loop

                          // manage Blinking LED
                            // Wifi disabled 
                            if (!wifi_state) {
                              key = handle_key_led(LOW);
                            } else {
                              if (WiFi.status()==WL_CONNECTED) {
                                // Connected (Client mode OK)
                                key = handle_key_led(((millis() % 1000) < 200) ? HIGH:LOW);
                              } else {
                                // AP Mode only or client failed
                                key = handle_key_led(((millis() % 333) < 111) ? HIGH:LOW);
                              }
                            }
                          
                            if (key) {
                              DebuglnF("Key pressed");
                            }
                          

                          et la fonction handle_key_led

                          /* ======================================================================
                          Function: handle_key_led 
                          Purpose : Manage on board Led and Push button of NodeMCU
                          Input   : 1 to light on the led, 0 to light off
                          Output  : 1 if button is pressed
                          Comments: on NodeMCU BUILTIN_LED is GPIO16
                          ====================================================================== */
                          uint8_t handle_key_led( uint8_t level)
                          {
                            uint8_t temp;
                            digitalWrite(16, 1);
                            pinMode(16, OUTPUT);
                            digitalWrite(16, !level);
                          
                            // Flash is on GPIO0, so RGB LED
                            pinMode(0, INPUT);
                            temp = digitalRead(0);
                            pinMode(0, OUTPUT); // set back to output
                            return !temp;
                          }
                          
                          

                          Ce sera intégré dans les prochaines version Remora et WifInfo

                          1 Reply Last reply Reply Quote
                          • Dany21000D Offline
                            Dany21000
                            last edited by

                            Je n'ai pas encore eux le temps d'apprivoiser ces modifications.

                            En tout cas, je viens de connecter la téléinfo sur la remora... enfin depuis 2 jours elle y est.
                            Aie, elle me fait du délestage en plus de jeedom...
                            Demain je lui retire sa teleinfo tant que je n'ai pas ajouté un petit booleen quelque part pour autoriser ou non le delestage par la remora.

                            Je vais certainement ouvrir un nouveau sujet dès que j'ai un peu de temps et tu aura la réponse du pourquoi du DHT22.

                            1 Reply Last reply Reply Quote
                            • S Offline
                              seb
                              last edited by

                              Bonjour à tous,

                              Merci Charles pour le module
                              Soudures faites , tout fonctionne imper

                              Je voulais vous remercier de votre efficacité et gentillesse, tout court

                              A bientôt
                              Seb

                              1 Reply Last reply Reply Quote
                              • CharlesC Offline
                                Charles
                                last edited by

                                @Seb,
                                Merci pour ton retour, à très vite.

                                1 Reply Last reply Reply Quote
                                • First post
                                  Last post

                                3

                                Online

                                5.7k

                                Users

                                534

                                Topics

                                5.0k

                                Posts

                                Top Topics

                                • Denky 4 - Domoticz - Triphasé -
                                  Nicolas BernaertsN
                                  Nicolas Bernaerts
                                  0
                                  7
                                  249

                                • Denky D4 et Linky Standard TInfo Rx Non Configuré
                                  CharlesC
                                  Charles
                                  0
                                  5
                                  282

                                • CC1101
                                  CharlesC
                                  Charles
                                  0
                                  2
                                  117

                                Popular Tags

                                teleinfo
                                24 topics
                                arduino
                                19 topics
                                remora
                                16 topics
                                esp8266
                                10 topics
                                arduipi
                                10 topics
                                wifinfo
                                7 topics
                                raspberry
                                7 topics
                                broadcast
                                7 topics
                                Copyright © 2022 Charles-Henri Hallard | Return to blog page | Powered by NodeBB