Merge pull request #3 from HendrikRauh/DMX-19

DMX-19 Basic config get endpoint
This commit is contained in:
Hendrik Rauh 2024-10-26 14:53:41 +02:00 committed by GitHub
commit deb1e591cf
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
2 changed files with 41 additions and 58 deletions

View file

@ -14,4 +14,5 @@ board = lolin_s2_mini
framework = arduino framework = arduino
lib_deps = lib_deps =
hideakitai/ArtNet @ ^0.8.0 hideakitai/ArtNet @ ^0.8.0
bblanchon/ArduinoJson @ ^7.2.0
ESP Async WebServer ESP Async WebServer

View file

@ -1,36 +1,40 @@
#include <ArtnetWiFi.h> #include <ArtnetWiFi.h>
// #include <ArtnetEther.h> // #include <ArtnetEther.h>
#include <ArduinoJson.h>
#include "ESPDMX.h" #include "ESPDMX.h"
#include <ESPAsyncWebServer.h> #include <ESPAsyncWebServer.h>
#include <SPIFFS.h> #include <SPIFFS.h>
#include <Preferences.h>
// WiFi stuff Preferences config;
const char *ssid = "artnet"; DMXESPSerial dmx;
const char *pwd = "mbgmbgmbg";
const IPAddress ip(192, 168, 1, 201);
const IPAddress gateway(192, 168, 1, 1);
const IPAddress subnet(255, 255, 255, 0);
AsyncWebServer server(80); AsyncWebServer server(80);
// Art-Net stuff
ArtnetWiFi artnet; ArtnetWiFi artnet;
// const String target_ip = "192.168.1.200";
uint8_t universe = 1; // 0 - 15
const uint16_t size = 512; const uint16_t size = 512;
uint8_t data[size]; uint8_t data[size];
uint8_t value = 0;
// DMX stuff
DMXESPSerial dmx;
void setup() void setup()
{ {
// Serial console
Serial.begin(9600); Serial.begin(9600);
config.begin("dmx", false);
uint8_t universe = config.getUChar("universe", 1);
String ssid = config.getString("ssid", "artnet");
String pwd = config.getString("pwd", "mbgmbgmbg");
IPAddress defaultIp(192, 168, 1, 201);
IPAddress ip = config.getUInt("ip", defaultIp);
IPAddress cidr = config.getUChar("cidr", 24);
// TODO: \/ Herleiten \/ @psxde
const IPAddress gateway(192, 168, 1, 1);
const IPAddress subnet(255, 255, 255, 0);
// WiFi stuff // WiFi stuff
// WiFi.begin(ssid, pwd); // WiFi.begin(ssid, pwd);
WiFi.softAP(ssid, pwd); WiFi.softAP(ssid, pwd);
@ -52,44 +56,15 @@ void setup()
// if Artnet packet comes to this universe, this function is called // if Artnet packet comes to this universe, this function is called
artnet.subscribeArtDmxUniverse(universe, [&](const uint8_t *data, uint16_t size, const ArtDmxMetadata &metadata, const ArtNetRemoteInfo &remote) artnet.subscribeArtDmxUniverse(universe, [&](const uint8_t *data, uint16_t size, const ArtDmxMetadata &metadata, const ArtNetRemoteInfo &remote)
{ {
/*Serial.print("lambda : artnet data from ");
Serial.print(remote.ip);
Serial.print(":");
Serial.print(remote.port);
Serial.print(", universe = ");
Serial.print(universe);
Serial.print(", size = ");
Serial.print(size);
Serial.print(") :");*/
for (size_t i = 0; i < size; ++i) for (size_t i = 0; i < size; ++i)
{ {
dmx.write((i + 1), data[i]); dmx.write((i + 1), data[i]);
// Serial.print(data[i]);
// Serial.print(",");
} }
// Serial.println();
dmx.update(); }); dmx.update(); });
// if Artnet packet comes, this function is called to every universe // if Artnet packet comes, this function is called to every universe
artnet.subscribeArtDmx([&](const uint8_t *data, uint16_t size, const ArtDmxMetadata &metadata, const ArtNetRemoteInfo &remote) artnet.subscribeArtDmx([&](const uint8_t *data, uint16_t size, const ArtDmxMetadata &metadata, const ArtNetRemoteInfo &remote) {});
{
/*Serial.print("received ArtNet data from ");
Serial.print(remote.ip);
Serial.print(":");
Serial.print(remote.port);
Serial.print(", net = ");
Serial.print(metadata.net);
Serial.print(", subnet = ");
Serial.print(metadata.subnet);
Serial.print(", universe = ");
Serial.print(metadata.universe);
Serial.print(", sequence = ");
Serial.print(metadata.sequence);
Serial.print(", size = ");
Serial.print(size);
Serial.println(")");*/ });
if (!SPIFFS.begin(true)) if (!SPIFFS.begin(true))
{ {
@ -99,6 +74,20 @@ void setup()
server.serveStatic("/", SPIFFS, "/").setDefaultFile("index.html"); server.serveStatic("/", SPIFFS, "/").setDefaultFile("index.html");
server.on("/config", HTTP_GET, [&, defaultIp, ssid, pwd, universe](AsyncWebServerRequest *request)
{
DynamicJsonDocument doc(1024);
doc["ssid"] = ssid;
doc["pwd"] = pwd;
doc["ip"] = defaultIp;
doc["universe"] = universe;
String jsonString;
serializeJson(doc, jsonString);
request->send(200, "application/json", jsonString); });
delay(1000);
server.begin(); server.begin();
Serial.println("Server started!"); Serial.println("Server started!");
} }
@ -106,11 +95,4 @@ void setup()
void loop() void loop()
{ {
artnet.parse(); // check if artnet packet has come and execute callback artnet.parse(); // check if artnet packet has come and execute callback
/*value = (millis() / 4) % 256;
memset(data, value, size);
artnet.setArtDmxData(data, size);
artnet.streamArtDmxTo(target_ip, universe); // automatically send set data in 40fps
// artnet.streamArtDmxTo(target_ip, net, subnet, univ); // or you can set net, subnet, and universe */
} }