Skip to content

WeMos D1 / D1R2 (ESP8266) Web Control Panel via WiFi using Johnny Five (JavaScript) and Socket.IO

Notifications You must be signed in to change notification settings

mateuszroth/esp8266-web-control-panel

Repository files navigation

WeMos D1 (ESP8266) Web Control Panel via WiFi

using Firmata, Johnny Five (JavaScript) and Socket.IO

not tested but after updating pins should work with WeMos D1R2 and Arduino UNO

Programming the ESP8266 WeMos D1 using JavaScript library Johnny Five to work remotely.

Requirements

  • make sure you have installed Node.js and Python in version 2.7
  • you should have Arduino 1.6.8 or higher installed

Installation

  1. Follow instructions for installing the newest hardware package using git for WeMos D1.
    1. Install the required driver (CH340G or CP2104).
    2. Follow instructions from the Using git version section.
    3. While instaling the hardware package, make sure you have at least v2.2.0 of ESP8266 Core (on Mac, check in your terminal cat ~/Documents/Arduino/hardware/esp8266com/esp8266/package.json).
    4. After install hardware package, you will see WeMos boards in the Tools→Board:xxx. Choose your right board.
  2. Then install newest Firmata from master branch from git repository (on Mac you have to delete existing Firmata directory ~/Documents/Arduino/libraries/Firmata and then run git clone git@github.com:firmata/arduino.git ~/Documents/Arduino/libraries/Firmata in your terminal). Firmata is a protocol that will allow us to communicate with our microcontroller using languages like JavaScript.
  3. Now you can use StandardFirmataWiFi (in Arduino, choose File -> Examples -> Firmata -> StandardFirmataWiFi) which enables the use of Firmata over a TCP connection and it can be configured as either a TCP server or TCP client.
    1. Configure wifiConfig.h (ESP8266 is enabled by default but follow all the 6 steps).
    2. You can skip step 4 but I prefer to have a static IP for both the computer and the board. If you decide to use static IP then on Mac you can check the router IP address and the network mask in Settings -> Network -> Advanced -> TCP/IP.
    3. Enable Serial debugging by uncommenting //#define SERIAL_DEBUG in StandardFirmataWiFi.
    4. Change Upload Speed in Menu -> Upload Speed to 115200.
    5. Then upload the project to your WeMos D1 in Arduino IDE.
  4. Check if the connection is configured properly by opening Serial Monitor (in Arduino, Tools -> Serial Monitor) at baud 9600. If the board is sending WiFi connection failed then try to reconfigure wifiConfig.h or try to use another WiFi point (your computer and the board should be in the same network).
    1. While I used hotspot on my mobile, it worked only for 2.4 GHz and not for 5 GHz.

Yay, your board is configured and ready to communicate via Firmata with your JavaScript code on your computer!

Test Firmata.js with your board

Firmata.js is the base for Johnny Five so let's test it with our board which has StandardFirmataWiFi deployed. Here's a simple Firmata.js client example with additional instructions. Just copy source code to a file for example named index.js and use correct IP address. Then run command npm install firmata etherport-client serialport --save to install dependencies and run the code by using node index.js. The LED on digital pin 2 should blink. You can change the pin to something different, for example digital pin 13.

If you're having some troubles with running the script, the command npm install serialport --build-from-source --save may help.

Test Johnny Five

If everything was done well, you can check simple J5 code (remember to install dependencies by using command npm install johnny-five etherport-client serialport --save):

var five = require("johnny-five");
var EtherPortClient = require("etherport-client").EtherPortClient;
// update host to the IP address for your ESP board
var board = new five.Board({
    port: new EtherPortClient({
        host: "10.0.0.17", // #TODO UPDATE!
        port: 3030
    }),
    timeout: 1e5,
    repl: false
});

board.on("ready", function() {
    console.log("READY!");
    var led = new five.Led(2);
    led.blink(500);
});

Now you can try code examples for Johhny Five.

In opposite to Johhny Five, you can check Breakout.

Build the web panel from the repo

Run npm install to install packages.

Start server/server.js on your server machine (command node server/server.js).

Update ESP device and server IP in device/client.js file and start client (command node device/client.js).

WeMos D1 vs D1 R2

There are two versions of the WeMos D1, called the "D1" and the "D2 R2". There are some pin differences between them.

WeMos D1 vs D1 R2

Source

WeMos D1 R2 vs Arduino UNO

There are some differences between these two boards.

WeMos D1 R2 vs Arduino UNO

Sources:

Links

Other helpful links:

About

WeMos D1 / D1R2 (ESP8266) Web Control Panel via WiFi using Johnny Five (JavaScript) and Socket.IO

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published