integrated FX library
added fire fx fixed ani reset individual led control
This commit is contained in:
parent
eb8825ab27
commit
bce00eea0c
1221
wled00/WS2812FX.cpp
Normal file
1221
wled00/WS2812FX.cpp
Normal file
File diff suppressed because it is too large
Load Diff
338
wled00/WS2812FX.h
Normal file
338
wled00/WS2812FX.h
Normal file
@ -0,0 +1,338 @@
|
|||||||
|
/*
|
||||||
|
WS2812FX.h - Library for WS2812 LED effects.
|
||||||
|
|
||||||
|
Harm Aldick - 2016
|
||||||
|
www.aldick.org
|
||||||
|
FEATURES
|
||||||
|
* A lot of blinken modes and counting
|
||||||
|
* WS2812FX can be used as drop-in replacement for Adafruit Neopixel Library
|
||||||
|
NOTES
|
||||||
|
* Uses the Adafruit Neopixel library. Get it here:
|
||||||
|
https://github.com/adafruit/Adafruit_NeoPixel
|
||||||
|
LICENSE
|
||||||
|
The MIT License (MIT)
|
||||||
|
Copyright (c) 2016 Harm Aldick
|
||||||
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
|
of this software and associated documentation files (the "Software"), to deal
|
||||||
|
in the Software without restriction, including without limitation the rights
|
||||||
|
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||||
|
copies of the Software, and to permit persons to whom the Software is
|
||||||
|
furnished to do so, subject to the following conditions:
|
||||||
|
The above copyright notice and this permission notice shall be included in
|
||||||
|
all copies or substantial portions of the Software.
|
||||||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||||
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||||
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
||||||
|
THE SOFTWARE.
|
||||||
|
CHANGELOG
|
||||||
|
2016-05-28 Initial beta release
|
||||||
|
2016-06-03 Code cleanup, minor improvements, new modes
|
||||||
|
2016-06-04 2 new fx, fixed setColor (now also resets _mode_color)
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef WS2812FX_h
|
||||||
|
#define WS2812FX_h
|
||||||
|
|
||||||
|
#include "Arduino.h"
|
||||||
|
#include <Adafruit_NeoPixel.h>
|
||||||
|
|
||||||
|
#define DEFAULT_BRIGHTNESS 50
|
||||||
|
#define DEFAULT_MODE 0
|
||||||
|
#define DEFAULT_SPEED 150
|
||||||
|
#define DEFAULT_COLOR 0xFF0000
|
||||||
|
|
||||||
|
#define SPEED_MIN 0
|
||||||
|
#define SPEED_MAX 255
|
||||||
|
|
||||||
|
#define BRIGHTNESS_MIN 0
|
||||||
|
#define BRIGHTNESS_MAX 255
|
||||||
|
|
||||||
|
#define MODE_COUNT 48
|
||||||
|
|
||||||
|
#define FX_MODE_STATIC 0
|
||||||
|
#define FX_MODE_BLINK 1
|
||||||
|
#define FX_MODE_BREATH 2
|
||||||
|
#define FX_MODE_COLOR_WIPE 3
|
||||||
|
#define FX_MODE_COLOR_WIPE_RANDOM 4
|
||||||
|
#define FX_MODE_RANDOM_COLOR 5
|
||||||
|
#define FX_MODE_SINGLE_DYNAMIC 6
|
||||||
|
#define FX_MODE_MULTI_DYNAMIC 7
|
||||||
|
#define FX_MODE_RAINBOW 8
|
||||||
|
#define FX_MODE_RAINBOW_CYCLE 9
|
||||||
|
#define FX_MODE_SCAN 10
|
||||||
|
#define FX_MODE_DUAL_SCAN 11
|
||||||
|
#define FX_MODE_FADE 12
|
||||||
|
#define FX_MODE_THEATER_CHASE 13
|
||||||
|
#define FX_MODE_THEATER_CHASE_RAINBOW 14
|
||||||
|
#define FX_MODE_RUNNING_LIGHTS 15
|
||||||
|
#define FX_MODE_TWINKLE 16
|
||||||
|
#define FX_MODE_TWINKLE_RANDOM 17
|
||||||
|
#define FX_MODE_TWINKLE_FADE 18
|
||||||
|
#define FX_MODE_TWINKLE_FADE_RANDOM 19
|
||||||
|
#define FX_MODE_SPARKLE 20
|
||||||
|
#define FX_MODE_FLASH_SPARKLE 21
|
||||||
|
#define FX_MODE_HYPER_SPARKLE 22
|
||||||
|
#define FX_MODE_STROBE 23
|
||||||
|
#define FX_MODE_STROBE_RAINBOW 24
|
||||||
|
#define FX_MODE_MULTI_STROBE 25
|
||||||
|
#define FX_MODE_BLINK_RAINBOW 26
|
||||||
|
#define FX_MODE_CHASE_WHITE 27
|
||||||
|
#define FX_MODE_CHASE_COLOR 28
|
||||||
|
#define FX_MODE_CHASE_RANDOM 29
|
||||||
|
#define FX_MODE_CHASE_RAINBOW 30
|
||||||
|
#define FX_MODE_CHASE_FLASH 31
|
||||||
|
#define FX_MODE_CHASE_FLASH_RANDOM 32
|
||||||
|
#define FX_MODE_CHASE_RAINBOW_WHITE 33
|
||||||
|
#define FX_MODE_CHASE_BLACKOUT 34
|
||||||
|
#define FX_MODE_CHASE_BLACKOUT_RAINBOW 35
|
||||||
|
#define FX_MODE_COLOR_SWEEP_RANDOM 36
|
||||||
|
#define FX_MODE_RUNNING_COLOR 37
|
||||||
|
#define FX_MODE_RUNNING_RED_BLUE 38
|
||||||
|
#define FX_MODE_RUNNING_RANDOM 39
|
||||||
|
#define FX_MODE_LARSON_SCANNER 40
|
||||||
|
#define FX_MODE_COMET 41
|
||||||
|
#define FX_MODE_FIREWORKS 42
|
||||||
|
#define FX_MODE_FIREWORKS_RANDOM 43
|
||||||
|
#define FX_MODE_MERRY_CHRISTMAS 44
|
||||||
|
#define FX_MODE_FIRE_FLICKER 45
|
||||||
|
#define FX_MODE_FIRE_FLICKER_SOFT 46
|
||||||
|
#define FX_MODE_INDIVIDUAL_CONTROL 47
|
||||||
|
|
||||||
|
class WS2812FX : public Adafruit_NeoPixel {
|
||||||
|
|
||||||
|
typedef void (WS2812FX::*mode_ptr)(void);
|
||||||
|
|
||||||
|
public:
|
||||||
|
|
||||||
|
WS2812FX(uint16_t n, uint8_t p, neoPixelType t) : Adafruit_NeoPixel(n, p, t) {
|
||||||
|
_mode[FX_MODE_STATIC] = &WS2812FX::mode_static;
|
||||||
|
_mode[FX_MODE_BLINK] = &WS2812FX::mode_blink;
|
||||||
|
_mode[FX_MODE_BREATH] = &WS2812FX::mode_breath;
|
||||||
|
_mode[FX_MODE_COLOR_WIPE] = &WS2812FX::mode_color_wipe;
|
||||||
|
_mode[FX_MODE_COLOR_WIPE_RANDOM] = &WS2812FX::mode_color_wipe_random;
|
||||||
|
_mode[FX_MODE_RANDOM_COLOR] = &WS2812FX::mode_random_color;
|
||||||
|
_mode[FX_MODE_SINGLE_DYNAMIC] = &WS2812FX::mode_single_dynamic;
|
||||||
|
_mode[FX_MODE_MULTI_DYNAMIC] = &WS2812FX::mode_multi_dynamic;
|
||||||
|
_mode[FX_MODE_RAINBOW] = &WS2812FX::mode_rainbow;
|
||||||
|
_mode[FX_MODE_RAINBOW_CYCLE] = &WS2812FX::mode_rainbow_cycle;
|
||||||
|
_mode[FX_MODE_SCAN] = &WS2812FX::mode_scan;
|
||||||
|
_mode[FX_MODE_DUAL_SCAN] = &WS2812FX::mode_dual_scan;
|
||||||
|
_mode[FX_MODE_FADE] = &WS2812FX::mode_fade;
|
||||||
|
_mode[FX_MODE_THEATER_CHASE] = &WS2812FX::mode_theater_chase;
|
||||||
|
_mode[FX_MODE_THEATER_CHASE_RAINBOW] = &WS2812FX::mode_theater_chase_rainbow;
|
||||||
|
_mode[FX_MODE_RUNNING_LIGHTS] = &WS2812FX::mode_running_lights;
|
||||||
|
_mode[FX_MODE_TWINKLE] = &WS2812FX::mode_twinkle;
|
||||||
|
_mode[FX_MODE_TWINKLE_RANDOM] = &WS2812FX::mode_twinkle_random;
|
||||||
|
_mode[FX_MODE_TWINKLE_FADE] = &WS2812FX::mode_twinkle_fade;
|
||||||
|
_mode[FX_MODE_TWINKLE_FADE_RANDOM] = &WS2812FX::mode_twinkle_fade_random;
|
||||||
|
_mode[FX_MODE_SPARKLE] = &WS2812FX::mode_sparkle;
|
||||||
|
_mode[FX_MODE_FLASH_SPARKLE] = &WS2812FX::mode_flash_sparkle;
|
||||||
|
_mode[FX_MODE_HYPER_SPARKLE] = &WS2812FX::mode_hyper_sparkle;
|
||||||
|
_mode[FX_MODE_STROBE] = &WS2812FX::mode_strobe;
|
||||||
|
_mode[FX_MODE_STROBE_RAINBOW] = &WS2812FX::mode_strobe_rainbow;
|
||||||
|
_mode[FX_MODE_MULTI_STROBE] = &WS2812FX::mode_multi_strobe;
|
||||||
|
_mode[FX_MODE_BLINK_RAINBOW] = &WS2812FX::mode_blink_rainbow;
|
||||||
|
_mode[FX_MODE_CHASE_WHITE] = &WS2812FX::mode_chase_white;
|
||||||
|
_mode[FX_MODE_CHASE_COLOR] = &WS2812FX::mode_chase_color;
|
||||||
|
_mode[FX_MODE_CHASE_RANDOM] = &WS2812FX::mode_chase_random;
|
||||||
|
_mode[FX_MODE_CHASE_RAINBOW] = &WS2812FX::mode_chase_rainbow;
|
||||||
|
_mode[FX_MODE_CHASE_FLASH] = &WS2812FX::mode_chase_flash;
|
||||||
|
_mode[FX_MODE_CHASE_FLASH_RANDOM] = &WS2812FX::mode_chase_flash_random;
|
||||||
|
_mode[FX_MODE_CHASE_RAINBOW_WHITE] = &WS2812FX::mode_chase_rainbow_white;
|
||||||
|
_mode[FX_MODE_CHASE_BLACKOUT] = &WS2812FX::mode_chase_blackout;
|
||||||
|
_mode[FX_MODE_CHASE_BLACKOUT_RAINBOW]= &WS2812FX::mode_chase_blackout_rainbow;
|
||||||
|
_mode[FX_MODE_COLOR_SWEEP_RANDOM] = &WS2812FX::mode_color_sweep_random;
|
||||||
|
_mode[FX_MODE_RUNNING_COLOR] = &WS2812FX::mode_running_color;
|
||||||
|
_mode[FX_MODE_RUNNING_RED_BLUE] = &WS2812FX::mode_running_red_blue;
|
||||||
|
_mode[FX_MODE_RUNNING_RANDOM] = &WS2812FX::mode_running_random;
|
||||||
|
_mode[FX_MODE_LARSON_SCANNER] = &WS2812FX::mode_larson_scanner;
|
||||||
|
_mode[FX_MODE_COMET] = &WS2812FX::mode_comet;
|
||||||
|
_mode[FX_MODE_FIREWORKS] = &WS2812FX::mode_fireworks;
|
||||||
|
_mode[FX_MODE_FIREWORKS_RANDOM] = &WS2812FX::mode_fireworks_random;
|
||||||
|
_mode[FX_MODE_MERRY_CHRISTMAS] = &WS2812FX::mode_merry_christmas;
|
||||||
|
_mode[FX_MODE_FIRE_FLICKER] = &WS2812FX::mode_fire_flicker;
|
||||||
|
_mode[FX_MODE_FIRE_FLICKER_SOFT] = &WS2812FX::mode_fire_flicker_soft;
|
||||||
|
_mode[FX_MODE_INDIVIDUAL_CONTROL] = &WS2812FX::mode_individual_control;
|
||||||
|
|
||||||
|
_name[FX_MODE_STATIC] = "Static";
|
||||||
|
_name[FX_MODE_BLINK] = "Blink";
|
||||||
|
_name[FX_MODE_BREATH] = "Breath";
|
||||||
|
_name[FX_MODE_COLOR_WIPE] = "Color Wipe";
|
||||||
|
_name[FX_MODE_COLOR_WIPE_RANDOM] = "Color Wipe Random";
|
||||||
|
_name[FX_MODE_RANDOM_COLOR] = "Random Color";
|
||||||
|
_name[FX_MODE_SINGLE_DYNAMIC] = "Single Dynamic";
|
||||||
|
_name[FX_MODE_MULTI_DYNAMIC] = "Multi Dynamic";
|
||||||
|
_name[FX_MODE_RAINBOW] = "Rainbow";
|
||||||
|
_name[FX_MODE_RAINBOW_CYCLE] = "Rainbow Cycle";
|
||||||
|
_name[FX_MODE_SCAN] = "Scan";
|
||||||
|
_name[FX_MODE_DUAL_SCAN] = "Dual Scan";
|
||||||
|
_name[FX_MODE_FADE] = "Fade";
|
||||||
|
_name[FX_MODE_THEATER_CHASE] = "Theater Chase";
|
||||||
|
_name[FX_MODE_THEATER_CHASE_RAINBOW] = "Theater Chase Rainbow";
|
||||||
|
_name[FX_MODE_RUNNING_LIGHTS] = "Running Lights";
|
||||||
|
_name[FX_MODE_TWINKLE] = "Twinkle";
|
||||||
|
_name[FX_MODE_TWINKLE_RANDOM] = "Twinkle Random";
|
||||||
|
_name[FX_MODE_TWINKLE_FADE] = "Twinkle Fade";
|
||||||
|
_name[FX_MODE_TWINKLE_FADE_RANDOM] = "Twinkle Fade Random";
|
||||||
|
_name[FX_MODE_SPARKLE] = "Sparkle";
|
||||||
|
_name[FX_MODE_FLASH_SPARKLE] = "Flash Sparkle";
|
||||||
|
_name[FX_MODE_HYPER_SPARKLE] = "Hyper Sparkle";
|
||||||
|
_name[FX_MODE_STROBE] = "Strobe";
|
||||||
|
_name[FX_MODE_STROBE_RAINBOW] = "Strobe Rainbow";
|
||||||
|
_name[FX_MODE_MULTI_STROBE] = "Multi Strobe";
|
||||||
|
_name[FX_MODE_BLINK_RAINBOW] = "Blink Rainbow";
|
||||||
|
_name[FX_MODE_CHASE_WHITE] = "Chase White";
|
||||||
|
_name[FX_MODE_CHASE_COLOR] = "Chase Color";
|
||||||
|
_name[FX_MODE_CHASE_RANDOM] = "Chase Random";
|
||||||
|
_name[FX_MODE_CHASE_RAINBOW] = "Chase Rainbow";
|
||||||
|
_name[FX_MODE_CHASE_FLASH] = "Chase Flash";
|
||||||
|
_name[FX_MODE_CHASE_FLASH_RANDOM] = "Chase Flash Random";
|
||||||
|
_name[FX_MODE_CHASE_RAINBOW_WHITE] = "Chase Rainbow White";
|
||||||
|
_name[FX_MODE_CHASE_BLACKOUT] = "Chase Blackout";
|
||||||
|
_name[FX_MODE_CHASE_BLACKOUT_RAINBOW]= "Chase Blackout Rainbow";
|
||||||
|
_name[FX_MODE_COLOR_SWEEP_RANDOM] = "Color Sweep Random";
|
||||||
|
_name[FX_MODE_RUNNING_COLOR] = "Running Color";
|
||||||
|
_name[FX_MODE_RUNNING_RED_BLUE] = "Running Red Blue";
|
||||||
|
_name[FX_MODE_RUNNING_RANDOM] = "Running Random";
|
||||||
|
_name[FX_MODE_LARSON_SCANNER] = "Larson Scanner";
|
||||||
|
_name[FX_MODE_COMET] = "Comet";
|
||||||
|
_name[FX_MODE_FIREWORKS] = "Fireworks";
|
||||||
|
_name[FX_MODE_FIREWORKS_RANDOM] = "Fireworks Random";
|
||||||
|
_name[FX_MODE_MERRY_CHRISTMAS] = "Merry Christmas";
|
||||||
|
_name[FX_MODE_FIRE_FLICKER] = "Fire Flicker";
|
||||||
|
_name[FX_MODE_FIRE_FLICKER_SOFT] = "Fire Flicker (soft)";
|
||||||
|
_name[FX_MODE_INDIVIDUAL_CONTROL] = "Individual Pixel Control";
|
||||||
|
|
||||||
|
_mode_index = DEFAULT_MODE;
|
||||||
|
_speed = DEFAULT_SPEED;
|
||||||
|
_brightness = DEFAULT_BRIGHTNESS;
|
||||||
|
_running = false;
|
||||||
|
_led_count = n;
|
||||||
|
_mode_last_call_time = 0;
|
||||||
|
_mode_delay = 0;
|
||||||
|
_color = DEFAULT_COLOR;
|
||||||
|
_mode_color = DEFAULT_COLOR;
|
||||||
|
_counter_mode_call = 0;
|
||||||
|
_counter_mode_step = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
init(void),
|
||||||
|
service(void),
|
||||||
|
start(void),
|
||||||
|
stop(void),
|
||||||
|
setMode(uint8_t m),
|
||||||
|
setSpeed(uint8_t s),
|
||||||
|
increaseSpeed(uint8_t s),
|
||||||
|
decreaseSpeed(uint8_t s),
|
||||||
|
setColor(uint8_t r, uint8_t g, uint8_t b),
|
||||||
|
setColor(uint32_t c),
|
||||||
|
setBrightness(uint8_t b),
|
||||||
|
increaseBrightness(uint8_t s),
|
||||||
|
decreaseBrightness(uint8_t s),
|
||||||
|
setIndividual(int i),
|
||||||
|
setRange(int i, int i2);
|
||||||
|
|
||||||
|
boolean
|
||||||
|
isRunning(void);
|
||||||
|
|
||||||
|
uint8_t
|
||||||
|
getMode(void),
|
||||||
|
getSpeed(void),
|
||||||
|
getBrightness(void),
|
||||||
|
getModeCount(void);
|
||||||
|
|
||||||
|
uint32_t
|
||||||
|
getColor(void);
|
||||||
|
|
||||||
|
const char*
|
||||||
|
getModeName(uint8_t m);
|
||||||
|
|
||||||
|
private:
|
||||||
|
|
||||||
|
void
|
||||||
|
strip_off(void),
|
||||||
|
mode_static(void),
|
||||||
|
mode_blink(void),
|
||||||
|
mode_color_wipe(void),
|
||||||
|
mode_color_wipe_random(void),
|
||||||
|
mode_random_color(void),
|
||||||
|
mode_single_dynamic(void),
|
||||||
|
mode_multi_dynamic(void),
|
||||||
|
mode_breath(void),
|
||||||
|
mode_fade(void),
|
||||||
|
mode_scan(void),
|
||||||
|
mode_dual_scan(void),
|
||||||
|
mode_theater_chase(void),
|
||||||
|
mode_theater_chase_rainbow(void),
|
||||||
|
mode_rainbow(void),
|
||||||
|
mode_rainbow_cycle(void),
|
||||||
|
mode_running_lights(void),
|
||||||
|
mode_twinkle(void),
|
||||||
|
mode_twinkle_random(void),
|
||||||
|
mode_twinkle_fade(void),
|
||||||
|
mode_twinkle_fade_random(void),
|
||||||
|
mode_sparkle(void),
|
||||||
|
mode_flash_sparkle(void),
|
||||||
|
mode_hyper_sparkle(void),
|
||||||
|
mode_strobe(void),
|
||||||
|
mode_strobe_rainbow(void),
|
||||||
|
mode_multi_strobe(void),
|
||||||
|
mode_blink_rainbow(void),
|
||||||
|
mode_chase_white(void),
|
||||||
|
mode_chase_color(void),
|
||||||
|
mode_chase_random(void),
|
||||||
|
mode_chase_rainbow(void),
|
||||||
|
mode_chase_flash(void),
|
||||||
|
mode_chase_flash_random(void),
|
||||||
|
mode_chase_rainbow_white(void),
|
||||||
|
mode_chase_blackout(void),
|
||||||
|
mode_chase_blackout_rainbow(void),
|
||||||
|
mode_color_sweep_random(void),
|
||||||
|
mode_running_color(void),
|
||||||
|
mode_running_red_blue(void),
|
||||||
|
mode_running_random(void),
|
||||||
|
mode_larson_scanner(void),
|
||||||
|
mode_comet(void),
|
||||||
|
mode_fireworks(void),
|
||||||
|
mode_fireworks_random(void),
|
||||||
|
mode_merry_christmas(void),
|
||||||
|
mode_fire_flicker(void),
|
||||||
|
mode_fire_flicker_soft(void),
|
||||||
|
mode_fire_flicker_int(int),
|
||||||
|
mode_individual_control(void);
|
||||||
|
|
||||||
|
boolean
|
||||||
|
_running;
|
||||||
|
|
||||||
|
uint8_t
|
||||||
|
get_random_wheel_index(uint8_t),
|
||||||
|
_mode_index,
|
||||||
|
_speed,
|
||||||
|
_brightness;
|
||||||
|
|
||||||
|
uint16_t
|
||||||
|
_led_count;
|
||||||
|
|
||||||
|
uint32_t
|
||||||
|
color_wheel(uint8_t),
|
||||||
|
_color,
|
||||||
|
_counter_mode_call,
|
||||||
|
_counter_mode_step,
|
||||||
|
_mode_color,
|
||||||
|
_mode_delay;
|
||||||
|
|
||||||
|
unsigned long
|
||||||
|
_mode_last_call_time;
|
||||||
|
|
||||||
|
const char*
|
||||||
|
_name[MODE_COUNT];
|
||||||
|
|
||||||
|
mode_ptr
|
||||||
|
_mode[MODE_COUNT];
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif
|
@ -5,7 +5,7 @@
|
|||||||
#include <ESP8266mDNS.h>
|
#include <ESP8266mDNS.h>
|
||||||
#include <EEPROM.h>
|
#include <EEPROM.h>
|
||||||
#include <Hash.h>
|
#include <Hash.h>
|
||||||
#include <WS2812FX.h>
|
#include "WS2812FX.h"
|
||||||
#include <FS.h>
|
#include <FS.h>
|
||||||
#include <WiFiUDP.h>
|
#include <WiFiUDP.h>
|
||||||
|
|
||||||
@ -15,7 +15,7 @@
|
|||||||
* @author Christian Schwinne
|
* @author Christian Schwinne
|
||||||
*/
|
*/
|
||||||
//Hardware-settings (only changeble via code)
|
//Hardware-settings (only changeble via code)
|
||||||
uint8_t led_amount = 9;
|
uint8_t led_amount = 84;
|
||||||
uint8_t buttonPin = 0; //needs pull-up
|
uint8_t buttonPin = 0; //needs pull-up
|
||||||
//Default CONFIG
|
//Default CONFIG
|
||||||
String serverDescription = "WLED 0.3pd";
|
String serverDescription = "WLED 0.3pd";
|
||||||
|
@ -176,15 +176,35 @@ boolean handleSet(String req)
|
|||||||
}
|
}
|
||||||
pos = req.indexOf("FX=");
|
pos = req.indexOf("FX=");
|
||||||
if (pos > 0) {
|
if (pos > 0) {
|
||||||
effectCurrent = req.substring(pos + 3).toInt();
|
if (effectCurrent != req.substring(pos + 3).toInt())
|
||||||
strip.setMode(effectCurrent);
|
{
|
||||||
effectUpdated = true;
|
effectCurrent = req.substring(pos + 3).toInt();
|
||||||
|
strip.setMode(effectCurrent);
|
||||||
|
effectUpdated = true;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
pos = req.indexOf("XS=");
|
pos = req.indexOf("XS=");
|
||||||
if (pos > 0) {
|
if (pos > 0) {
|
||||||
effectSpeed = req.substring(pos + 3).toInt();
|
if (effectSpeed != req.substring(pos + 3).toInt())
|
||||||
strip.setSpeed(effectSpeed);
|
{
|
||||||
effectUpdated = true;
|
effectSpeed = req.substring(pos + 3).toInt();
|
||||||
|
strip.setSpeed(effectSpeed);
|
||||||
|
effectUpdated = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
pos = req.indexOf("I=");
|
||||||
|
if (pos > 0){
|
||||||
|
if (strip.getMode() != 47) strip.setMode(47);
|
||||||
|
effectCurrent = 47;
|
||||||
|
int index = req.substring(pos + 2).toInt();
|
||||||
|
pos = req.indexOf("I2=");
|
||||||
|
if (pos > 0){
|
||||||
|
int index2 = req.substring(pos + 3).toInt();
|
||||||
|
strip.setRange(index, index2);
|
||||||
|
} else
|
||||||
|
{
|
||||||
|
strip.setIndividual(index);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
if (req.indexOf("NS=") > 0)
|
if (req.indexOf("NS=") > 0)
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user