WIP
This commit is contained in:
parent
bcf24560e9
commit
b5d3578c22
@ -17,11 +17,6 @@ void setup()
|
|||||||
// WIFI
|
// WIFI
|
||||||
setupWifi();
|
setupWifi();
|
||||||
|
|
||||||
// MQTT
|
|
||||||
client.setServer(MQTT_SERVER, MQTT_PORT);
|
|
||||||
client.setCallback(callbackMQTT);
|
|
||||||
testConnectMQTT();
|
|
||||||
|
|
||||||
// LED
|
// LED
|
||||||
brightness = LED_BRIGHTNESS_DEFAULT;
|
brightness = LED_BRIGHTNESS_DEFAULT;
|
||||||
color = LED_COLOR_DEFAULT;
|
color = LED_COLOR_DEFAULT;
|
||||||
@ -29,6 +24,7 @@ void setup()
|
|||||||
ledEffect = LED_EFFECT_ERROR;
|
ledEffect = LED_EFFECT_ERROR;
|
||||||
ledState = false;
|
ledState = false;
|
||||||
|
|
||||||
|
// LED
|
||||||
LEDS.addLeds<LED_CHIPSET,LED_PIN, LED_COLOR_ORDER>(leds, LED_NUM).setCorrection(TypicalSMD5050);
|
LEDS.addLeds<LED_CHIPSET,LED_PIN, LED_COLOR_ORDER>(leds, LED_NUM).setCorrection(TypicalSMD5050);
|
||||||
ledBlackAll();
|
ledBlackAll();
|
||||||
FastLED.setBrightness(brightness);
|
FastLED.setBrightness(brightness);
|
||||||
@ -37,6 +33,12 @@ void setup()
|
|||||||
currentPalette = RainbowColors_p;
|
currentPalette = RainbowColors_p;
|
||||||
currentBlending = LINEARBLEND;
|
currentBlending = LINEARBLEND;
|
||||||
//////////////////////////////// ColorPalette ///////////////////////////////
|
//////////////////////////////// ColorPalette ///////////////////////////////
|
||||||
|
|
||||||
|
// MQTT
|
||||||
|
client.setServer(MQTT_SERVER, MQTT_PORT);
|
||||||
|
client.setCallback(callbackMQTT);
|
||||||
|
testConnectMQTT();
|
||||||
|
|
||||||
Serial.println("Ready");
|
Serial.println("Ready");
|
||||||
|
|
||||||
/* MQTT
|
/* MQTT
|
||||||
@ -76,17 +78,20 @@ void testConnectMQTT()
|
|||||||
while (!client.connected()) {
|
while (!client.connected()) {
|
||||||
Serial.print("Connexion au serveur MQTT... ");
|
Serial.print("Connexion au serveur MQTT... ");
|
||||||
if (client.connect("ESP8266Client", MQTT_USER, MQTT_PASS)) {
|
if (client.connect("ESP8266Client", MQTT_USER, MQTT_PASS)) {
|
||||||
|
Serial.print("OK\nSend Current State");
|
||||||
|
mqttSendState();
|
||||||
|
mqttSendSpeedState();
|
||||||
|
mqttSendBrightnessState();
|
||||||
|
mqttSendEffectState();
|
||||||
|
mqttSendColorState();
|
||||||
|
|
||||||
Serial.print("OK\nSubscribe");
|
Serial.print("OK\nSubscribe");
|
||||||
client.subscribe(MQTT_LED_COMMAND);
|
client.subscribe(MQTT_LED_COMMAND);
|
||||||
mqttSendState();
|
|
||||||
client.subscribe(MQTT_LED_EFFECT_COMMAND);
|
client.subscribe(MQTT_LED_EFFECT_COMMAND);
|
||||||
//mqttSendEffectState();
|
|
||||||
client.subscribe(MQTT_LED_BRIGHTNESS_COMMAND);
|
client.subscribe(MQTT_LED_BRIGHTNESS_COMMAND);
|
||||||
mqttSendBrightnessState();
|
|
||||||
client.subscribe(MQTT_LED_SPEED_COMMAND);
|
client.subscribe(MQTT_LED_SPEED_COMMAND);
|
||||||
//mqttSendSpeedState();
|
|
||||||
client.subscribe(MQTT_LED_COLOR_COMMAND);
|
client.subscribe(MQTT_LED_COLOR_COMMAND);
|
||||||
//mqttSendColorState();
|
|
||||||
Serial.println(" OK");
|
Serial.println(" OK");
|
||||||
} else {
|
} else {
|
||||||
Serial.print("KO, erreur : ");
|
Serial.print("KO, erreur : ");
|
||||||
@ -124,11 +129,11 @@ void callbackMQTT(char* topic, byte* payload, unsigned int length)
|
|||||||
// Si on ne repasse pas tout à noir, cela peut faire des effets surprenants
|
// Si on ne repasse pas tout à noir, cela peut faire des effets surprenants
|
||||||
ledBlackAll();
|
ledBlackAll();
|
||||||
ledEffect = msgString;
|
ledEffect = msgString;
|
||||||
client.publish(MQTT_LED_EFFECT_STATE, message_buff, true);
|
mqttSendEffectState();
|
||||||
} else if (stopic == MQTT_LED_BRIGHTNESS_COMMAND) {
|
} else if (stopic == MQTT_LED_BRIGHTNESS_COMMAND) {
|
||||||
brightness = msgString.toInt();
|
brightness = msgString.toInt();
|
||||||
FastLED.setBrightness(brightness);
|
FastLED.setBrightness(brightness);
|
||||||
client.publish(MQTT_LED_BRIGHTNESS_STATE, message_buff, true);
|
mqttSendBrightnessState();
|
||||||
} else if (stopic == MQTT_LED_COLOR_COMMAND) {
|
} else if (stopic == MQTT_LED_COLOR_COMMAND) {
|
||||||
// Sample : 134,168,255
|
// Sample : 134,168,255
|
||||||
int red = msgString.substring(0, msgString.indexOf(',')).toInt();
|
int red = msgString.substring(0, msgString.indexOf(',')).toInt();
|
||||||
@ -136,20 +141,16 @@ void callbackMQTT(char* topic, byte* payload, unsigned int length)
|
|||||||
int blue = msgString.substring(msgString.lastIndexOf(',') + 1).toInt();
|
int blue = msgString.substring(msgString.lastIndexOf(',') + 1).toInt();
|
||||||
|
|
||||||
color=((red <<16)|(green <<8)|blue);
|
color=((red <<16)|(green <<8)|blue);
|
||||||
client.publish(MQTT_LED_COLOR_STATE, message_buff, true);
|
mqttSendColorState();
|
||||||
} else if (stopic == MQTT_LED_SPEED_COMMAND) {
|
} else if (stopic == MQTT_LED_SPEED_COMMAND) {
|
||||||
speed = msgString.toInt();
|
speed = msgString.toInt();
|
||||||
client.publish(MQTT_LED_SPEED_STATE, message_buff, true);
|
mqttSendSpeedState();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void mqttSendState()
|
void mqttSendState()
|
||||||
{
|
{
|
||||||
if (ledState) {
|
client.publish(MQTT_LED_STATE, (ledState) ? "ON": "OFF", true);
|
||||||
client.publish(MQTT_LED_STATE, "ON", true);
|
|
||||||
} else {
|
|
||||||
client.publish(MQTT_LED_STATE, "OFF", true);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void mqttSendEffectState()
|
void mqttSendEffectState()
|
||||||
@ -175,14 +176,13 @@ void mqttSendSpeedState()
|
|||||||
|
|
||||||
void mqttSendColorState()
|
void mqttSendColorState()
|
||||||
{
|
{
|
||||||
/*
|
int red = color>>16 & 0xFF;
|
||||||
int red = msgString.substring(0, msgString.indexOf(',')).toInt();
|
int green = color>>8 & 0xFF;
|
||||||
int green = msgString.substring(msgString.indexOf(',') + 1, msgString.lastIndexOf(',')).toInt();
|
int blue = color & 0xFF;
|
||||||
int blue = msgString.substring(msgString.lastIndexOf(',') + 1).toInt();
|
char buff[12];
|
||||||
color=((red <<16)|(green <<8)|blue);
|
|
||||||
TODO: client.publish(MQTT_LED_COLOR_STATE, message_buff, true);
|
sprintf(buff, "%i,%i,%i\0", red, green, blue);
|
||||||
avec color
|
client.publish(MQTT_LED_COLOR_STATE, buff, true);
|
||||||
*/
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// LED
|
// LED
|
||||||
@ -316,8 +316,8 @@ void ledFullColor()
|
|||||||
// 0.36787944 ?? censé correspondre au minimum
|
// 0.36787944 ?? censé correspondre au minimum
|
||||||
// 108.4 ?? censé correspondre au maximum
|
// 108.4 ?? censé correspondre au maximum
|
||||||
int breath = (exp(sin(millis() / 2000.0 * PI)) - 0.3678794) * 108.4;
|
int breath = (exp(sin(millis() / 2000.0 * PI)) - 0.3678794) * 108.4;
|
||||||
Serial.print(breath);
|
//Serial.print(breath);
|
||||||
Serial.println(" / 255");
|
//Serial.println(" / 255");
|
||||||
FastLED.setBrightness(breath);
|
FastLED.setBrightness(breath);
|
||||||
FastLED.delay(100 / speed);
|
FastLED.delay(100 / speed);
|
||||||
}
|
}
|
||||||
|
|||||||
@ -54,6 +54,11 @@ PubSubClient client(espClient);
|
|||||||
void setupWifi();
|
void setupWifi();
|
||||||
void testConnectMQTT();
|
void testConnectMQTT();
|
||||||
void callbackMQTT(char* topic, byte* payload, unsigned int length);
|
void callbackMQTT(char* topic, byte* payload, unsigned int length);
|
||||||
|
void mqttSendState();
|
||||||
|
void mqttSendEffectState();
|
||||||
|
void mqttSendBrightnessState();
|
||||||
|
void mqttSendSpeedState();
|
||||||
|
void mqttSendColorState();
|
||||||
void ledBlackAll();
|
void ledBlackAll();
|
||||||
void ledCylon();
|
void ledCylon();
|
||||||
void ledError();
|
void ledError();
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user