mirror of
https://github.com/Links2004/arduinoWebSockets.git
synced 2025-07-15 16:30:31 +02:00
add LED control example
command out all echos
This commit is contained in:
@ -30,26 +30,28 @@ void webSocketEvent(WStype_t type, uint8_t * payload, size_t lenght) {
|
|||||||
case WStype_CONNECTED:
|
case WStype_CONNECTED:
|
||||||
{
|
{
|
||||||
USE_SERIAL.printf("[WSc] Connected to url: %s\n", payload);
|
USE_SERIAL.printf("[WSc] Connected to url: %s\n", payload);
|
||||||
|
|
||||||
|
// send message to server when Connected
|
||||||
|
webSocket.sendTXT(num, "Connected");
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case WStype_TEXT:
|
case WStype_TEXT:
|
||||||
USE_SERIAL.printf("[WSc] get text: %s\n", payload);
|
USE_SERIAL.printf("[WSc] get text: %s\n", payload);
|
||||||
|
|
||||||
// send data to back to Server
|
// send message to server
|
||||||
webSocket.sendTXT(payload, lenght);
|
// webSocket.sendTXT("message here");
|
||||||
break;
|
break;
|
||||||
case WStype_BIN:
|
case WStype_BIN:
|
||||||
USE_SERIAL.printf("[WSc] get binary lenght: %u\n", lenght);
|
USE_SERIAL.printf("[WSc] get binary lenght: %u\n", lenght);
|
||||||
hexdump(payload, lenght);
|
hexdump(payload, lenght);
|
||||||
|
|
||||||
// echo data back to Server
|
// send data to server
|
||||||
webSocket.sendBIN(payload, lenght);
|
// webSocket.sendBIN(payload, lenght);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void setup() {
|
void setup() {
|
||||||
// USE_SERIAL.begin(921600);
|
// USE_SERIAL.begin(921600);
|
||||||
USE_SERIAL.begin(115200);
|
USE_SERIAL.begin(115200);
|
||||||
@ -79,8 +81,6 @@ void setup() {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void loop() {
|
void loop() {
|
||||||
webSocket.loop();
|
webSocket.loop();
|
||||||
}
|
}
|
||||||
|
@ -28,23 +28,26 @@ void webSocketEvent(uint8_t num, WStype_t type, uint8_t * payload, size_t lenght
|
|||||||
{
|
{
|
||||||
IPAddress ip = webSocket.remoteIP(num);
|
IPAddress ip = webSocket.remoteIP(num);
|
||||||
USE_SERIAL.printf("[%u] Connected from %d.%d.%d.%d url: %s\n", num, ip[0], ip[1], ip[2], ip[3], payload);
|
USE_SERIAL.printf("[%u] Connected from %d.%d.%d.%d url: %s\n", num, ip[0], ip[1], ip[2], ip[3], payload);
|
||||||
|
|
||||||
|
// send message to client
|
||||||
|
webSocket.sendTXT(num, "Connected");
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case WStype_TEXT:
|
case WStype_TEXT:
|
||||||
USE_SERIAL.printf("[%u] get Text: %s\n", num, payload);
|
USE_SERIAL.printf("[%u] get Text: %s\n", num, payload);
|
||||||
|
|
||||||
// echo data back to browser
|
// send message to client
|
||||||
webSocket.sendTXT(num, payload, lenght);
|
// webSocket.sendTXT(num, "message here");
|
||||||
|
|
||||||
// send data to all connected clients
|
// send data to all connected clients
|
||||||
webSocket.broadcastTXT(payload, lenght);
|
// webSocket.broadcastTXT("message here");
|
||||||
break;
|
break;
|
||||||
case WStype_BIN:
|
case WStype_BIN:
|
||||||
USE_SERIAL.printf("[%u] get binary lenght: %u\n", num, lenght);
|
USE_SERIAL.printf("[%u] get binary lenght: %u\n", num, lenght);
|
||||||
hexdump(payload, lenght);
|
hexdump(payload, lenght);
|
||||||
|
|
||||||
// echo data back to browser
|
// send message to client
|
||||||
webSocket.sendBIN(num, payload, lenght);
|
// webSocket.sendBIN(num, payload, lenght);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -0,0 +1,122 @@
|
|||||||
|
/*
|
||||||
|
* WebSocketServer_LEDcontrol.ino
|
||||||
|
*
|
||||||
|
* Created on: 26.11.2015
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <Arduino.h>
|
||||||
|
|
||||||
|
#include <ESP8266WiFi.h>
|
||||||
|
#include <ESP8266WiFiMulti.h>
|
||||||
|
#include <WebSocketsServer.h>
|
||||||
|
#include <ESP8266WebServer.h>
|
||||||
|
#include <ESP8266mDNS.h>
|
||||||
|
#include <Hash.h>
|
||||||
|
|
||||||
|
#define LED_RED 15
|
||||||
|
#define LED_GREEN 12
|
||||||
|
#define LED_BLUE 13
|
||||||
|
|
||||||
|
#define USE_SERIAL Serial
|
||||||
|
|
||||||
|
|
||||||
|
ESP8266WiFiMulti WiFiMulti;
|
||||||
|
|
||||||
|
ESP8266WebServer server = ESP8266WebServer(80);
|
||||||
|
WebSocketsServer webSocket = WebSocketsServer(81);
|
||||||
|
|
||||||
|
void webSocketEvent(uint8_t num, WStype_t type, uint8_t * payload, size_t lenght) {
|
||||||
|
|
||||||
|
switch(type) {
|
||||||
|
case WStype_DISCONNECTED:
|
||||||
|
USE_SERIAL.printf("[%u] Disconnected!\n", num);
|
||||||
|
break;
|
||||||
|
case WStype_CONNECTED: {
|
||||||
|
IPAddress ip = webSocket.remoteIP(num);
|
||||||
|
USE_SERIAL.printf("[%u] Connected from %d.%d.%d.%d url: %s\n", num, ip[0], ip[1], ip[2], ip[3], payload);
|
||||||
|
|
||||||
|
// send message to client
|
||||||
|
webSocket.sendTXT(num, "Connected");
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case WStype_TEXT:
|
||||||
|
USE_SERIAL.printf("[%u] get Text: %s\n", num, payload);
|
||||||
|
|
||||||
|
if(payload[0] == '#') {
|
||||||
|
// we get RGB data
|
||||||
|
|
||||||
|
// decode rgb data
|
||||||
|
uint32_t rgb = (uint32_t) strtol((const char *) &payload[1], NULL, 16);
|
||||||
|
|
||||||
|
analogWrite(LED_RED, ((rgb >> 16) & 0xFF));
|
||||||
|
analogWrite(LED_GREEN, ((rgb >> 8) & 0xFF));
|
||||||
|
analogWrite(LED_BLUE, ((rgb >> 0) & 0xFF));
|
||||||
|
}
|
||||||
|
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
void setup() {
|
||||||
|
USE_SERIAL.begin(921600);
|
||||||
|
//USE_SERIAL.begin(115200);
|
||||||
|
|
||||||
|
USE_SERIAL.setDebugOutput(true);
|
||||||
|
|
||||||
|
USE_SERIAL.println();
|
||||||
|
USE_SERIAL.println();
|
||||||
|
USE_SERIAL.println();
|
||||||
|
|
||||||
|
for(uint8_t t = 4; t > 0; t--) {
|
||||||
|
USE_SERIAL.printf("[SETUP] BOOT WAIT %d...\n", t);
|
||||||
|
USE_SERIAL.flush();
|
||||||
|
delay(1000);
|
||||||
|
}
|
||||||
|
|
||||||
|
pinMode(LED_RED, OUTPUT);
|
||||||
|
pinMode(LED_GREEN, OUTPUT);
|
||||||
|
pinMode(LED_BLUE, OUTPUT);
|
||||||
|
|
||||||
|
digitalWrite(LED_RED, 1);
|
||||||
|
digitalWrite(LED_GREEN, 1);
|
||||||
|
digitalWrite(LED_BLUE, 1);
|
||||||
|
|
||||||
|
WiFiMulti.addAP("SSID", "passpasspass");
|
||||||
|
|
||||||
|
while(WiFiMulti.run() != WL_CONNECTED) {
|
||||||
|
delay(100);
|
||||||
|
}
|
||||||
|
|
||||||
|
// start webSocket server
|
||||||
|
webSocket.begin();
|
||||||
|
webSocket.onEvent(webSocketEvent);
|
||||||
|
|
||||||
|
if(MDNS.begin("esp8266")) {
|
||||||
|
Serial.println("MDNS responder started");
|
||||||
|
}
|
||||||
|
|
||||||
|
// handle index
|
||||||
|
server.on("/", []() {
|
||||||
|
// send index.html
|
||||||
|
server.send(200, "text/html", "<html><head><script>var connection = new WebSocket('ws://'+location.hostname+':81/', ['arduino']);connection.onopen = function () { connection.send('Connect ' + new Date()); }; connection.onerror = function (error) { console.log('WebSocket Error ', error);};connection.onmessage = function (e) { console.log('Server: ', e.data);};function sendRGB() { var r = parseInt(document.getElementById('r').value).toString(16); var g = parseInt(document.getElementById('g').value).toString(16); var b = parseInt(document.getElementById('b').value).toString(16); if(r.length < 2) { r = '0' + r; } if(g.length < 2) { g = '0' + g; } if(b.length < 2) { b = '0' + b; } var rgb = '#'+r+g+b; console.log('RGB: ' + rgb); connection.send(rgb); }</script></head><body>LED Control:<br/><br/>R: <input id=\"r\" type=\"range\" min=\"0\" max=\"255\" step=\"1\" onchange=\"sendRGB();\" /><br/>G: <input id=\"g\" type=\"range\" min=\"0\" max=\"255\" step=\"1\" onchange=\"sendRGB();\" /><br/>B: <input id=\"b\" type=\"range\" min=\"0\" max=\"255\" step=\"1\" onchange=\"sendRGB();\" /><br/></body></html>");
|
||||||
|
});
|
||||||
|
|
||||||
|
server.begin();
|
||||||
|
|
||||||
|
// Add service to MDNS
|
||||||
|
MDNS.addService("http", "tcp", 80);
|
||||||
|
MDNS.addService("ws", "tcp", 81);
|
||||||
|
|
||||||
|
digitalWrite(LED_RED, 0);
|
||||||
|
digitalWrite(LED_GREEN, 0);
|
||||||
|
digitalWrite(LED_BLUE, 0);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
void loop() {
|
||||||
|
webSocket.loop();
|
||||||
|
server.handleClient();
|
||||||
|
}
|
||||||
|
|
@ -2,11 +2,16 @@
|
|||||||
<head>
|
<head>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
var connection = new WebSocket('ws://10.11.2.2:81/test', ['arduino']);
|
var connection = new WebSocket('ws://10.11.2.1:81/', ['arduino']);
|
||||||
|
|
||||||
connection.onopen = function () {
|
connection.onopen = function () {
|
||||||
connection.send('Message from Browser to ESP8266 yay its Working!! ' + new Date());
|
connection.send('Message from Browser to ESP8266 yay its Working!! ' + new Date());
|
||||||
connection.send('ping');
|
connection.send('ping');
|
||||||
|
|
||||||
|
setInterval(function() {
|
||||||
|
connection.send('Time: ' + new Date());
|
||||||
|
}, 20);
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
connection.onerror = function (error) {
|
connection.onerror = function (error) {
|
||||||
@ -17,14 +22,26 @@ connection.onmessage = function (e) {
|
|||||||
console.log('Server: ', e.data);
|
console.log('Server: ', e.data);
|
||||||
};
|
};
|
||||||
|
|
||||||
setInterval(function() {
|
function sendRGB() {
|
||||||
connection.send('Time: ' + new Date());
|
var r = parseInt(document.getElementById('r').value).toString(16);
|
||||||
}, 1000);
|
var g = parseInt(document.getElementById('g').value).toString(16);
|
||||||
|
var b = parseInt(document.getElementById('b').value).toString(16);
|
||||||
|
if(r.length < 2) { r = '0' + r; }
|
||||||
|
if(g.length < 2) { g = '0' + g; }
|
||||||
|
if(b.length < 2) { b = '0' + b; }
|
||||||
|
var rgb = '#'+r+g+b;
|
||||||
|
console.log('RGB: ' + rgb);
|
||||||
|
connection.send(rgb);
|
||||||
|
}
|
||||||
|
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
Test Websocket.
|
LED Control:<br/>
|
||||||
|
<br/>
|
||||||
|
R: <input id="r" type="range" min="0" max="255" step="1" onchange="sendRGB();" /><br/>
|
||||||
|
G: <input id="g" type="range" min="0" max="255" step="1" onchange="sendRGB();" /><br/>
|
||||||
|
B: <input id="b" type="range" min="0" max="255" step="1" onchange="sendRGB();" /><br/>
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
Reference in New Issue
Block a user