Compare commits
42 Commits
Author | SHA1 | Date | |
---|---|---|---|
88c6dc6e51 | |||
40c9ac4536 | |||
1e9861d6d0 | |||
f377ae2742 | |||
e205f8bece | |||
dc07ab11e4 | |||
b83e48016c | |||
1b9535651a | |||
5c9ab4f749 | |||
0db34d27ef | |||
b31c73e217 | |||
85d99b6a7f | |||
0c16edc65c | |||
1edb9517cb | |||
2d08fa5b96 | |||
94700bf4d3 | |||
cec7952757 | |||
3376514e01 | |||
e57869202e | |||
757e3b2fd8 | |||
e2d546bf8c | |||
cdb02c9bbf | |||
04103b80a3 | |||
669acec2c8 | |||
813970de78 | |||
83cc76340a | |||
f58c2b3dbd | |||
a974f0c481 | |||
432fbb95d9 | |||
350feed191 | |||
410186e6a5 | |||
c17cea3426 | |||
407fd536c2 | |||
020b0b0e43 | |||
681c29a877 | |||
9bc7b7a5e7 | |||
e28346a6ee | |||
95e5f27caf | |||
608a7827d2 | |||
f49ca2d1f9 | |||
1e9b486cfd | |||
f5702fe80f |
3
.vs/ProjectSettings.json
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
{
|
||||||
|
"CurrentProjectSetting": "Visual Micro"
|
||||||
|
}
|
9
.vs/VSWorkspaceState.json
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
{
|
||||||
|
"ExpandedNodes": [
|
||||||
|
"",
|
||||||
|
"\\data",
|
||||||
|
"\\data\\images"
|
||||||
|
],
|
||||||
|
"SelectedNode": "\\data\\index.htm",
|
||||||
|
"PreviewInSolutionExplorer": false
|
||||||
|
}
|
113
.vs/__vm/.vsarduino.h
Normal file
@ -0,0 +1,113 @@
|
|||||||
|
/*
|
||||||
|
Editor: https://www.visualmicro.com/
|
||||||
|
visual micro and the arduino ide ignore this code during compilation. this code is automatically maintained by visualmicro, manual changes to this file will be overwritten
|
||||||
|
the contents of the Visual Micro sketch sub folder can be deleted prior to publishing a project
|
||||||
|
all non-arduino files created by visual micro and all visual studio project or solution files can be freely deleted and are not required to compile a sketch (do not delete your own code!).
|
||||||
|
note: debugger breakpoints are stored in '.sln' or '.asln' files, knowledge of last uploaded breakpoints is stored in the upload.vmps.xml file. Both files are required to continue a previous debug session without needing to compile and upload again
|
||||||
|
|
||||||
|
Hardware: WeMos D1 R2 & mini, Platform=esp8266, Package=esp8266
|
||||||
|
*/
|
||||||
|
|
||||||
|
#if defined(_VMICRO_INTELLISENSE)
|
||||||
|
|
||||||
|
#ifndef _VSARDUINO_H_
|
||||||
|
#define _VSARDUINO_H_
|
||||||
|
#define __ESP8266_ESp8266__
|
||||||
|
#define __ESP8266_ESP8266__
|
||||||
|
#define __ets__
|
||||||
|
#define ICACHE_FLASH
|
||||||
|
#define F_CPU 80000000L
|
||||||
|
#define LWIP_OPEN_SRC
|
||||||
|
#define TCP_MSS 536
|
||||||
|
#define ARDUINO 10807
|
||||||
|
#define ARDUINO_ESP8266_WEMOS_D1MINI
|
||||||
|
#define ARDUINO_ARCH_ESP8266
|
||||||
|
#define ESP8266
|
||||||
|
#define __cplusplus 201103L
|
||||||
|
#undef __cplusplus
|
||||||
|
#define __cplusplus 201103L
|
||||||
|
#define __STDC__
|
||||||
|
#define __ARM__
|
||||||
|
#define __arm__
|
||||||
|
#define __inline__
|
||||||
|
#define __asm__(x)
|
||||||
|
#define __asm__
|
||||||
|
#define __extension__
|
||||||
|
#define __ATTR_PURE__
|
||||||
|
#define __ATTR_CONST__
|
||||||
|
#define __volatile__
|
||||||
|
|
||||||
|
|
||||||
|
#define __ASM
|
||||||
|
#define __INLINE
|
||||||
|
#define __attribute__(noinline)
|
||||||
|
|
||||||
|
//#define _STD_BEGIN
|
||||||
|
//#define EMIT
|
||||||
|
#define WARNING
|
||||||
|
#define _Lockit
|
||||||
|
#define __CLR_OR_THIS_CALL
|
||||||
|
#define C4005
|
||||||
|
#define _NEW
|
||||||
|
|
||||||
|
//typedef int uint8_t;
|
||||||
|
//#define __ARMCC_VERSION 400678
|
||||||
|
//#define PROGMEM
|
||||||
|
//#define string_literal
|
||||||
|
//
|
||||||
|
//#define prog_void
|
||||||
|
//#define PGM_VOID_P int
|
||||||
|
//
|
||||||
|
|
||||||
|
typedef int _read;
|
||||||
|
typedef int _seek;
|
||||||
|
typedef int _write;
|
||||||
|
typedef int _close;
|
||||||
|
typedef int __cleanup;
|
||||||
|
|
||||||
|
//#define inline
|
||||||
|
|
||||||
|
#define __builtin_clz
|
||||||
|
#define __builtin_clzl
|
||||||
|
#define __builtin_clzll
|
||||||
|
#define __builtin_labs
|
||||||
|
#define __builtin_va_list
|
||||||
|
typedef int __gnuc_va_list;
|
||||||
|
|
||||||
|
#define __ATOMIC_ACQ_REL
|
||||||
|
|
||||||
|
#define __CHAR_BIT__
|
||||||
|
#define _EXFUN()
|
||||||
|
|
||||||
|
typedef unsigned char byte;
|
||||||
|
extern "C" void __cxa_pure_virtual() {;}
|
||||||
|
|
||||||
|
|
||||||
|
typedef long __INTPTR_TYPE__ ;
|
||||||
|
typedef long __UINTPTR_TYPE__ ;
|
||||||
|
typedef long __SIZE_TYPE__ ;
|
||||||
|
typedef long __PTRDIFF_TYPE__;
|
||||||
|
|
||||||
|
|
||||||
|
#include "new"
|
||||||
|
#include "Esp.h"
|
||||||
|
|
||||||
|
|
||||||
|
#include <arduino.h>
|
||||||
|
#include <pins_arduino.h>
|
||||||
|
|
||||||
|
#include "..\generic\Common.h"
|
||||||
|
#include "..\generic\pins_arduino.h"
|
||||||
|
|
||||||
|
#undef F
|
||||||
|
#define F(string_literal) ((const PROGMEM char *)(string_literal))
|
||||||
|
#undef PSTR
|
||||||
|
#define PSTR(string_literal) ((const PROGMEM char *)(string_literal))
|
||||||
|
//current vc++ does not understand this syntax so use older arduino example for intellisense
|
||||||
|
//todo:move to the new clang/gcc project types.
|
||||||
|
#define interrupts() sei()
|
||||||
|
#define noInterrupts() cli()
|
||||||
|
|
||||||
|
#include "esp8266-fastled-webserver.ino"
|
||||||
|
#endif
|
||||||
|
#endif
|
1025
.vs/config/applicationhost.config
Normal file
BIN
.vs/esp8266-fastled-webserver/v15/.suo
Normal file
BIN
.vs/slnx.sqlite
Normal file
47
CppProperties.json
Normal file
@ -0,0 +1,47 @@
|
|||||||
|
{
|
||||||
|
"configurations": [
|
||||||
|
{
|
||||||
|
"name": "Visual Micro",
|
||||||
|
"intelliSenseMode": "msvc-x64",
|
||||||
|
"includePath": [
|
||||||
|
"${projectRoot}..\\esp8266-fastled-webserver",
|
||||||
|
"D:\\Music\\Documents\\Arduino\\libraries\\FastLED",
|
||||||
|
"${projectRoot}..\\..\\..\\..\\AppData\\Local\\arduino15\\packages\\esp8266\\hardware\\esp8266\\2.4.1\\libraries\\ESP8266WiFi\\src",
|
||||||
|
"${projectRoot}..\\..\\..\\..\\AppData\\Local\\arduino15\\packages\\esp8266\\hardware\\esp8266\\2.4.1\\libraries\\ESP8266WebServer\\src",
|
||||||
|
"${projectRoot}..\\..\\..\\..\\AppData\\Local\\arduino15\\packages\\esp8266\\hardware\\esp8266\\2.4.1\\libraries\\ESP8266HTTPUpdateServer\\src",
|
||||||
|
"${projectRoot}..\\..\\..\\..\\AppData\\Local\\arduino15\\packages\\esp8266\\hardware\\esp8266\\2.4.1\\libraries\\EEPROM",
|
||||||
|
"S:\\Software\\Arduino\\libraries",
|
||||||
|
"${projectRoot}..\\..\\..\\..\\AppData\\Local\\arduino15\\packages\\esp8266\\hardware\\esp8266\\2.4.1\\libraries",
|
||||||
|
"D:\\Music\\Documents\\Arduino\\libraries",
|
||||||
|
"${projectRoot}..\\..\\..\\..\\AppData\\Local\\arduino15\\packages\\esp8266\\hardware\\esp8266\\2.4.1\\cores\\esp8266",
|
||||||
|
"${projectRoot}..\\..\\..\\..\\AppData\\Local\\arduino15\\packages\\esp8266\\hardware\\esp8266\\2.4.1\\cores\\esp8266\\libb64",
|
||||||
|
"${projectRoot}..\\..\\..\\..\\AppData\\Local\\arduino15\\packages\\esp8266\\hardware\\esp8266\\2.4.1\\cores\\esp8266\\spiffs",
|
||||||
|
"${projectRoot}..\\..\\..\\..\\AppData\\Local\\arduino15\\packages\\esp8266\\hardware\\esp8266\\2.4.1\\cores\\esp8266\\umm_malloc",
|
||||||
|
"${projectRoot}..\\..\\..\\..\\AppData\\Local\\arduino15\\packages\\esp8266\\hardware\\esp8266\\2.4.1\\variants\\d1_mini",
|
||||||
|
"${projectRoot}..\\..\\..\\..\\AppData\\Local\\arduino15\\packages\\esp8266\\hardware\\esp8266\\2.4.1\\tools\\sdk\\include",
|
||||||
|
"${projectRoot}..\\..\\..\\..\\AppData\\Local\\arduino15\\packages\\esp8266\\hardware\\esp8266\\2.4.1\\tools\\sdk\\lwip2\\include",
|
||||||
|
"${projectRoot}..\\..\\..\\..\\AppData\\Local\\arduino15\\packages\\esp8266\\hardware\\esp8266\\2.4.1\\tools\\sdk\\libc\\xtensa-lx106-elf\\include",
|
||||||
|
"${projectRoot}..\\..\\..\\..\\AppData\\Local\\arduino15\\packages\\esp8266\\tools\\xtensa-lx106-elf-gcc\\1.20.0-26-gb404fb9-2\\xtensa-lx106-elf\\include\\c++\\4.8.2",
|
||||||
|
"${projectRoot}..\\..\\..\\..\\AppData\\Local\\arduino15\\packages\\esp8266\\tools\\xtensa-lx106-elf-gcc\\1.20.0-26-gb404fb9-2\\xtensa-lx106-elf\\include\\c++\\4.8.2\\xtensa-lx106-elf",
|
||||||
|
"${projectRoot}..\\..\\..\\..\\AppData\\Local\\arduino15\\packages\\esp8266\\tools\\xtensa-lx106-elf-gcc\\1.20.0-26-gb404fb9-2\\xtensa-lx106-elf\\include",
|
||||||
|
"${projectRoot}..\\..\\..\\..\\AppData\\Local\\arduino15\\packages\\esp8266\\tools\\xtensa-lx106-elf-gcc\\1.20.0-26-gb404fb9-2\\lib\\gcc\\xtensa-lx106-elf\\4.8.2\\include",
|
||||||
|
"${projectRoot}..\\..\\..\\..\\AppData\\Local\\arduino15\\packages\\esp8266\\hardware\\esp8266\\2.4.1\\tools\\sdk\\include"
|
||||||
|
],
|
||||||
|
"defines": [
|
||||||
|
"__ESP8266_ESp8266__",
|
||||||
|
"__ESP8266_ESP8266__",
|
||||||
|
"__ets__",
|
||||||
|
"ICACHE_FLASH",
|
||||||
|
"F_CPU=80000000L",
|
||||||
|
"LWIP_OPEN_SRC",
|
||||||
|
"TCP_MSS=536",
|
||||||
|
"ARDUINO=10807",
|
||||||
|
"ARDUINO_ESP8266_WEMOS_D1MINI",
|
||||||
|
"ARDUINO_ARCH_ESP8266",
|
||||||
|
"ESP8266",
|
||||||
|
"__cplusplus=201103L",
|
||||||
|
"_VMICRO_INTELLISENSE"
|
||||||
|
]
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
11
Fields.h
@ -81,6 +81,14 @@ String getAutoplayDuration() {
|
|||||||
return String(autoplayDuration);
|
return String(autoplayDuration);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
String getAllLeafs() {
|
||||||
|
return String(allLeafs);
|
||||||
|
}
|
||||||
|
|
||||||
|
String getSelectedLeaf() {
|
||||||
|
return String(selectedLeaf);
|
||||||
|
}
|
||||||
|
|
||||||
String getSolidColor() {
|
String getSolidColor() {
|
||||||
return String(solidColor.r) + "," + String(solidColor.g) + "," + String(solidColor.b);
|
return String(solidColor.r) + "," + String(solidColor.g) + "," + String(solidColor.b);
|
||||||
}
|
}
|
||||||
@ -114,6 +122,9 @@ FieldList fields = {
|
|||||||
{ "autoplay", "Autoplay", SectionFieldType },
|
{ "autoplay", "Autoplay", SectionFieldType },
|
||||||
{ "autoplay", "Autoplay", BooleanFieldType, 0, 1, getAutoplay },
|
{ "autoplay", "Autoplay", BooleanFieldType, 0, 1, getAutoplay },
|
||||||
{ "autoplayDuration", "Autoplay Duration", NumberFieldType, 0, 255, getAutoplayDuration },
|
{ "autoplayDuration", "Autoplay Duration", NumberFieldType, 0, 255, getAutoplayDuration },
|
||||||
|
{ "allLeafs", "Color Leafs", SectionFieldType },
|
||||||
|
{ "allLeafs", "Color All Leafs", BooleanFieldType, 0, 1, getAllLeafs },
|
||||||
|
{ "selectedLeaf", "Select Leaf to Color", NumberFieldType, 1, LEAFCOUNT, getSelectedLeaf },
|
||||||
{ "solidColor", "Solid Color", SectionFieldType },
|
{ "solidColor", "Solid Color", SectionFieldType },
|
||||||
{ "solidColor", "Color", ColorFieldType, 0, 255, getSolidColor },
|
{ "solidColor", "Color", ColorFieldType, 0, 255, getSolidColor },
|
||||||
{ "fire", "Fire & Water", SectionFieldType },
|
{ "fire", "Fire & Water", SectionFieldType },
|
||||||
|
@ -10,460 +10,493 @@
|
|||||||
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
||||||
// Size: 16 bytes of program space.
|
// Size: 16 bytes of program space.
|
||||||
|
|
||||||
DEFINE_GRADIENT_PALETTE( ib_jul01_gp ) {
|
DEFINE_GRADIENT_PALETTE(ib_jul01_gp) {
|
||||||
0, 194, 1, 1,
|
0, 194, 1, 1,
|
||||||
94, 1, 29, 18,
|
94, 1, 29, 18,
|
||||||
132, 57,131, 28,
|
132, 57, 131, 28,
|
||||||
255, 113, 1, 1};
|
255, 113, 1, 1
|
||||||
|
};
|
||||||
|
|
||||||
// Gradient palette "es_vintage_57_gp", originally from
|
// Gradient palette "es_vintage_57_gp", originally from
|
||||||
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/es/vintage/tn/es_vintage_57.png.index.html
|
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/es/vintage/tn/es_vintage_57.png.index.html
|
||||||
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
||||||
// Size: 20 bytes of program space.
|
// Size: 20 bytes of program space.
|
||||||
|
|
||||||
DEFINE_GRADIENT_PALETTE( es_vintage_57_gp ) {
|
DEFINE_GRADIENT_PALETTE(es_vintage_57_gp) {
|
||||||
0, 2, 1, 1,
|
0, 2, 1, 1,
|
||||||
53, 18, 1, 0,
|
53, 18, 1, 0,
|
||||||
104, 69, 29, 1,
|
104, 69, 29, 1,
|
||||||
153, 167,135, 10,
|
153, 167, 135, 10,
|
||||||
255, 46, 56, 4};
|
255, 46, 56, 4
|
||||||
|
};
|
||||||
|
|
||||||
// Gradient palette "es_vintage_01_gp", originally from
|
// Gradient palette "es_vintage_01_gp", originally from
|
||||||
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/es/vintage/tn/es_vintage_01.png.index.html
|
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/es/vintage/tn/es_vintage_01.png.index.html
|
||||||
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
||||||
// Size: 32 bytes of program space.
|
// Size: 32 bytes of program space.
|
||||||
|
|
||||||
DEFINE_GRADIENT_PALETTE( es_vintage_01_gp ) {
|
DEFINE_GRADIENT_PALETTE(es_vintage_01_gp) {
|
||||||
0, 4, 1, 1,
|
0, 4, 1, 1,
|
||||||
51, 16, 0, 1,
|
51, 16, 0, 1,
|
||||||
76, 97,104, 3,
|
76, 97, 104, 3,
|
||||||
101, 255,131, 19,
|
101, 255, 131, 19,
|
||||||
127, 67, 9, 4,
|
127, 67, 9, 4,
|
||||||
153, 16, 0, 1,
|
153, 16, 0, 1,
|
||||||
229, 4, 1, 1,
|
229, 4, 1, 1,
|
||||||
255, 4, 1, 1};
|
255, 4, 1, 1
|
||||||
|
};
|
||||||
|
|
||||||
// Gradient palette "es_rivendell_15_gp", originally from
|
// Gradient palette "es_rivendell_15_gp", originally from
|
||||||
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/es/rivendell/tn/es_rivendell_15.png.index.html
|
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/es/rivendell/tn/es_rivendell_15.png.index.html
|
||||||
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
||||||
// Size: 20 bytes of program space.
|
// Size: 20 bytes of program space.
|
||||||
|
|
||||||
DEFINE_GRADIENT_PALETTE( es_rivendell_15_gp ) {
|
DEFINE_GRADIENT_PALETTE(es_rivendell_15_gp) {
|
||||||
0, 1, 14, 5,
|
0, 1, 14, 5,
|
||||||
101, 16, 36, 14,
|
101, 16, 36, 14,
|
||||||
165, 56, 68, 30,
|
165, 56, 68, 30,
|
||||||
242, 150,156, 99,
|
242, 150, 156, 99,
|
||||||
255, 150,156, 99};
|
255, 150, 156, 99
|
||||||
|
};
|
||||||
|
|
||||||
// Gradient palette "rgi_15_gp", originally from
|
// Gradient palette "rgi_15_gp", originally from
|
||||||
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/ds/rgi/tn/rgi_15.png.index.html
|
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/ds/rgi/tn/rgi_15.png.index.html
|
||||||
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
||||||
// Size: 36 bytes of program space.
|
// Size: 36 bytes of program space.
|
||||||
|
|
||||||
DEFINE_GRADIENT_PALETTE( rgi_15_gp ) {
|
DEFINE_GRADIENT_PALETTE(rgi_15_gp) {
|
||||||
0, 4, 1, 31,
|
0, 4, 1, 31,
|
||||||
31, 55, 1, 16,
|
31, 55, 1, 16,
|
||||||
63, 197, 3, 7,
|
63, 197, 3, 7,
|
||||||
95, 59, 2, 17,
|
95, 59, 2, 17,
|
||||||
127, 6, 2, 34,
|
127, 6, 2, 34,
|
||||||
159, 39, 6, 33,
|
159, 39, 6, 33,
|
||||||
191, 112, 13, 32,
|
191, 112, 13, 32,
|
||||||
223, 56, 9, 35,
|
223, 56, 9, 35,
|
||||||
255, 22, 6, 38};
|
255, 22, 6, 38
|
||||||
|
};
|
||||||
|
|
||||||
// Gradient palette "retro2_16_gp", originally from
|
// Gradient palette "retro2_16_gp", originally from
|
||||||
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/ma/retro2/tn/retro2_16.png.index.html
|
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/ma/retro2/tn/retro2_16.png.index.html
|
||||||
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
||||||
// Size: 8 bytes of program space.
|
// Size: 8 bytes of program space.
|
||||||
|
|
||||||
DEFINE_GRADIENT_PALETTE( retro2_16_gp ) {
|
DEFINE_GRADIENT_PALETTE(retro2_16_gp) {
|
||||||
0, 188,135, 1,
|
0, 188, 135, 1,
|
||||||
255, 46, 7, 1};
|
255, 46, 7, 1
|
||||||
|
};
|
||||||
|
|
||||||
// Gradient palette "Analogous_1_gp", originally from
|
// Gradient palette "Analogous_1_gp", originally from
|
||||||
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/nd/red/tn/Analogous_1.png.index.html
|
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/nd/red/tn/Analogous_1.png.index.html
|
||||||
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
||||||
// Size: 20 bytes of program space.
|
// Size: 20 bytes of program space.
|
||||||
|
|
||||||
DEFINE_GRADIENT_PALETTE( Analogous_1_gp ) {
|
DEFINE_GRADIENT_PALETTE(Analogous_1_gp) {
|
||||||
0, 3, 0,255,
|
0, 3, 0, 255,
|
||||||
63, 23, 0,255,
|
63, 23, 0, 255,
|
||||||
127, 67, 0,255,
|
127, 67, 0, 255,
|
||||||
191, 142, 0, 45,
|
191, 142, 0, 45,
|
||||||
255, 255, 0, 0};
|
255, 255, 0, 0
|
||||||
|
};
|
||||||
|
|
||||||
// Gradient palette "es_pinksplash_08_gp", originally from
|
// Gradient palette "es_pinksplash_08_gp", originally from
|
||||||
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/es/pink_splash/tn/es_pinksplash_08.png.index.html
|
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/es/pink_splash/tn/es_pinksplash_08.png.index.html
|
||||||
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
||||||
// Size: 20 bytes of program space.
|
// Size: 20 bytes of program space.
|
||||||
|
|
||||||
DEFINE_GRADIENT_PALETTE( es_pinksplash_08_gp ) {
|
DEFINE_GRADIENT_PALETTE(es_pinksplash_08_gp) {
|
||||||
0, 126, 11,255,
|
0, 126, 11, 255,
|
||||||
127, 197, 1, 22,
|
127, 197, 1, 22,
|
||||||
175, 210,157,172,
|
175, 210, 157, 172,
|
||||||
221, 157, 3,112,
|
221, 157, 3, 112,
|
||||||
255, 157, 3,112};
|
255, 157, 3, 112
|
||||||
|
};
|
||||||
|
|
||||||
// Gradient palette "es_pinksplash_07_gp", originally from
|
// Gradient palette "es_pinksplash_07_gp", originally from
|
||||||
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/es/pink_splash/tn/es_pinksplash_07.png.index.html
|
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/es/pink_splash/tn/es_pinksplash_07.png.index.html
|
||||||
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
||||||
// Size: 28 bytes of program space.
|
// Size: 28 bytes of program space.
|
||||||
|
|
||||||
DEFINE_GRADIENT_PALETTE( es_pinksplash_07_gp ) {
|
DEFINE_GRADIENT_PALETTE(es_pinksplash_07_gp) {
|
||||||
0, 229, 1, 1,
|
0, 229, 1, 1,
|
||||||
61, 242, 4, 63,
|
61, 242, 4, 63,
|
||||||
101, 255, 12,255,
|
101, 255, 12, 255,
|
||||||
127, 249, 81,252,
|
127, 249, 81, 252,
|
||||||
153, 255, 11,235,
|
153, 255, 11, 235,
|
||||||
193, 244, 5, 68,
|
193, 244, 5, 68,
|
||||||
255, 232, 1, 5};
|
255, 232, 1, 5
|
||||||
|
};
|
||||||
|
|
||||||
// Gradient palette "Coral_reef_gp", originally from
|
// Gradient palette "Coral_reef_gp", originally from
|
||||||
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/nd/other/tn/Coral_reef.png.index.html
|
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/nd/other/tn/Coral_reef.png.index.html
|
||||||
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
||||||
// Size: 24 bytes of program space.
|
// Size: 24 bytes of program space.
|
||||||
|
|
||||||
DEFINE_GRADIENT_PALETTE( Coral_reef_gp ) {
|
DEFINE_GRADIENT_PALETTE(Coral_reef_gp) {
|
||||||
0, 40,199,197,
|
0, 40, 199, 197,
|
||||||
50, 10,152,155,
|
50, 10, 152, 155,
|
||||||
96, 1,111,120,
|
96, 1, 111, 120,
|
||||||
96, 43,127,162,
|
96, 43, 127, 162,
|
||||||
139, 10, 73,111,
|
139, 10, 73, 111,
|
||||||
255, 1, 34, 71};
|
255, 1, 34, 71
|
||||||
|
};
|
||||||
|
|
||||||
// Gradient palette "es_ocean_breeze_068_gp", originally from
|
// Gradient palette "es_ocean_breeze_068_gp", originally from
|
||||||
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/es/ocean_breeze/tn/es_ocean_breeze_068.png.index.html
|
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/es/ocean_breeze/tn/es_ocean_breeze_068.png.index.html
|
||||||
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
||||||
// Size: 24 bytes of program space.
|
// Size: 24 bytes of program space.
|
||||||
|
|
||||||
DEFINE_GRADIENT_PALETTE( es_ocean_breeze_068_gp ) {
|
DEFINE_GRADIENT_PALETTE(es_ocean_breeze_068_gp) {
|
||||||
0, 100,156,153,
|
0, 100, 156, 153,
|
||||||
51, 1, 99,137,
|
51, 1, 99, 137,
|
||||||
101, 1, 68, 84,
|
101, 1, 68, 84,
|
||||||
104, 35,142,168,
|
104, 35, 142, 168,
|
||||||
178, 0, 63,117,
|
178, 0, 63, 117,
|
||||||
255, 1, 10, 10};
|
255, 1, 10, 10
|
||||||
|
};
|
||||||
|
|
||||||
// Gradient palette "es_ocean_breeze_036_gp", originally from
|
// Gradient palette "es_ocean_breeze_036_gp", originally from
|
||||||
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/es/ocean_breeze/tn/es_ocean_breeze_036.png.index.html
|
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/es/ocean_breeze/tn/es_ocean_breeze_036.png.index.html
|
||||||
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
||||||
// Size: 16 bytes of program space.
|
// Size: 16 bytes of program space.
|
||||||
|
|
||||||
DEFINE_GRADIENT_PALETTE( es_ocean_breeze_036_gp ) {
|
DEFINE_GRADIENT_PALETTE(es_ocean_breeze_036_gp) {
|
||||||
0, 1, 6, 7,
|
0, 1, 6, 7,
|
||||||
89, 1, 99,111,
|
89, 1, 99, 111,
|
||||||
153, 144,209,255,
|
153, 144, 209, 255,
|
||||||
255, 0, 73, 82};
|
255, 0, 73, 82
|
||||||
|
};
|
||||||
|
|
||||||
// Gradient palette "departure_gp", originally from
|
// Gradient palette "departure_gp", originally from
|
||||||
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/mjf/tn/departure.png.index.html
|
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/mjf/tn/departure.png.index.html
|
||||||
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
||||||
// Size: 88 bytes of program space.
|
// Size: 88 bytes of program space.
|
||||||
|
|
||||||
DEFINE_GRADIENT_PALETTE( departure_gp ) {
|
DEFINE_GRADIENT_PALETTE(departure_gp) {
|
||||||
0, 8, 3, 0,
|
0, 8, 3, 0,
|
||||||
42, 23, 7, 0,
|
42, 23, 7, 0,
|
||||||
63, 75, 38, 6,
|
63, 75, 38, 6,
|
||||||
84, 169, 99, 38,
|
84, 169, 99, 38,
|
||||||
106, 213,169,119,
|
106, 213, 169, 119,
|
||||||
116, 255,255,255,
|
116, 255, 255, 255,
|
||||||
138, 135,255,138,
|
138, 135, 255, 138,
|
||||||
148, 22,255, 24,
|
148, 22, 255, 24,
|
||||||
170, 0,255, 0,
|
170, 0, 255, 0,
|
||||||
191, 0,136, 0,
|
191, 0, 136, 0,
|
||||||
212, 0, 55, 0,
|
212, 0, 55, 0,
|
||||||
255, 0, 55, 0};
|
255, 0, 55, 0
|
||||||
|
};
|
||||||
|
|
||||||
// Gradient palette "es_landscape_64_gp", originally from
|
// Gradient palette "es_landscape_64_gp", originally from
|
||||||
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/es/landscape/tn/es_landscape_64.png.index.html
|
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/es/landscape/tn/es_landscape_64.png.index.html
|
||||||
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
||||||
// Size: 36 bytes of program space.
|
// Size: 36 bytes of program space.
|
||||||
|
|
||||||
DEFINE_GRADIENT_PALETTE( es_landscape_64_gp ) {
|
DEFINE_GRADIENT_PALETTE(es_landscape_64_gp) {
|
||||||
0, 0, 0, 0,
|
0, 0, 0, 0,
|
||||||
37, 2, 25, 1,
|
37, 2, 25, 1,
|
||||||
76, 15,115, 5,
|
76, 15, 115, 5,
|
||||||
127, 79,213, 1,
|
127, 79, 213, 1,
|
||||||
128, 126,211, 47,
|
128, 126, 211, 47,
|
||||||
130, 188,209,247,
|
130, 188, 209, 247,
|
||||||
153, 144,182,205,
|
153, 144, 182, 205,
|
||||||
204, 59,117,250,
|
204, 59, 117, 250,
|
||||||
255, 1, 37,192};
|
255, 1, 37, 192
|
||||||
|
};
|
||||||
|
|
||||||
// Gradient palette "es_landscape_33_gp", originally from
|
// Gradient palette "es_landscape_33_gp", originally from
|
||||||
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/es/landscape/tn/es_landscape_33.png.index.html
|
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/es/landscape/tn/es_landscape_33.png.index.html
|
||||||
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
||||||
// Size: 24 bytes of program space.
|
// Size: 24 bytes of program space.
|
||||||
|
|
||||||
DEFINE_GRADIENT_PALETTE( es_landscape_33_gp ) {
|
DEFINE_GRADIENT_PALETTE(es_landscape_33_gp) {
|
||||||
0, 1, 5, 0,
|
0, 1, 5, 0,
|
||||||
19, 32, 23, 1,
|
19, 32, 23, 1,
|
||||||
38, 161, 55, 1,
|
38, 161, 55, 1,
|
||||||
63, 229,144, 1,
|
63, 229, 144, 1,
|
||||||
66, 39,142, 74,
|
66, 39, 142, 74,
|
||||||
255, 1, 4, 1};
|
255, 1, 4, 1
|
||||||
|
};
|
||||||
|
|
||||||
// Gradient palette "rainbowsherbet_gp", originally from
|
// Gradient palette "rainbowsherbet_gp", originally from
|
||||||
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/ma/icecream/tn/rainbowsherbet.png.index.html
|
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/ma/icecream/tn/rainbowsherbet.png.index.html
|
||||||
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
||||||
// Size: 28 bytes of program space.
|
// Size: 28 bytes of program space.
|
||||||
|
|
||||||
DEFINE_GRADIENT_PALETTE( rainbowsherbet_gp ) {
|
DEFINE_GRADIENT_PALETTE(rainbowsherbet_gp) {
|
||||||
0, 255, 33, 4,
|
0, 255, 33, 4,
|
||||||
43, 255, 68, 25,
|
43, 255, 68, 25,
|
||||||
86, 255, 7, 25,
|
86, 255, 7, 25,
|
||||||
127, 255, 82,103,
|
127, 255, 82, 103,
|
||||||
170, 255,255,242,
|
170, 255, 255, 242,
|
||||||
209, 42,255, 22,
|
209, 42, 255, 22,
|
||||||
255, 87,255, 65};
|
255, 87, 255, 65
|
||||||
|
};
|
||||||
|
|
||||||
// Gradient palette "gr65_hult_gp", originally from
|
// Gradient palette "gr65_hult_gp", originally from
|
||||||
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/hult/tn/gr65_hult.png.index.html
|
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/hult/tn/gr65_hult.png.index.html
|
||||||
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
||||||
// Size: 24 bytes of program space.
|
// Size: 24 bytes of program space.
|
||||||
|
|
||||||
DEFINE_GRADIENT_PALETTE( gr65_hult_gp ) {
|
DEFINE_GRADIENT_PALETTE(gr65_hult_gp) {
|
||||||
0, 247,176,247,
|
0, 247, 176, 247,
|
||||||
48, 255,136,255,
|
48, 255, 136, 255,
|
||||||
89, 220, 29,226,
|
89, 220, 29, 226,
|
||||||
160, 7, 82,178,
|
160, 7, 82, 178,
|
||||||
216, 1,124,109,
|
216, 1, 124, 109,
|
||||||
255, 1,124,109};
|
255, 1, 124, 109
|
||||||
|
};
|
||||||
|
|
||||||
// Gradient palette "gr64_hult_gp", originally from
|
// Gradient palette "gr64_hult_gp", originally from
|
||||||
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/hult/tn/gr64_hult.png.index.html
|
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/hult/tn/gr64_hult.png.index.html
|
||||||
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
||||||
// Size: 32 bytes of program space.
|
// Size: 32 bytes of program space.
|
||||||
|
|
||||||
DEFINE_GRADIENT_PALETTE( gr64_hult_gp ) {
|
DEFINE_GRADIENT_PALETTE(gr64_hult_gp) {
|
||||||
0, 1,124,109,
|
0, 1, 124, 109,
|
||||||
66, 1, 93, 79,
|
66, 1, 93, 79,
|
||||||
104, 52, 65, 1,
|
104, 52, 65, 1,
|
||||||
130, 115,127, 1,
|
130, 115, 127, 1,
|
||||||
150, 52, 65, 1,
|
150, 52, 65, 1,
|
||||||
201, 1, 86, 72,
|
201, 1, 86, 72,
|
||||||
239, 0, 55, 45,
|
239, 0, 55, 45,
|
||||||
255, 0, 55, 45};
|
255, 0, 55, 45
|
||||||
|
};
|
||||||
|
|
||||||
// Gradient palette "GMT_drywet_gp", originally from
|
// Gradient palette "GMT_drywet_gp", originally from
|
||||||
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/gmt/tn/GMT_drywet.png.index.html
|
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/gmt/tn/GMT_drywet.png.index.html
|
||||||
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
||||||
// Size: 28 bytes of program space.
|
// Size: 28 bytes of program space.
|
||||||
|
|
||||||
DEFINE_GRADIENT_PALETTE( GMT_drywet_gp ) {
|
DEFINE_GRADIENT_PALETTE(GMT_drywet_gp) {
|
||||||
0, 47, 30, 2,
|
0, 47, 30, 2,
|
||||||
42, 213,147, 24,
|
42, 213, 147, 24,
|
||||||
84, 103,219, 52,
|
84, 103, 219, 52,
|
||||||
127, 3,219,207,
|
127, 3, 219, 207,
|
||||||
170, 1, 48,214,
|
170, 1, 48, 214,
|
||||||
212, 1, 1,111,
|
212, 1, 1, 111,
|
||||||
255, 1, 7, 33};
|
255, 1, 7, 33
|
||||||
|
};
|
||||||
|
|
||||||
// Gradient palette "ib15_gp", originally from
|
// Gradient palette "ib15_gp", originally from
|
||||||
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/ing/general/tn/ib15.png.index.html
|
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/ing/general/tn/ib15.png.index.html
|
||||||
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
||||||
// Size: 24 bytes of program space.
|
// Size: 24 bytes of program space.
|
||||||
|
|
||||||
DEFINE_GRADIENT_PALETTE( ib15_gp ) {
|
DEFINE_GRADIENT_PALETTE(ib15_gp) {
|
||||||
0, 113, 91,147,
|
0, 113, 91, 147,
|
||||||
72, 157, 88, 78,
|
72, 157, 88, 78,
|
||||||
89, 208, 85, 33,
|
89, 208, 85, 33,
|
||||||
107, 255, 29, 11,
|
107, 255, 29, 11,
|
||||||
141, 137, 31, 39,
|
141, 137, 31, 39,
|
||||||
255, 59, 33, 89};
|
255, 59, 33, 89
|
||||||
|
};
|
||||||
|
|
||||||
// Gradient palette "Fuschia_7_gp", originally from
|
// Gradient palette "Fuschia_7_gp", originally from
|
||||||
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/ds/fuschia/tn/Fuschia-7.png.index.html
|
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/ds/fuschia/tn/Fuschia-7.png.index.html
|
||||||
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
||||||
// Size: 20 bytes of program space.
|
// Size: 20 bytes of program space.
|
||||||
|
|
||||||
DEFINE_GRADIENT_PALETTE( Fuschia_7_gp ) {
|
DEFINE_GRADIENT_PALETTE(Fuschia_7_gp) {
|
||||||
0, 43, 3,153,
|
0, 43, 3, 153,
|
||||||
63, 100, 4,103,
|
63, 100, 4, 103,
|
||||||
127, 188, 5, 66,
|
127, 188, 5, 66,
|
||||||
191, 161, 11,115,
|
191, 161, 11, 115,
|
||||||
255, 135, 20,182};
|
255, 135, 20, 182
|
||||||
|
};
|
||||||
|
|
||||||
// Gradient palette "es_emerald_dragon_08_gp", originally from
|
// Gradient palette "es_emerald_dragon_08_gp", originally from
|
||||||
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/es/emerald_dragon/tn/es_emerald_dragon_08.png.index.html
|
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/es/emerald_dragon/tn/es_emerald_dragon_08.png.index.html
|
||||||
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
||||||
// Size: 16 bytes of program space.
|
// Size: 16 bytes of program space.
|
||||||
|
|
||||||
DEFINE_GRADIENT_PALETTE( es_emerald_dragon_08_gp ) {
|
DEFINE_GRADIENT_PALETTE(es_emerald_dragon_08_gp) {
|
||||||
0, 97,255, 1,
|
0, 97, 255, 1,
|
||||||
101, 47,133, 1,
|
101, 47, 133, 1,
|
||||||
178, 13, 43, 1,
|
178, 13, 43, 1,
|
||||||
255, 2, 10, 1};
|
255, 2, 10, 1
|
||||||
|
};
|
||||||
|
|
||||||
// Gradient palette "lava_gp", originally from
|
// Gradient palette "lava_gp", originally from
|
||||||
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/neota/elem/tn/lava.png.index.html
|
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/neota/elem/tn/lava.png.index.html
|
||||||
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
||||||
// Size: 52 bytes of program space.
|
// Size: 52 bytes of program space.
|
||||||
|
|
||||||
DEFINE_GRADIENT_PALETTE( lava_gp ) {
|
DEFINE_GRADIENT_PALETTE(lava_gp) {
|
||||||
0, 0, 0, 0,
|
0, 0, 0, 0,
|
||||||
46, 18, 0, 0,
|
46, 18, 0, 0,
|
||||||
96, 113, 0, 0,
|
96, 113, 0, 0,
|
||||||
108, 142, 3, 1,
|
108, 142, 3, 1,
|
||||||
119, 175, 17, 1,
|
119, 175, 17, 1,
|
||||||
146, 213, 44, 2,
|
146, 213, 44, 2,
|
||||||
174, 255, 82, 4,
|
174, 255, 82, 4,
|
||||||
188, 255,115, 4,
|
188, 255, 115, 4,
|
||||||
202, 255,156, 4,
|
202, 255, 156, 4,
|
||||||
218, 255,203, 4,
|
218, 255, 203, 4,
|
||||||
234, 255,255, 4,
|
234, 255, 255, 4,
|
||||||
244, 255,255, 71,
|
244, 255, 255, 71,
|
||||||
255, 255,255,255};
|
255, 255, 255, 255
|
||||||
|
};
|
||||||
|
|
||||||
// Gradient palette "fire_gp", originally from
|
// Gradient palette "fire_gp", originally from
|
||||||
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/neota/elem/tn/fire.png.index.html
|
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/neota/elem/tn/fire.png.index.html
|
||||||
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
||||||
// Size: 28 bytes of program space.
|
// Size: 28 bytes of program space.
|
||||||
|
|
||||||
DEFINE_GRADIENT_PALETTE( fire_gp ) {
|
DEFINE_GRADIENT_PALETTE(fire_gp) {
|
||||||
0, 1, 1, 0,
|
0, 1, 1, 0,
|
||||||
76, 32, 5, 0,
|
76, 32, 5, 0,
|
||||||
146, 192, 24, 0,
|
146, 192, 24, 0,
|
||||||
197, 220,105, 5,
|
197, 220, 105, 5,
|
||||||
240, 252,255, 31,
|
240, 252, 255, 31,
|
||||||
250, 252,255,111,
|
250, 252, 255, 111,
|
||||||
255, 255,255,255};
|
255, 255, 255, 255
|
||||||
|
};
|
||||||
|
|
||||||
// Gradient palette "Colorfull_gp", originally from
|
// Gradient palette "Colorfull_gp", originally from
|
||||||
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/nd/atmospheric/tn/Colorfull.png.index.html
|
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/nd/atmospheric/tn/Colorfull.png.index.html
|
||||||
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
||||||
// Size: 44 bytes of program space.
|
// Size: 44 bytes of program space.
|
||||||
|
|
||||||
DEFINE_GRADIENT_PALETTE( Colorfull_gp ) {
|
DEFINE_GRADIENT_PALETTE(Colorfull_gp) {
|
||||||
0, 10, 85, 5,
|
0, 10, 85, 5,
|
||||||
25, 29,109, 18,
|
25, 29, 109, 18,
|
||||||
60, 59,138, 42,
|
60, 59, 138, 42,
|
||||||
93, 83, 99, 52,
|
93, 83, 99, 52,
|
||||||
106, 110, 66, 64,
|
106, 110, 66, 64,
|
||||||
109, 123, 49, 65,
|
109, 123, 49, 65,
|
||||||
113, 139, 35, 66,
|
113, 139, 35, 66,
|
||||||
116, 192,117, 98,
|
116, 192, 117, 98,
|
||||||
124, 255,255,137,
|
124, 255, 255, 137,
|
||||||
168, 100,180,155,
|
168, 100, 180, 155,
|
||||||
255, 22,121,174};
|
255, 22, 121, 174
|
||||||
|
};
|
||||||
|
|
||||||
// Gradient palette "Magenta_Evening_gp", originally from
|
// Gradient palette "Magenta_Evening_gp", originally from
|
||||||
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/nd/atmospheric/tn/Magenta_Evening.png.index.html
|
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/nd/atmospheric/tn/Magenta_Evening.png.index.html
|
||||||
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
||||||
// Size: 28 bytes of program space.
|
// Size: 28 bytes of program space.
|
||||||
|
|
||||||
DEFINE_GRADIENT_PALETTE( Magenta_Evening_gp ) {
|
DEFINE_GRADIENT_PALETTE(Magenta_Evening_gp) {
|
||||||
0, 71, 27, 39,
|
0, 71, 27, 39,
|
||||||
31, 130, 11, 51,
|
31, 130, 11, 51,
|
||||||
63, 213, 2, 64,
|
63, 213, 2, 64,
|
||||||
70, 232, 1, 66,
|
70, 232, 1, 66,
|
||||||
76, 252, 1, 69,
|
76, 252, 1, 69,
|
||||||
108, 123, 2, 51,
|
108, 123, 2, 51,
|
||||||
255, 46, 9, 35};
|
255, 46, 9, 35
|
||||||
|
};
|
||||||
|
|
||||||
// Gradient palette "Pink_Purple_gp", originally from
|
// Gradient palette "Pink_Purple_gp", originally from
|
||||||
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/nd/atmospheric/tn/Pink_Purple.png.index.html
|
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/nd/atmospheric/tn/Pink_Purple.png.index.html
|
||||||
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
||||||
// Size: 44 bytes of program space.
|
// Size: 44 bytes of program space.
|
||||||
|
|
||||||
DEFINE_GRADIENT_PALETTE( Pink_Purple_gp ) {
|
DEFINE_GRADIENT_PALETTE(Pink_Purple_gp) {
|
||||||
0, 19, 2, 39,
|
0, 19, 2, 39,
|
||||||
25, 26, 4, 45,
|
25, 26, 4, 45,
|
||||||
51, 33, 6, 52,
|
51, 33, 6, 52,
|
||||||
76, 68, 62,125,
|
76, 68, 62, 125,
|
||||||
102, 118,187,240,
|
102, 118, 187, 240,
|
||||||
109, 163,215,247,
|
109, 163, 215, 247,
|
||||||
114, 217,244,255,
|
114, 217, 244, 255,
|
||||||
122, 159,149,221,
|
122, 159, 149, 221,
|
||||||
149, 113, 78,188,
|
149, 113, 78, 188,
|
||||||
183, 128, 57,155,
|
183, 128, 57, 155,
|
||||||
255, 146, 40,123};
|
255, 146, 40, 123
|
||||||
|
};
|
||||||
|
|
||||||
// Gradient palette "Sunset_Real_gp", originally from
|
// Gradient palette "Sunset_Real_gp", originally from
|
||||||
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/nd/atmospheric/tn/Sunset_Real.png.index.html
|
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/nd/atmospheric/tn/Sunset_Real.png.index.html
|
||||||
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
||||||
// Size: 28 bytes of program space.
|
// Size: 28 bytes of program space.
|
||||||
|
|
||||||
DEFINE_GRADIENT_PALETTE( Sunset_Real_gp ) {
|
DEFINE_GRADIENT_PALETTE(Sunset_Real_gp) {
|
||||||
0, 120, 0, 0,
|
0, 120, 0, 0,
|
||||||
22, 179, 22, 0,
|
22, 179, 22, 0,
|
||||||
51, 255,104, 0,
|
51, 255, 104, 0,
|
||||||
85, 167, 22, 18,
|
85, 167, 22, 18,
|
||||||
135, 100, 0,103,
|
135, 100, 0, 103,
|
||||||
198, 16, 0,130,
|
198, 16, 0, 130,
|
||||||
255, 0, 0,160};
|
255, 0, 0, 160
|
||||||
|
};
|
||||||
|
|
||||||
// Gradient palette "es_autumn_19_gp", originally from
|
// Gradient palette "es_autumn_19_gp", originally from
|
||||||
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/es/autumn/tn/es_autumn_19.png.index.html
|
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/es/autumn/tn/es_autumn_19.png.index.html
|
||||||
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
||||||
// Size: 52 bytes of program space.
|
// Size: 52 bytes of program space.
|
||||||
|
|
||||||
DEFINE_GRADIENT_PALETTE( es_autumn_19_gp ) {
|
DEFINE_GRADIENT_PALETTE(es_autumn_19_gp) {
|
||||||
0, 26, 1, 1,
|
0, 26, 1, 1,
|
||||||
51, 67, 4, 1,
|
51, 67, 4, 1,
|
||||||
84, 118, 14, 1,
|
84, 118, 14, 1,
|
||||||
104, 137,152, 52,
|
104, 137, 152, 52,
|
||||||
112, 113, 65, 1,
|
112, 113, 65, 1,
|
||||||
122, 133,149, 59,
|
122, 133, 149, 59,
|
||||||
124, 137,152, 52,
|
124, 137, 152, 52,
|
||||||
135, 113, 65, 1,
|
135, 113, 65, 1,
|
||||||
142, 139,154, 46,
|
142, 139, 154, 46,
|
||||||
163, 113, 13, 1,
|
163, 113, 13, 1,
|
||||||
204, 55, 3, 1,
|
204, 55, 3, 1,
|
||||||
249, 17, 1, 1,
|
249, 17, 1, 1,
|
||||||
255, 17, 1, 1};
|
255, 17, 1, 1
|
||||||
|
};
|
||||||
|
|
||||||
// Gradient palette "BlacK_Blue_Magenta_White_gp", originally from
|
// Gradient palette "BlacK_Blue_Magenta_White_gp", originally from
|
||||||
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/nd/basic/tn/BlacK_Blue_Magenta_White.png.index.html
|
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/nd/basic/tn/BlacK_Blue_Magenta_White.png.index.html
|
||||||
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
||||||
// Size: 28 bytes of program space.
|
// Size: 28 bytes of program space.
|
||||||
|
|
||||||
DEFINE_GRADIENT_PALETTE( BlacK_Blue_Magenta_White_gp ) {
|
DEFINE_GRADIENT_PALETTE(BlacK_Blue_Magenta_White_gp) {
|
||||||
0, 0, 0, 0,
|
0, 0, 0, 0,
|
||||||
42, 0, 0, 45,
|
42, 0, 0, 45,
|
||||||
84, 0, 0,255,
|
84, 0, 0, 255,
|
||||||
127, 42, 0,255,
|
127, 42, 0, 255,
|
||||||
170, 255, 0,255,
|
170, 255, 0, 255,
|
||||||
212, 255, 55,255,
|
212, 255, 55, 255,
|
||||||
255, 255,255,255};
|
255, 255, 255, 255
|
||||||
|
};
|
||||||
|
|
||||||
// Gradient palette "BlacK_Magenta_Red_gp", originally from
|
// Gradient palette "BlacK_Magenta_Red_gp", originally from
|
||||||
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/nd/basic/tn/BlacK_Magenta_Red.png.index.html
|
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/nd/basic/tn/BlacK_Magenta_Red.png.index.html
|
||||||
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
||||||
// Size: 20 bytes of program space.
|
// Size: 20 bytes of program space.
|
||||||
|
|
||||||
DEFINE_GRADIENT_PALETTE( BlacK_Magenta_Red_gp ) {
|
DEFINE_GRADIENT_PALETTE(BlacK_Magenta_Red_gp) {
|
||||||
0, 0, 0, 0,
|
0, 0, 0, 0,
|
||||||
63, 42, 0, 45,
|
63, 42, 0, 45,
|
||||||
127, 255, 0,255,
|
127, 255, 0, 255,
|
||||||
191, 255, 0, 45,
|
191, 255, 0, 45,
|
||||||
255, 255, 0, 0};
|
255, 255, 0, 0
|
||||||
|
};
|
||||||
|
|
||||||
// Gradient palette "BlacK_Red_Magenta_Yellow_gp", originally from
|
// Gradient palette "BlacK_Red_Magenta_Yellow_gp", originally from
|
||||||
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/nd/basic/tn/BlacK_Red_Magenta_Yellow.png.index.html
|
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/nd/basic/tn/BlacK_Red_Magenta_Yellow.png.index.html
|
||||||
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
||||||
// Size: 28 bytes of program space.
|
// Size: 28 bytes of program space.
|
||||||
|
|
||||||
DEFINE_GRADIENT_PALETTE( BlacK_Red_Magenta_Yellow_gp ) {
|
DEFINE_GRADIENT_PALETTE(BlacK_Red_Magenta_Yellow_gp) {
|
||||||
0, 0, 0, 0,
|
0, 0, 0, 0,
|
||||||
42, 42, 0, 0,
|
42, 42, 0, 0,
|
||||||
84, 255, 0, 0,
|
84, 255, 0, 0,
|
||||||
127, 255, 0, 45,
|
127, 255, 0, 45,
|
||||||
170, 255, 0,255,
|
170, 255, 0, 255,
|
||||||
212, 255, 55, 45,
|
212, 255, 55, 45,
|
||||||
255, 255,255, 0};
|
255, 255, 255, 0
|
||||||
|
};
|
||||||
|
|
||||||
// Gradient palette "Blue_Cyan_Yellow_gp", originally from
|
// Gradient palette "Blue_Cyan_Yellow_gp", originally from
|
||||||
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/nd/basic/tn/Blue_Cyan_Yellow.png.index.html
|
// http://soliton.vm.bytemark.co.uk/pub/cpt-city/nd/basic/tn/Blue_Cyan_Yellow.png.index.html
|
||||||
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
// converted for FastLED with gammas (2.6, 2.2, 2.5)
|
||||||
// Size: 20 bytes of program space.
|
// Size: 20 bytes of program space.
|
||||||
|
|
||||||
DEFINE_GRADIENT_PALETTE( Blue_Cyan_Yellow_gp ) {
|
DEFINE_GRADIENT_PALETTE(Blue_Cyan_Yellow_gp) {
|
||||||
0, 0, 0,255,
|
0, 0, 0, 255,
|
||||||
63, 0, 55,255,
|
63, 0, 55, 255,
|
||||||
127, 0,255,255,
|
127, 0, 255, 255,
|
||||||
191, 42,255, 45,
|
191, 42, 255, 45,
|
||||||
255, 255,255, 0};
|
255, 255, 255, 0
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
// Single array of defined cpt-city color palettes.
|
// Single array of defined cpt-city color palettes.
|
||||||
@ -514,5 +547,5 @@ const TProgmemRGBGradientPalettePtr gGradientPalettes[] = {
|
|||||||
|
|
||||||
// Count of how many cpt-city gradients are defined:
|
// Count of how many cpt-city gradients are defined:
|
||||||
const uint8_t gGradientPaletteCount =
|
const uint8_t gGradientPaletteCount =
|
||||||
sizeof( gGradientPalettes) / sizeof( TProgmemRGBGradientPalettePtr );
|
sizeof(gGradientPalettes) / sizeof(TProgmemRGBGradientPalettePtr);
|
||||||
|
|
||||||
|
161
README.md
@ -1,54 +1,131 @@
|
|||||||
FastLED + ESP8266 Web Server
|
Nanoleaf Web Server
|
||||||
=========
|
=========
|
||||||
|
|
||||||
Control an addressable LED strip with an ESP8266 via a web browser or infrared remote control.
|
This is a fork of [jasoncoon's esp8266 fastled webserver](https://github.com/jasoncoon/esp8266-fastled-webserver) that was adapted to control the colors of my [DIY-Nanoleaf Replica](https://www.thingiverse.com/thing:3354082).
|
||||||
|
|
||||||
|
[](https://www.thingiverse.com/thing:3354082)
|
||||||
|
|
||||||
Hardware
|
Hardware
|
||||||
--------
|
--------
|
||||||
|
|
||||||
##### ESP8266 development board
|
##### ESP8266
|
||||||
|
|
||||||
[](https://www.aliexpress.com/item/WEMOS-D1-mini-Pro-16M-bytes-external-antenna-connector-ESP8266-WIFI-Internet-of-Things-development-board/32724692514.html)
|

|
||||||
|
|
||||||
[Wemos D1 Mini Pro & Headers](https://www.aliexpress.com/item/WEMOS-D1-mini-Pro-16M-bytes-external-antenna-connector-ESP8266-WIFI-Internet-of-Things-development-board/32724692514.html)
|
[Wemos D1 mini](http://s.click.aliexpress.com/e/cBDdafPw) is recommended, but any other ESP8266 variant should work too, but it might require an additional step-down converter.
|
||||||
|
|
||||||
or
|
|
||||||
|
|
||||||
[](https://www.adafruit.com/products/2471)
|
|
||||||
|
|
||||||
[Adafruit HUZZAH ESP8266 Breakout](https://www.adafruit.com/products/2471)
|
**Addressable Led Strip**
|
||||||
|
|
||||||
##### Addressable LED strip
|

|
||||||
|
|
||||||
[](https://www.adafruit.com/product/1586)
|
I have used 12 led pixels per leaf → 1m of 60 leds/m = 5 leafs
|
||||||
|
|
||||||
[Adafruit NeoPixel Ring]
|
I would recommend buying a strip with 60 leds/m or more.
|
||||||
|
|
||||||
Other hardware:
|
[WS2812b led strip](http://s.click.aliexpress.com/e/SkQFQqc), make sure you choose IP30 any other IP rating wouldn't make any sense and might not even fit.
|
||||||
|
|
||||||
* [3.3V to 5V Logic Level Shifter](http://www.digikey.com/product-detail/en/texas-instruments/SN74HCT245N/296-1612-5-ND/277258) (required if LEDs "glitch")
|
|
||||||
|
|
||||||
Recommended by [Adafruit NeoPixel "Best Practices"](https://learn.adafruit.com/adafruit-neopixel-uberguide/best-practices) to help protect LEDs from current onrush:
|
|
||||||
* [1000µF Capacitor](http://www.digikey.com/product-detail/en/panasonic-electronic-components/ECA-1EM102/P5156-ND/245015)
|
|
||||||
* [300 to 500 Ohm resistor](https://www.digikey.com/product-detail/en/stackpole-electronics-inc/CF14JT470R/CF14JT470RCT-ND/1830342)
|
|
||||||
|
|
||||||
Optional shield to make everything more tidy:
|
Other (optional) hardware:
|
||||||
|
|
||||||
[](https://www.tindie.com/products/jasoncoon/wemos-d1-mini-esp8266-led-and-level-shifter-shield/)
|
* [3.3V to 5V Logic Level Shifter](http://s.click.aliexpress.com/e/buDr0PT2) (required if LEDs "glitch")
|
||||||
|
|
||||||
[Wemos D1 Mini ESP8266 LED & Level Shifter Shield](https://www.tindie.com/products/jasoncoon/wemos-d1-mini-esp8266-led-and-level-shifter-shield)
|
|
||||||
|
|
||||||
Features
|
Features
|
||||||
--------
|
--------
|
||||||
* Turn the NeoPixel Ring on and off
|
* Control the colors of individual leafs
|
||||||
* Adjust the brightness
|
* Adjust the brightness
|
||||||
* Change the display pattern
|
* Change the display pattern
|
||||||
* Adjust the color
|
* Adjust the color
|
||||||
|
* Adapted patterns to look great on the [DIY-Nanoleaf Replica](https://www.thingiverse.com/thing:3354082)
|
||||||
|
* OTA-Update support
|
||||||
|
|
||||||
Web App
|
|
||||||
|
|
||||||
|
### Upcoming Features
|
||||||
|
|
||||||
|
- **Node-RED** integration
|
||||||
|
- Custom-Alexa skill
|
||||||
|
- Nanoleaf voice control
|
||||||
|
- Custom color pattern designer
|
||||||
|
- **Node-RED** webinterface to store special patterns persistant
|
||||||
|
- Controlling multiple nanoleafs at once
|
||||||
|
|
||||||
|
> these features will be optional and require additional hardware (any linux/windows device that is in the same network)
|
||||||
|
|
||||||
|
Webinterface
|
||||||
--------
|
--------
|
||||||
|
|
||||||

|

|
||||||
|
|
||||||
|
The web app is stored in SPIFFS (on-board flash memory).
|
||||||
|
|
||||||
|
Installing
|
||||||
|
-----------
|
||||||
|
The app is installed via the Arduino IDE which can be [downloaded here](https://www.arduino.cc/en/main/software). The ESP8266 boards will need to be added to the Arduino IDE which is achieved as follows. Click File > Preferences and copy and paste the URL "http://arduino.esp8266.com/stable/package_esp8266com_index.json" into the Additional Boards Manager URLs field. Click OK. Click Tools > Boards: ... > Boards Manager. Find and click on ESP8266 (using the Search function may expedite this). Click on Install. After installation, click on Close and then select your ESP8266 board from the Tools > Board: ... menu.
|
||||||
|
|
||||||
|
The app depends on the following libraries. They must either be downloaded from GitHub and placed in the Arduino 'libraries' folder, or installed as [described here](https://www.arduino.cc/en/Guide/Libraries) by using the Arduino library manager.
|
||||||
|
|
||||||
|
* [FastLED](https://github.com/FastLED/FastLED)
|
||||||
|
* [Arduino WebSockets](https://github.com/Links2004/arduinoWebSockets)
|
||||||
|
|
||||||
|
Download the app code from GitHub using the green Clone or Download button from [GitHub](https://github.com/NimmLor/esp8266-fastled-webserver) and click Download ZIP. Decompress the ZIP file in your Arduino sketch folder.
|
||||||
|
|
||||||
|
The web app needs to be uploaded to the ESP8266's SPIFFS. You can do this within the Arduino IDE after installing the [Arduino ESP8266FS tool](http://esp8266.github.io/Arduino/versions/2.3.0/doc/filesystem.html#uploading-files-to-file-system). An alternative would be to install the [Visual Micro](https://www.visualmicro.com/) plugin for Visual Studio.
|
||||||
|
|
||||||
|
With ESP8266FS installed upload the web app using `ESP8266 Sketch Data Upload` command in the Arduino Tools menu.
|
||||||
|
|
||||||
|
## Configuration
|
||||||
|
|
||||||
|
The most important thing to do is to set the amount of 'leafs' and the amount of led pixels that one 'leaf' contains.
|
||||||
|
|
||||||
|
For instance I use 12 leafs (triangles) with a total of 12 pixels in one leaf (=4 leds in each corner of the triangle).
|
||||||
|
|
||||||
|
```c++
|
||||||
|
#define LEAFCOUNT 12
|
||||||
|
#define PIXELS_PER_LEAF 12
|
||||||
|
```
|
||||||
|
|
||||||
|
Next enter the pin where the *Data* line is connected to, in my case it's pin D4 (you can either write D4 or 2).
|
||||||
|
|
||||||
|
`#define DATA_PIN D4`
|
||||||
|
|
||||||
|
Another **important** step is to create the **Secrets.h** file. Create a new tab (**ctrl**+**shift**+**n**) and name it *Secrets.h*, this file contains your WIFI credentials and it's structure must look like this:
|
||||||
|
|
||||||
|
``````c++
|
||||||
|
// AP mode password
|
||||||
|
const char WiFiAPPSK[] = "WIFI_NAME_IF_IN_AP_MODE";
|
||||||
|
|
||||||
|
// Wi-Fi network to connect to (if not in AP mode)
|
||||||
|
char* ssid = "YOUR_WIFI_NAME";
|
||||||
|
char* password = "YOUR_WIFI_PASSWORD";
|
||||||
|
``````
|
||||||
|
|
||||||
|
If colors appear to be swapped you should change the color order. For me, red and green was swapped so i had to change the color order from *RGB* to *GRB*.
|
||||||
|
|
||||||
|
You should also set the milli-amps of your power supply to prevent power overloading. I am using a 3A 5V psu so i defined 3000mA.
|
||||||
|
|
||||||
|
`#define MILLI_AMPS 3000`
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
## Circuit
|
||||||
|
|
||||||
|
### Without Logic-Level Converter
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
### With Logic-Level-Converter (required if leds 'glitch')
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
Technical information
|
||||||
|
-----------------
|
||||||
|
|
||||||
Patterns are requested by the app from the ESP8266, so as new patterns are added, they're automatically listed in the app.
|
Patterns are requested by the app from the ESP8266, so as new patterns are added, they're automatically listed in the app.
|
||||||
|
|
||||||
@ -58,44 +135,6 @@ The web app is a single page app that uses [jQuery](https://jquery.com) and [Boo
|
|||||||
|
|
||||||
The only drawback to SPIFFS that I've found so far is uploading the files can be extremely slow, requiring several minutes, sometimes regardless of how large the files are. It can be so slow that I've been just developing the web app and debugging locally on my desktop (with a hard-coded IP for the ESP8266), before uploading to SPIFFS and testing on the ESP8266.
|
The only drawback to SPIFFS that I've found so far is uploading the files can be extremely slow, requiring several minutes, sometimes regardless of how large the files are. It can be so slow that I've been just developing the web app and debugging locally on my desktop (with a hard-coded IP for the ESP8266), before uploading to SPIFFS and testing on the ESP8266.
|
||||||
|
|
||||||
Installing
|
|
||||||
-----------
|
|
||||||
The app is installed via the Arduino IDE which can be [downloaded here](https://www.arduino.cc/en/main/software). The ESP8266 boards will need to be added to the Arduino IDE which is achieved as follows. Click File > Preferences and copy and paste the URL "http://arduino.esp8266.com/stable/package_esp8266com_index.json" into the Additional Boards Manager URLs field. Click OK. Click Tools > Boards: ... > Boards Manager. Find and click on ESP8266 (using the Search function may expedite this). Click on Install. After installation, click on Close and then select your ESP8266 board from the Tools > Board: ... menu.
|
|
||||||
|
|
||||||
The app depends on the following libraries. They must either be downloaded from GitHub and placed in the Arduino 'libraries' folder, or installed as [described here](https://www.arduino.cc/en/Guide/Libraries) by using the Arduino library manager.
|
|
||||||
|
|
||||||
* [FastLED](https://github.com/FastLED/FastLED)
|
|
||||||
* [IRremoteESP8266](https://github.com/sebastienwarin/IRremoteESP8266)
|
|
||||||
* [Arduino WebSockets](https://github.com/Links2004/arduinoWebSockets)
|
|
||||||
|
|
||||||
Download the app code from GitHub using the green Clone or Download button from [the GitHub project main page](https://github.com/jasoncoon/esp8266-fastled-webserver) and click Download ZIP. Decompress the ZIP file in your Arduino sketch folder.
|
|
||||||
|
|
||||||
The web app needs to be uploaded to the ESP8266's SPIFFS. You can do this within the Arduino IDE after installing the [Arduino ESP8266FS tool](http://esp8266.github.io/Arduino/versions/2.3.0/doc/filesystem.html#uploading-files-to-file-system).
|
|
||||||
|
|
||||||
With ESP8266FS installed upload the web app using `ESP8266 Sketch Data Upload` command in the Arduino Tools menu.
|
|
||||||
|
|
||||||
Then enter your wi-fi network SSID and password in the .ino file, and upload the sketch using the Upload button.
|
|
||||||
|
|
||||||
Compression
|
|
||||||
-----------
|
|
||||||
|
|
||||||
The web app files can be gzip compressed before uploading to SPIFFS by running the following command:
|
|
||||||
|
|
||||||
`gzip -r data/`
|
|
||||||
|
|
||||||
The ESP8266WebServer will automatically serve any .gz file. The file index.htm.gz will get served as index.htm, with the content-encoding header set to gzip, so the browser knows to decompress it. The ESP8266WebServer doesn't seem to like the Glyphicon fonts gzipped, though, so I decompress them with this command:
|
|
||||||
|
|
||||||
`gunzip -r data/fonts/`
|
|
||||||
|
|
||||||
REST Web services
|
|
||||||
-----------------
|
|
||||||
|
|
||||||
The firmware implements basic [RESTful web services](https://en.wikipedia.org/wiki/Representational_state_transfer) using the ESP8266WebServer library. Current values are requested with HTTP GETs, and values are set with POSTs using query string parameters. It can run in connected or standalone access point modes.
|
The firmware implements basic [RESTful web services](https://en.wikipedia.org/wiki/Representational_state_transfer) using the ESP8266WebServer library. Current values are requested with HTTP GETs, and values are set with POSTs using query string parameters. It can run in connected or standalone access point modes.
|
||||||
|
|
||||||
Infrared Remote Control
|
|
||||||
-----------------------
|
|
||||||
|
|
||||||
Control via infrared remote control is also supported, via the [ESP8266 port of the IRremote library](https://github.com/sebastienwarin/IRremoteESP8266).
|
|
||||||
|
|
||||||
[Adafruit NeoPixel Ring]:https://www.adafruit.com/product/1586
|
|
||||||
[Adafruit HUZZAH ESP8266 Breakout]:https://www.adafruit.com/products/2471
|
|
||||||
|
177
TwinkleFOX.h
@ -99,26 +99,27 @@ CRGBPalette16 twinkleFoxPalette;
|
|||||||
// / \
|
// / \
|
||||||
//
|
//
|
||||||
|
|
||||||
uint8_t attackDecayWave8( uint8_t i)
|
uint8_t attackDecayWave8(uint8_t i)
|
||||||
{
|
{
|
||||||
if( i < 86) {
|
if (i < 86) {
|
||||||
return i * 3;
|
return i * 3;
|
||||||
} else {
|
}
|
||||||
|
else {
|
||||||
i -= 86;
|
i -= 86;
|
||||||
return 255 - (i + (i/2));
|
return 255 - (i + (i / 2));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// This function takes a pixel, and if its in the 'fading down'
|
// This function takes a pixel, and if its in the 'fading down'
|
||||||
// part of the cycle, it adjusts the color a little bit like the
|
// part of the cycle, it adjusts the color a little bit like the
|
||||||
// way that incandescent bulbs fade toward 'red' as they dim.
|
// way that incandescent bulbs fade toward 'red' as they dim.
|
||||||
void coolLikeIncandescent( CRGB& c, uint8_t phase)
|
void coolLikeIncandescent(CRGB& c, uint8_t phase)
|
||||||
{
|
{
|
||||||
if( phase < 128) return;
|
if (phase < 128) return;
|
||||||
|
|
||||||
uint8_t cooling = (phase - 128) >> 4;
|
uint8_t cooling = (phase - 128) >> 4;
|
||||||
c.g = qsub8( c.g, cooling);
|
c.g = qsub8(c.g, cooling);
|
||||||
c.b = qsub8( c.b, cooling * 2);
|
c.b = qsub8(c.b, cooling * 2);
|
||||||
}
|
}
|
||||||
|
|
||||||
// This function takes a time in pseudo-milliseconds,
|
// This function takes a time in pseudo-milliseconds,
|
||||||
@ -130,28 +131,29 @@ void coolLikeIncandescent( CRGB& c, uint8_t phase)
|
|||||||
// of one cycle of the brightness wave function.
|
// of one cycle of the brightness wave function.
|
||||||
// The 'high digits' are also used to determine whether this pixel
|
// The 'high digits' are also used to determine whether this pixel
|
||||||
// should light at all during this cycle, based on the twinkleDensity.
|
// should light at all during this cycle, based on the twinkleDensity.
|
||||||
CRGB computeOneTwinkle( uint32_t ms, uint8_t salt)
|
CRGB computeOneTwinkle(uint32_t ms, uint8_t salt)
|
||||||
{
|
{
|
||||||
uint16_t ticks = ms >> (8-twinkleSpeed);
|
uint16_t ticks = ms >> (8 - twinkleSpeed);
|
||||||
uint8_t fastcycle8 = ticks;
|
uint8_t fastcycle8 = ticks;
|
||||||
uint16_t slowcycle16 = (ticks >> 8) + salt;
|
uint16_t slowcycle16 = (ticks >> 8) + salt;
|
||||||
slowcycle16 += sin8( slowcycle16);
|
slowcycle16 += sin8(slowcycle16);
|
||||||
slowcycle16 = (slowcycle16 * 2053) + 1384;
|
slowcycle16 = (slowcycle16 * 2053) + 1384;
|
||||||
uint8_t slowcycle8 = (slowcycle16 & 0xFF) + (slowcycle16 >> 8);
|
uint8_t slowcycle8 = (slowcycle16 & 0xFF) + (slowcycle16 >> 8);
|
||||||
|
|
||||||
uint8_t bright = 0;
|
uint8_t bright = 0;
|
||||||
if( ((slowcycle8 & 0x0E)/2) < twinkleDensity) {
|
if (((slowcycle8 & 0x0E) / 2) < twinkleDensity) {
|
||||||
bright = attackDecayWave8( fastcycle8);
|
bright = attackDecayWave8(fastcycle8);
|
||||||
}
|
}
|
||||||
|
|
||||||
uint8_t hue = slowcycle8 - salt;
|
uint8_t hue = slowcycle8 - salt;
|
||||||
CRGB c;
|
CRGB c;
|
||||||
if( bright > 0) {
|
if (bright > 0) {
|
||||||
c = ColorFromPalette( twinkleFoxPalette, hue, bright, NOBLEND);
|
c = ColorFromPalette(twinkleFoxPalette, hue, bright, NOBLEND);
|
||||||
if( COOL_LIKE_INCANDESCENT == 1 ) {
|
if (COOL_LIKE_INCANDESCENT == 1) {
|
||||||
coolLikeIncandescent( c, fastcycle8);
|
coolLikeIncandescent(c, fastcycle8);
|
||||||
}
|
}
|
||||||
} else {
|
}
|
||||||
|
else {
|
||||||
c = CRGB::Black;
|
c = CRGB::Black;
|
||||||
}
|
}
|
||||||
return c;
|
return c;
|
||||||
@ -177,61 +179,148 @@ void drawTwinkles()
|
|||||||
// the current palette are identical, then a deeply faded version of
|
// the current palette are identical, then a deeply faded version of
|
||||||
// that color is used for the background color
|
// that color is used for the background color
|
||||||
CRGB bg;
|
CRGB bg;
|
||||||
if( (AUTO_SELECT_BACKGROUND_COLOR == 1) &&
|
if ((AUTO_SELECT_BACKGROUND_COLOR == 1) &&
|
||||||
(twinkleFoxPalette[0] == twinkleFoxPalette[1] )) {
|
(twinkleFoxPalette[0] == twinkleFoxPalette[1])) {
|
||||||
bg = twinkleFoxPalette[0];
|
bg = twinkleFoxPalette[0];
|
||||||
uint8_t bglight = bg.getAverageLight();
|
uint8_t bglight = bg.getAverageLight();
|
||||||
if( bglight > 64) {
|
if (bglight > 64) {
|
||||||
bg.nscale8_video( 16); // very bright, so scale to 1/16th
|
bg.nscale8_video(16); // very bright, so scale to 1/16th
|
||||||
} else if( bglight > 16) {
|
|
||||||
bg.nscale8_video( 64); // not that bright, so scale to 1/4th
|
|
||||||
} else {
|
|
||||||
bg.nscale8_video( 86); // dim, scale to 1/3rd.
|
|
||||||
}
|
}
|
||||||
} else {
|
else if (bglight > 16) {
|
||||||
|
bg.nscale8_video(64); // not that bright, so scale to 1/4th
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
bg.nscale8_video(86); // dim, scale to 1/3rd.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
bg = gBackgroundColor; // just use the explicitly defined background color
|
bg = gBackgroundColor; // just use the explicitly defined background color
|
||||||
}
|
}
|
||||||
|
|
||||||
uint8_t backgroundBrightness = bg.getAverageLight();
|
uint8_t backgroundBrightness = bg.getAverageLight();
|
||||||
|
|
||||||
for(uint8_t i = 0; i < NUM_LEDS; i++) {
|
for (uint16_t i = 0; i < LEAFCOUNT; i++) {
|
||||||
CRGB& pixel = leds[i];
|
CRGB& pixel = leds[i*PIXELS_PER_LEAF];
|
||||||
|
|
||||||
PRNG16 = (uint16_t)(PRNG16 * 2053) + 1384; // next 'random' number
|
PRNG16 = (uint16_t)(PRNG16 * 2053) + 1384; // next 'random' number
|
||||||
uint16_t myclockoffset16= PRNG16; // use that number as clock offset
|
uint16_t myclockoffset16 = PRNG16; // use that number as clock offset
|
||||||
PRNG16 = (uint16_t)(PRNG16 * 2053) + 1384; // next 'random' number
|
PRNG16 = (uint16_t)(PRNG16 * 2053) + 1384; // next 'random' number
|
||||||
// use that number as clock speed adjustment factor (in 8ths, from 8/8ths to 23/8ths)
|
// use that number as clock speed adjustment factor (in 8ths, from 8/8ths to 23/8ths)
|
||||||
uint8_t myspeedmultiplierQ5_3 = ((((PRNG16 & 0xFF)>>4) + (PRNG16 & 0x0F)) & 0x0F) + 0x08;
|
uint8_t myspeedmultiplierQ5_3 = ((((PRNG16 & 0xFF) >> 4) + (PRNG16 & 0x0F)) & 0x0F) + 0x08;
|
||||||
uint32_t myclock30 = (uint32_t)((clock32 * myspeedmultiplierQ5_3) >> 3) + myclockoffset16;
|
uint32_t myclock30 = (uint32_t)((clock32 * myspeedmultiplierQ5_3) >> 3) + myclockoffset16;
|
||||||
uint8_t myunique8 = PRNG16 >> 8; // get 'salt' value for this pixel
|
uint8_t myunique8 = PRNG16 >> 8; // get 'salt' value for this pixel
|
||||||
|
|
||||||
// We now have the adjusted 'clock' for this pixel, now we call
|
// We now have the adjusted 'clock' for this pixel, now we call
|
||||||
// the function that computes what color the pixel should be based
|
// the function that computes what color the pixel should be based
|
||||||
// on the "brightness = f( time )" idea.
|
// on the "brightness = f( time )" idea.
|
||||||
CRGB c = computeOneTwinkle( myclock30, myunique8);
|
CRGB c = computeOneTwinkle(myclock30, myunique8);
|
||||||
|
|
||||||
uint8_t cbright = c.getAverageLight();
|
uint8_t cbright = c.getAverageLight();
|
||||||
int16_t deltabright = cbright - backgroundBrightness;
|
int16_t deltabright = cbright - backgroundBrightness;
|
||||||
if( deltabright >= 32 || (!bg)) {
|
if (deltabright >= 32 || (!bg)) {
|
||||||
|
// If the new pixel is significantly brighter than the background color,
|
||||||
|
// use the new color.
|
||||||
|
fill_solid(leds + i * PIXELS_PER_LEAF, PIXELS_PER_LEAF, c);
|
||||||
|
//Serial.printf("rgb: %d, %d, %d\n", c.r,c.g,c.b);
|
||||||
|
}
|
||||||
|
else if (deltabright > 0) {
|
||||||
|
// If the new pixel is just slightly brighter than the background color,
|
||||||
|
// mix a blend of the new color and the background color
|
||||||
|
fill_solid(leds + i * PIXELS_PER_LEAF, PIXELS_PER_LEAF, blend(bg, c, deltabright * 8));
|
||||||
|
//Serial.println("rgb:"+ blend(bg, c, deltabright * 8));
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
// if the new pixel is not at all brighter than the background color,
|
||||||
|
// just use the background color.
|
||||||
|
fill_solid(leds + i * PIXELS_PER_LEAF, PIXELS_PER_LEAF, bg);
|
||||||
|
//Serial.println("rgb:" + bg);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/////// #############################BACKUP####################################
|
||||||
|
/*
|
||||||
|
// This function loops over each pixel, calculates the
|
||||||
|
// adjusted 'clock' that this pixel should use, and calls
|
||||||
|
// "CalculateOneTwinkle" on each pixel. It then displays
|
||||||
|
// either the twinkle color of the background color,
|
||||||
|
// whichever is brighter.
|
||||||
|
void drawTwinkles()
|
||||||
|
{
|
||||||
|
// "PRNG16" is the pseudorandom number generator
|
||||||
|
// It MUST be reset to the same starting value each time
|
||||||
|
// this function is called, so that the sequence of 'random'
|
||||||
|
// numbers that it generates is (paradoxically) stable.
|
||||||
|
uint16_t PRNG16 = 11337;
|
||||||
|
|
||||||
|
uint32_t clock32 = millis();
|
||||||
|
|
||||||
|
// Set up the background color, "bg".
|
||||||
|
// if AUTO_SELECT_BACKGROUND_COLOR == 1, and the first two colors of
|
||||||
|
// the current palette are identical, then a deeply faded version of
|
||||||
|
// that color is used for the background color
|
||||||
|
CRGB bg;
|
||||||
|
if ((AUTO_SELECT_BACKGROUND_COLOR == 1) &&
|
||||||
|
(twinkleFoxPalette[0] == twinkleFoxPalette[1])) {
|
||||||
|
bg = twinkleFoxPalette[0];
|
||||||
|
uint8_t bglight = bg.getAverageLight();
|
||||||
|
if (bglight > 64) {
|
||||||
|
bg.nscale8_video(16); // very bright, so scale to 1/16th
|
||||||
|
}
|
||||||
|
else if (bglight > 16) {
|
||||||
|
bg.nscale8_video(64); // not that bright, so scale to 1/4th
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
bg.nscale8_video(86); // dim, scale to 1/3rd.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
bg = gBackgroundColor; // just use the explicitly defined background color
|
||||||
|
}
|
||||||
|
|
||||||
|
uint8_t backgroundBrightness = bg.getAverageLight();
|
||||||
|
|
||||||
|
for (uint16_t i = 0; i < NUM_LEDS; i++) {
|
||||||
|
CRGB& pixel = leds[i];
|
||||||
|
|
||||||
|
PRNG16 = (uint16_t)(PRNG16 * 2053) + 1384; // next 'random' number
|
||||||
|
uint16_t myclockoffset16 = PRNG16; // use that number as clock offset
|
||||||
|
PRNG16 = (uint16_t)(PRNG16 * 2053) + 1384; // next 'random' number
|
||||||
|
// use that number as clock speed adjustment factor (in 8ths, from 8/8ths to 23/8ths)
|
||||||
|
uint8_t myspeedmultiplierQ5_3 = ((((PRNG16 & 0xFF) >> 4) + (PRNG16 & 0x0F)) & 0x0F) + 0x08;
|
||||||
|
uint32_t myclock30 = (uint32_t)((clock32 * myspeedmultiplierQ5_3) >> 3) + myclockoffset16;
|
||||||
|
uint8_t myunique8 = PRNG16 >> 8; // get 'salt' value for this pixel
|
||||||
|
|
||||||
|
// We now have the adjusted 'clock' for this pixel, now we call
|
||||||
|
// the function that computes what color the pixel should be based
|
||||||
|
// on the "brightness = f( time )" idea.
|
||||||
|
CRGB c = computeOneTwinkle(myclock30, myunique8);
|
||||||
|
|
||||||
|
uint8_t cbright = c.getAverageLight();
|
||||||
|
int16_t deltabright = cbright - backgroundBrightness;
|
||||||
|
if (deltabright >= 32 || (!bg)) {
|
||||||
// If the new pixel is significantly brighter than the background color,
|
// If the new pixel is significantly brighter than the background color,
|
||||||
// use the new color.
|
// use the new color.
|
||||||
pixel = c;
|
pixel = c;
|
||||||
} else if( deltabright > 0 ) {
|
}
|
||||||
|
else if (deltabright > 0) {
|
||||||
// If the new pixel is just slightly brighter than the background color,
|
// If the new pixel is just slightly brighter than the background color,
|
||||||
// mix a blend of the new color and the background color
|
// mix a blend of the new color and the background color
|
||||||
pixel = blend( bg, c, deltabright * 8);
|
pixel = blend(bg, c, deltabright * 8);
|
||||||
} else {
|
}
|
||||||
|
else {
|
||||||
// if the new pixel is not at all brighter than the background color,
|
// if the new pixel is not at all brighter than the background color,
|
||||||
// just use the background color.
|
// just use the background color.
|
||||||
pixel = bg;
|
pixel = bg;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
*/
|
||||||
|
|
||||||
// A mostly red palette with green accents and white trim.
|
// A mostly red palette with green accents and white trim.
|
||||||
// "CRGB::Gray" is used as white to keep the brightness more uniform.
|
// "CRGB::Gray" is used as white to keep the brightness more uniform.
|
||||||
const TProgmemRGBPalette16 RedGreenWhite_p FL_PROGMEM =
|
const TProgmemRGBPalette16 RedGreenWhite_p FL_PROGMEM =
|
||||||
{ CRGB::Red, CRGB::Red, CRGB::Red, CRGB::Red,
|
{ CRGB::Red, CRGB::Red, CRGB::Red, CRGB::Red,
|
||||||
CRGB::Red, CRGB::Red, CRGB::Red, CRGB::Red,
|
CRGB::Red, CRGB::Red, CRGB::Red, CRGB::Red,
|
||||||
CRGB::Red, CRGB::Red, CRGB::Gray, CRGB::Gray,
|
CRGB::Red, CRGB::Red, CRGB::Gray, CRGB::Gray,
|
||||||
CRGB::Green, CRGB::Green, CRGB::Green, CRGB::Green };
|
CRGB::Green, CRGB::Green, CRGB::Green, CRGB::Green };
|
||||||
@ -240,7 +329,7 @@ const TProgmemRGBPalette16 RedGreenWhite_p FL_PROGMEM =
|
|||||||
#define Holly_Green 0x00580c
|
#define Holly_Green 0x00580c
|
||||||
#define Holly_Red 0xB00402
|
#define Holly_Red 0xB00402
|
||||||
const TProgmemRGBPalette16 Holly_p FL_PROGMEM =
|
const TProgmemRGBPalette16 Holly_p FL_PROGMEM =
|
||||||
{ Holly_Green, Holly_Green, Holly_Green, Holly_Green,
|
{ Holly_Green, Holly_Green, Holly_Green, Holly_Green,
|
||||||
Holly_Green, Holly_Green, Holly_Green, Holly_Green,
|
Holly_Green, Holly_Green, Holly_Green, Holly_Green,
|
||||||
Holly_Green, Holly_Green, Holly_Green, Holly_Green,
|
Holly_Green, Holly_Green, Holly_Green, Holly_Green,
|
||||||
Holly_Green, Holly_Green, Holly_Green, Holly_Red
|
Holly_Green, Holly_Green, Holly_Green, Holly_Red
|
||||||
@ -249,7 +338,7 @@ const TProgmemRGBPalette16 Holly_p FL_PROGMEM =
|
|||||||
// A red and white striped palette
|
// A red and white striped palette
|
||||||
// "CRGB::Gray" is used as white to keep the brightness more uniform.
|
// "CRGB::Gray" is used as white to keep the brightness more uniform.
|
||||||
const TProgmemRGBPalette16 RedWhite_p FL_PROGMEM =
|
const TProgmemRGBPalette16 RedWhite_p FL_PROGMEM =
|
||||||
{ CRGB::Red, CRGB::Red, CRGB::Gray, CRGB::Gray,
|
{ CRGB::Red, CRGB::Red, CRGB::Gray, CRGB::Gray,
|
||||||
CRGB::Red, CRGB::Red, CRGB::Gray, CRGB::Gray,
|
CRGB::Red, CRGB::Red, CRGB::Gray, CRGB::Gray,
|
||||||
CRGB::Red, CRGB::Red, CRGB::Gray, CRGB::Gray,
|
CRGB::Red, CRGB::Red, CRGB::Gray, CRGB::Gray,
|
||||||
CRGB::Red, CRGB::Red, CRGB::Gray, CRGB::Gray };
|
CRGB::Red, CRGB::Red, CRGB::Gray, CRGB::Gray };
|
||||||
@ -257,7 +346,7 @@ const TProgmemRGBPalette16 RedWhite_p FL_PROGMEM =
|
|||||||
// A mostly blue palette with white accents.
|
// A mostly blue palette with white accents.
|
||||||
// "CRGB::Gray" is used as white to keep the brightness more uniform.
|
// "CRGB::Gray" is used as white to keep the brightness more uniform.
|
||||||
const TProgmemRGBPalette16 BlueWhite_p FL_PROGMEM =
|
const TProgmemRGBPalette16 BlueWhite_p FL_PROGMEM =
|
||||||
{ CRGB::Blue, CRGB::Blue, CRGB::Blue, CRGB::Blue,
|
{ CRGB::Blue, CRGB::Blue, CRGB::Blue, CRGB::Blue,
|
||||||
CRGB::Blue, CRGB::Blue, CRGB::Blue, CRGB::Blue,
|
CRGB::Blue, CRGB::Blue, CRGB::Blue, CRGB::Blue,
|
||||||
CRGB::Blue, CRGB::Blue, CRGB::Blue, CRGB::Blue,
|
CRGB::Blue, CRGB::Blue, CRGB::Blue, CRGB::Blue,
|
||||||
CRGB::Blue, CRGB::Gray, CRGB::Gray, CRGB::Gray };
|
CRGB::Blue, CRGB::Gray, CRGB::Gray, CRGB::Gray };
|
||||||
@ -266,14 +355,14 @@ const TProgmemRGBPalette16 BlueWhite_p FL_PROGMEM =
|
|||||||
#define HALFFAIRY ((CRGB::FairyLight & 0xFEFEFE) / 2)
|
#define HALFFAIRY ((CRGB::FairyLight & 0xFEFEFE) / 2)
|
||||||
#define QUARTERFAIRY ((CRGB::FairyLight & 0xFCFCFC) / 4)
|
#define QUARTERFAIRY ((CRGB::FairyLight & 0xFCFCFC) / 4)
|
||||||
const TProgmemRGBPalette16 FairyLight_p FL_PROGMEM =
|
const TProgmemRGBPalette16 FairyLight_p FL_PROGMEM =
|
||||||
{ CRGB::FairyLight, CRGB::FairyLight, CRGB::FairyLight, CRGB::FairyLight,
|
{ CRGB::FairyLight, CRGB::FairyLight, CRGB::FairyLight, CRGB::FairyLight,
|
||||||
HALFFAIRY, HALFFAIRY, CRGB::FairyLight, CRGB::FairyLight,
|
HALFFAIRY, HALFFAIRY, CRGB::FairyLight, CRGB::FairyLight,
|
||||||
QUARTERFAIRY, QUARTERFAIRY, CRGB::FairyLight, CRGB::FairyLight,
|
QUARTERFAIRY, QUARTERFAIRY, CRGB::FairyLight, CRGB::FairyLight,
|
||||||
CRGB::FairyLight, CRGB::FairyLight, CRGB::FairyLight, CRGB::FairyLight };
|
CRGB::FairyLight, CRGB::FairyLight, CRGB::FairyLight, CRGB::FairyLight };
|
||||||
|
|
||||||
// A palette of soft snowflakes with the occasional bright one
|
// A palette of soft snowflakes with the occasional bright one
|
||||||
const TProgmemRGBPalette16 Snow_p FL_PROGMEM =
|
const TProgmemRGBPalette16 Snow_p FL_PROGMEM =
|
||||||
{ 0x304048, 0x304048, 0x304048, 0x304048,
|
{ 0x304048, 0x304048, 0x304048, 0x304048,
|
||||||
0x304048, 0x304048, 0x304048, 0x304048,
|
0x304048, 0x304048, 0x304048, 0x304048,
|
||||||
0x304048, 0x304048, 0x304048, 0x304048,
|
0x304048, 0x304048, 0x304048, 0x304048,
|
||||||
0x304048, 0x304048, 0x304048, 0xE0F0FF };
|
0x304048, 0x304048, 0x304048, 0xE0F0FF };
|
||||||
@ -286,7 +375,7 @@ const TProgmemRGBPalette16 Snow_p FL_PROGMEM =
|
|||||||
#define C9_Blue 0x070758
|
#define C9_Blue 0x070758
|
||||||
#define C9_White 0x606820
|
#define C9_White 0x606820
|
||||||
const TProgmemRGBPalette16 RetroC9_p FL_PROGMEM =
|
const TProgmemRGBPalette16 RetroC9_p FL_PROGMEM =
|
||||||
{ C9_Red, C9_Orange, C9_Red, C9_Orange,
|
{ C9_Red, C9_Orange, C9_Red, C9_Orange,
|
||||||
C9_Orange, C9_Red, C9_Orange, C9_Red,
|
C9_Orange, C9_Red, C9_Orange, C9_Red,
|
||||||
C9_Green, C9_Green, C9_Green, C9_Green,
|
C9_Green, C9_Green, C9_Green, C9_Green,
|
||||||
C9_Blue, C9_Blue, C9_Blue,
|
C9_Blue, C9_Blue, C9_Blue,
|
||||||
|
53
Twinkles.h
@ -7,17 +7,17 @@
|
|||||||
|
|
||||||
enum { GETTING_DARKER = 0, GETTING_BRIGHTER = 1 };
|
enum { GETTING_DARKER = 0, GETTING_BRIGHTER = 1 };
|
||||||
|
|
||||||
CRGB makeBrighter( const CRGB& color, fract8 howMuchBrighter)
|
CRGB makeBrighter(const CRGB& color, fract8 howMuchBrighter)
|
||||||
{
|
{
|
||||||
CRGB incrementalColor = color;
|
CRGB incrementalColor = color;
|
||||||
incrementalColor.nscale8( howMuchBrighter);
|
incrementalColor.nscale8(howMuchBrighter);
|
||||||
return color + incrementalColor;
|
return color + incrementalColor;
|
||||||
}
|
}
|
||||||
|
|
||||||
CRGB makeDarker( const CRGB& color, fract8 howMuchDarker)
|
CRGB makeDarker(const CRGB& color, fract8 howMuchDarker)
|
||||||
{
|
{
|
||||||
CRGB newcolor = color;
|
CRGB newcolor = color;
|
||||||
newcolor.nscale8( 255 - howMuchDarker);
|
newcolor.nscale8(255 - howMuchDarker);
|
||||||
return newcolor;
|
return newcolor;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -26,9 +26,9 @@ CRGB makeDarker( const CRGB& color, fract8 howMuchDarker)
|
|||||||
// per pixel. This requires a bunch of bit wrangling,
|
// per pixel. This requires a bunch of bit wrangling,
|
||||||
// but conserves precious RAM. The cost is a few
|
// but conserves precious RAM. The cost is a few
|
||||||
// cycles and about 100 bytes of flash program memory.
|
// cycles and about 100 bytes of flash program memory.
|
||||||
uint8_t directionFlags[ (NUM_LEDS + 7) / 8];
|
uint8_t directionFlags[(NUM_LEDS + 7) / 8];
|
||||||
|
|
||||||
bool getPixelDirection( uint16_t i)
|
bool getPixelDirection(uint16_t i)
|
||||||
{
|
{
|
||||||
uint16_t index = i / 8;
|
uint16_t index = i / 8;
|
||||||
uint8_t bitNum = i & 0x07;
|
uint8_t bitNum = i & 0x07;
|
||||||
@ -37,7 +37,7 @@ bool getPixelDirection( uint16_t i)
|
|||||||
return (directionFlags[index] & andMask) != 0;
|
return (directionFlags[index] & andMask) != 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void setPixelDirection( uint16_t i, bool dir)
|
void setPixelDirection(uint16_t i, bool dir)
|
||||||
{
|
{
|
||||||
uint16_t index = i / 8;
|
uint16_t index = i / 8;
|
||||||
uint8_t bitNum = i & 0x07;
|
uint8_t bitNum = i & 0x07;
|
||||||
@ -45,25 +45,26 @@ void setPixelDirection( uint16_t i, bool dir)
|
|||||||
uint8_t orMask = 1 << bitNum;
|
uint8_t orMask = 1 << bitNum;
|
||||||
uint8_t andMask = 255 - orMask;
|
uint8_t andMask = 255 - orMask;
|
||||||
uint8_t value = directionFlags[index] & andMask;
|
uint8_t value = directionFlags[index] & andMask;
|
||||||
if ( dir ) {
|
if (dir) {
|
||||||
value += orMask;
|
value += orMask;
|
||||||
}
|
}
|
||||||
directionFlags[index] = value;
|
directionFlags[index] = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
void brightenOrDarkenEachPixel( fract8 fadeUpAmount, fract8 fadeDownAmount)
|
void brightenOrDarkenEachPixel(fract8 fadeUpAmount, fract8 fadeDownAmount)
|
||||||
{
|
{
|
||||||
for ( uint16_t i = 0; i < NUM_LEDS; i++) {
|
for (uint16_t i = 0; i < LEAFCOUNT; i++) {
|
||||||
if ( getPixelDirection(i) == GETTING_DARKER) {
|
if (getPixelDirection(i*PIXELS_PER_LEAF) == GETTING_DARKER) {
|
||||||
// This pixel is getting darker
|
// This pixel is getting darker
|
||||||
leds[i] = makeDarker( leds[i], fadeDownAmount);
|
for (int i2 = 0; i2 < PIXELS_PER_LEAF; i2++)leds[i*PIXELS_PER_LEAF + i2] = makeDarker(leds[i*PIXELS_PER_LEAF + i2], fadeDownAmount);
|
||||||
} else {
|
}
|
||||||
|
else {
|
||||||
// This pixel is getting brighter
|
// This pixel is getting brighter
|
||||||
leds[i] = makeBrighter( leds[i], fadeUpAmount);
|
for (int i2 = 0; i2 < PIXELS_PER_LEAF; i2++)leds[i*PIXELS_PER_LEAF + i2] = makeBrighter(leds[i*PIXELS_PER_LEAF + i2], fadeUpAmount);
|
||||||
// now check to see if we've maxxed out the brightness
|
// now check to see if we've maxxed out the brightness
|
||||||
if ( leds[i].r == 255 || leds[i].g == 255 || leds[i].b == 255) {
|
if (leds[i*PIXELS_PER_LEAF].r == 255 || leds[i*PIXELS_PER_LEAF].g == 255 || leds[i*PIXELS_PER_LEAF].b == 255) {
|
||||||
// if so, turn around and start getting darker
|
// if so, turn around and start getting darker
|
||||||
setPixelDirection(i, GETTING_DARKER);
|
for (int i2 = 0; i2 < PIXELS_PER_LEAF; i2++)setPixelDirection(i*PIXELS_PER_LEAF + i2, GETTING_DARKER);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -75,14 +76,18 @@ void colortwinkles()
|
|||||||
{
|
{
|
||||||
// Make each pixel brighter or darker, depending on
|
// Make each pixel brighter or darker, depending on
|
||||||
// its 'direction' flag.
|
// its 'direction' flag.
|
||||||
brightenOrDarkenEachPixel( FADE_IN_SPEED, FADE_OUT_SPEED);
|
brightenOrDarkenEachPixel(FADE_IN_SPEED, FADE_OUT_SPEED);
|
||||||
|
|
||||||
// Now consider adding a new random twinkle
|
// Now consider adding a new random twinkle
|
||||||
if ( random8() < DENSITY ) {
|
if (random8() < DENSITY) {
|
||||||
int pos = random16(NUM_LEDS);
|
int pos = random16(LEAFCOUNT);
|
||||||
if ( !leds[pos]) {
|
if (!leds[pos]) {
|
||||||
leds[pos] = ColorFromPalette( gCurrentPalette, random8(), STARTING_BRIGHTNESS, NOBLEND);
|
uint8_t rdo = random8();
|
||||||
setPixelDirection(pos, GETTING_BRIGHTER);
|
for (int i = 0; i < PIXELS_PER_LEAF; i++)
|
||||||
|
{
|
||||||
|
leds[pos*PIXELS_PER_LEAF + i] = ColorFromPalette(gCurrentPalette, rdo, STARTING_BRIGHTNESS, NOBLEND);
|
||||||
|
setPixelDirection(pos*PIXELS_PER_LEAF + i, GETTING_BRIGHTER);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -104,7 +109,7 @@ void snowTwinkles()
|
|||||||
{
|
{
|
||||||
CRGB w(85, 85, 85), W(CRGB::White);
|
CRGB w(85, 85, 85), W(CRGB::White);
|
||||||
|
|
||||||
gCurrentPalette = CRGBPalette16( W, W, W, W, w, w, w, w, w, w, w, w, w, w, w, w );
|
gCurrentPalette = CRGBPalette16(W, W, W, W, w, w, w, w, w, w, w, w, w, w, w, w);
|
||||||
colortwinkles();
|
colortwinkles();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -112,7 +117,7 @@ void incandescentTwinkles()
|
|||||||
{
|
{
|
||||||
CRGB l(0xE1A024);
|
CRGB l(0xE1A024);
|
||||||
|
|
||||||
gCurrentPalette = CRGBPalette16( l, l, l, l, l, l, l, l, l, l, l, l, l, l, l, l );
|
gCurrentPalette = CRGBPalette16(l, l, l, l, l, l, l, l, l, l, l, l, l, l, l, l);
|
||||||
colortwinkles();
|
colortwinkles();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
186
WiFi.h
@ -1,186 +0,0 @@
|
|||||||
//#include <DNSServer.h>
|
|
||||||
|
|
||||||
//DNSServer dnsServer;
|
|
||||||
|
|
||||||
//const byte DNS_PORT = 53;
|
|
||||||
|
|
||||||
// bool apMode = false;
|
|
||||||
|
|
||||||
// AP mode password
|
|
||||||
const char WiFiAPPSK[] = "";
|
|
||||||
|
|
||||||
// Wi-Fi network to connect to (if not in AP mode)
|
|
||||||
char* ssid = "";
|
|
||||||
char* password = "";
|
|
||||||
|
|
||||||
#define HOSTNAME "ESP8266-" ///< Hostname. The initializeWiFi function adds the Chip ID at the end.
|
|
||||||
|
|
||||||
#define DEBUG_WIFI 1
|
|
||||||
|
|
||||||
unsigned long futureTimeout = 0;
|
|
||||||
uint16_t connectionTimeout = 20000;
|
|
||||||
|
|
||||||
template <typename Generic>
|
|
||||||
void debugPrintln(Generic text) {
|
|
||||||
if (DEBUG_WIFI) {
|
|
||||||
Serial.print("*WiFi: ");
|
|
||||||
Serial.println(text);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void startAp() {
|
|
||||||
// WiFi.disconnect();
|
|
||||||
|
|
||||||
// apMode = true;
|
|
||||||
|
|
||||||
// WiFi.mode(WIFI_AP_STA);
|
|
||||||
// debugPrintln("SET AP STA");
|
|
||||||
|
|
||||||
String AP_NameString = "ESP8266-";
|
|
||||||
AP_NameString += String(ESP.getChipId(), HEX);
|
|
||||||
|
|
||||||
char AP_NameChar[AP_NameString.length() + 1];
|
|
||||||
memset(AP_NameChar, 0, AP_NameString.length() + 1);
|
|
||||||
|
|
||||||
for (int i = 0; i < AP_NameString.length(); i++)
|
|
||||||
AP_NameChar[i] = AP_NameString.charAt(i);
|
|
||||||
|
|
||||||
debugPrintln("Starting soft AP");
|
|
||||||
|
|
||||||
if (WiFiAPPSK != NULL) {
|
|
||||||
debugPrintln(WiFi.softAP(AP_NameChar, WiFiAPPSK) ? "ready" : "failed");
|
|
||||||
} else {
|
|
||||||
debugPrintln(WiFi.softAP(AP_NameChar) ? "ready" : "failed");
|
|
||||||
}
|
|
||||||
|
|
||||||
debugPrintln("Connect to Wi-Fi access point: ");
|
|
||||||
debugPrintln(AP_NameChar);
|
|
||||||
|
|
||||||
delay(500); // Without delay I've seen the IP address blank
|
|
||||||
debugPrintln("AP IP address: ");
|
|
||||||
debugPrintln(WiFi.softAPIP());
|
|
||||||
|
|
||||||
// dnsServer.setErrorReplyCode(DNSReplyCode::NoError);
|
|
||||||
// dnsServer.start(DNS_PORT, "*", WiFi.softAPIP());
|
|
||||||
}
|
|
||||||
|
|
||||||
String getWiFiJson() {
|
|
||||||
String hostname = String(HOSTNAME);
|
|
||||||
hostname += String(ESP.getChipId(), HEX);
|
|
||||||
|
|
||||||
String json = "{";
|
|
||||||
|
|
||||||
json += "\"status\":\"" + String(WiFi.status()) + "\"";
|
|
||||||
json += ",\"localIP\":\"" + WiFi.localIP().toString() + "\"";
|
|
||||||
json += ",\"softAPIP\":\"" + WiFi.softAPIP().toString() + "\"";
|
|
||||||
json += ",\"hostname\":\"" + hostname + "\"";
|
|
||||||
json += ",\"ssid\":\"" + WiFi.SSID() + "\"";
|
|
||||||
json += ",\"rssi\":\"" + String(WiFi.RSSI()) + "\"";
|
|
||||||
|
|
||||||
// json += ",\"networks\":[";
|
|
||||||
// byte ssidCount = WiFi.scanNetworks();
|
|
||||||
// for (byte i = 0; i < ssidCount; i++) {
|
|
||||||
// if (i > 0)
|
|
||||||
// json += ",";
|
|
||||||
//
|
|
||||||
// json += "{\"name\":\"" + WiFi.SSID(i) + "\",\"rssi\":\"" + String(WiFi.RSSI(i)) + "\"}";
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// json += "]";
|
|
||||||
|
|
||||||
json += "}";
|
|
||||||
|
|
||||||
return json;
|
|
||||||
}
|
|
||||||
|
|
||||||
void initializeWiFi() {
|
|
||||||
WiFi.mode(WIFI_AP_STA);
|
|
||||||
|
|
||||||
// Set Hostname.
|
|
||||||
String hostname = String(HOSTNAME);
|
|
||||||
hostname += String(ESP.getChipId(), HEX);
|
|
||||||
WiFi.hostname(hostname);
|
|
||||||
|
|
||||||
// Print hostname.
|
|
||||||
Serial.println("Hostname: " + hostname);
|
|
||||||
|
|
||||||
char hostnameChar[hostname.length() + 1];
|
|
||||||
memset(hostnameChar, 0, hostname.length() + 1);
|
|
||||||
|
|
||||||
for (uint8_t i = 0; i < hostname.length(); i++)
|
|
||||||
hostnameChar[i] = hostname.charAt(i);
|
|
||||||
|
|
||||||
// MDNS.begin(hostnameChar);
|
|
||||||
|
|
||||||
// Add service to MDNS-SD
|
|
||||||
// MDNS.addService("http", "tcp", 80);
|
|
||||||
|
|
||||||
// attempt to connect; should it fail, fall back to AP mode
|
|
||||||
// WiFi.mode(WIFI_STA);
|
|
||||||
|
|
||||||
String stored_ssid = WiFi.SSID();
|
|
||||||
if (stored_ssid != NULL && stored_ssid != "") {
|
|
||||||
debugPrintln("Connecting to stored SSID:");
|
|
||||||
debugPrintln(stored_ssid);
|
|
||||||
WiFi.begin();
|
|
||||||
} else {
|
|
||||||
debugPrintln("No stored SSID");
|
|
||||||
}
|
|
||||||
|
|
||||||
startAp();
|
|
||||||
|
|
||||||
webServer.on("/wifi", HTTP_POST, []() {
|
|
||||||
String ssid = webServer.arg("ssid");
|
|
||||||
String password = webServer.arg("password");
|
|
||||||
// String mode = webServer.arg("mode");
|
|
||||||
|
|
||||||
char ssidChars[50];
|
|
||||||
ssid.toCharArray(ssidChars, 50);
|
|
||||||
|
|
||||||
char passwordChars[50];
|
|
||||||
password.toCharArray(passwordChars, 50);
|
|
||||||
|
|
||||||
debugPrintln("Connecting to new SSID:");
|
|
||||||
debugPrintln(ssid);
|
|
||||||
|
|
||||||
// dnsServer.stop();
|
|
||||||
// WiFi.softAPdisconnect(true);
|
|
||||||
|
|
||||||
// apMode = false;
|
|
||||||
// WiFi.mode(WIFI_STA);
|
|
||||||
WiFi.begin(ssidChars, passwordChars);
|
|
||||||
// futureTimeout = millis() + connectionTimeout;
|
|
||||||
|
|
||||||
webServer.sendHeader("Location", "/wifi.htm");
|
|
||||||
webServer.send(303);
|
|
||||||
});
|
|
||||||
|
|
||||||
webServer.on("/wifi", HTTP_GET, []() {
|
|
||||||
String json = getWiFiJson();
|
|
||||||
webServer.send(200, "application/json", json);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
void checkWiFi() {
|
|
||||||
// if (WiFi.status() == WL_CONNECTED) {
|
|
||||||
// debugPrintln("connected");
|
|
||||||
// futureTimeout = millis() + connectionTimeout;
|
|
||||||
// return;
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// if (apMode) {
|
|
||||||
// debugPrintln("Already running in AP mode.");
|
|
||||||
// return;
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// // time to give up on the stored network and switch to ap mode?
|
|
||||||
// if (futureTimeout != 0 && millis() < futureTimeout) {
|
|
||||||
// return;
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// debugPrintln("Switching to AP mode, timeout elapsed: ");
|
|
||||||
// debugPrintln(connectionTimeout);
|
|
||||||
//
|
|
||||||
// startApMode();
|
|
||||||
}
|
|
||||||
|
|
@ -1,27 +1,20 @@
|
|||||||
<!DOCTYPE html>
|
<!DOCTYPE html>
|
||||||
<html>
|
<html>
|
||||||
|
|
||||||
<head>
|
<head>
|
||||||
<meta charset="utf-8">
|
<meta charset="utf-8">
|
||||||
<meta http-equiv="X-UA-Compatible" content="IE=edge">
|
<meta http-equiv="X-UA-Compatible" content="IE=edge">
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1">
|
<meta name="viewport" content="width=device-width, initial-scale=1">
|
||||||
<title>ESP8266 + FastLED by Evil Genius Labs</title>
|
<title>ESP8266 + FastLED by Evil Genius Labs</title>
|
||||||
|
|
||||||
<!-- request CSS from internet CDN -->
|
<!-- request CSS from internet CDN -->
|
||||||
<!-- <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha384-BVYiiSIFeK1dGmJRAkycuHAHRg32OmUcww7on3RYdg4Va+PmSTsz/K68vbdEjh4u" crossorigin="anonymous"> -->
|
<!-- <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha384-BVYiiSIFeK1dGmJRAkycuHAHRg32OmUcww7on3RYdg4Va+PmSTsz/K68vbdEjh4u" crossorigin="anonymous"> -->
|
||||||
<!-- <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/jquery-minicolors/2.2.4/jquery.minicolors.min.css" integrity="sha256-4wnSkPYU5B4yngAlx/rEb8LdfMah4teUth4AfhGEuaY=" crossorigin="anonymous" /> -->
|
<!-- <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/jquery-minicolors/2.2.4/jquery.minicolors.min.css" integrity="sha256-4wnSkPYU5B4yngAlx/rEb8LdfMah4teUth4AfhGEuaY=" crossorigin="anonymous" /> -->
|
||||||
|
|
||||||
<!-- request CSS from the ESP8266 web server -->
|
<!-- request CSS from the ESP8266 web server -->
|
||||||
<link rel="stylesheet" href="css/bootstrap.min.css">
|
<link rel="stylesheet" href="css/bootstrap.min.css">
|
||||||
<link rel="stylesheet" href="css/minicolors.min.css">
|
<link rel="stylesheet" href="css/minicolors.min.css">
|
||||||
|
|
||||||
<link rel="stylesheet" href="css/styles.css">
|
<link rel="stylesheet" href="css/styles.css">
|
||||||
|
|
||||||
<link rel="icon" href="images/atom196.png">
|
<link rel="icon" href="images/atom196.png">
|
||||||
</head>
|
</head>
|
||||||
|
|
||||||
<body>
|
<body>
|
||||||
|
|
||||||
<nav class="navbar navbar-default navbar-static-top" id="top" role="banner">
|
<nav class="navbar navbar-default navbar-static-top" id="top" role="banner">
|
||||||
<div class="container">
|
<div class="container">
|
||||||
<div class="navbar-header">
|
<div class="navbar-header">
|
||||||
@ -36,7 +29,7 @@
|
|||||||
</div>
|
</div>
|
||||||
<div class="collapse navbar-collapse" id="navbar-collapse-1">
|
<div class="collapse navbar-collapse" id="navbar-collapse-1">
|
||||||
<ul class="nav navbar-nav">
|
<ul class="nav navbar-nav">
|
||||||
<li class="active"><a href="/">ESP8266 + FastLED <span class="sr-only">(current)</span></a></li>
|
<li class="active"><a href="/">DIY Nanoleaf control <span class="sr-only">(current)</span></a></li>
|
||||||
<li><a href="/simple.htm" target="_blank" title="Simple Mode">Simple</a></li>
|
<li><a href="/simple.htm" target="_blank" title="Simple Mode">Simple</a></li>
|
||||||
<li><a href="/edit.htm" target="_blank" title="Edit Files">Files</a></li>
|
<li><a href="/edit.htm" target="_blank" title="Edit Files">Files</a></li>
|
||||||
<li><a href="/update" target="_blank" title="Update Firmware">Firmware</a></li>
|
<li><a href="/update" target="_blank" title="Update Firmware">Firmware</a></li>
|
||||||
@ -52,22 +45,15 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</nav>
|
</nav>
|
||||||
|
|
||||||
<div id="container" class="container">
|
<div id="container" class="container">
|
||||||
|
<form class="form-horizontal" id="form"></form>
|
||||||
<form class="form-horizontal" id="form">
|
|
||||||
</form>
|
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div id="templates" style="display: none">
|
<div id="templates" style="display: none">
|
||||||
|
|
||||||
<div id="sectionTemplate" class="form-group">
|
<div id="sectionTemplate" class="form-group">
|
||||||
<div class="col-sm-12">
|
<div class="col-sm-12">
|
||||||
<hr style="margin-bottom: 5px;margin-top: 5px;" />
|
<hr style="margin-bottom: 5px;margin-top: 5px;" />
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div id="numberTemplate" class="form-group">
|
<div id="numberTemplate" class="form-group">
|
||||||
<label class="col-sm-2 control-label"></label>
|
<label class="col-sm-2 control-label"></label>
|
||||||
<div class="col-sm-2">
|
<div class="col-sm-2">
|
||||||
@ -77,7 +63,6 @@
|
|||||||
<input class="form-control slider" type="range" step="1" min="0" max="255" />
|
<input class="form-control slider" type="range" step="1" min="0" max="255" />
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div id="booleanTemplate" class="form-group">
|
<div id="booleanTemplate" class="form-group">
|
||||||
<label class="col-sm-2 control-label"></label>
|
<label class="col-sm-2 control-label"></label>
|
||||||
<div class="col-sm-10">
|
<div class="col-sm-10">
|
||||||
@ -87,7 +72,6 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div id="selectTemplate" class="form-group">
|
<div id="selectTemplate" class="form-group">
|
||||||
<label class="col-sm-2 control-label"></label>
|
<label class="col-sm-2 control-label"></label>
|
||||||
<div class="col-sm-8">
|
<div class="col-sm-8">
|
||||||
@ -107,8 +91,36 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<div id="booleanTemplate" class="form-group">
|
||||||
|
<label class="col-sm-2 control-label"></label>
|
||||||
|
<div class="col-sm-10">
|
||||||
|
<div class="btn-group" role="group">
|
||||||
|
<button type="button" class="btn btn-default" id="btnOn">On</button>
|
||||||
|
<button type="button" class="btn btn-default" id="btnOff">Off</button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div id="selectTemplate" class="form-group">
|
||||||
|
<label class="col-sm-2 control-label"></label>
|
||||||
|
<div class="col-sm-8">
|
||||||
|
<select class="form-control"><select>
|
||||||
|
</div>
|
||||||
|
<div class="col-sm-2">
|
||||||
|
<div class="btn-group" role="group" aria-label="...">
|
||||||
|
<button type="button" class="btn btn-default btn-previous"
|
||||||
|
aria-label="Previous" title="Previous">
|
||||||
|
<span class="glyphicon glyphicon-chevron-left"></span>
|
||||||
|
</button>
|
||||||
|
<button type="button" class="btn btn-default btn-next"
|
||||||
|
aria-label="Next" title="Next">
|
||||||
|
<span class="glyphicon glyphicon-chevron-right"></span>
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
<div id="colorPaletteTemplate" class="form-group">
|
<div id="colorPaletteTemplate" class="form-group">
|
||||||
<label class="col-sm-2 control-label color-label"></label>
|
<label class="col-sm-2 control-label color-label"></label>
|
||||||
|
|
||||||
<div class="col-sm-10">
|
<div class="col-sm-10">
|
||||||
<div class="btn-group btn-group-justified" role="group">
|
<div class="btn-group btn-group-justified" role="group">
|
||||||
<div class="btn-group" role="group">
|
<div class="btn-group" role="group">
|
||||||
@ -153,7 +165,6 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div id="colorTemplate">
|
<div id="colorTemplate">
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<!-- <label class="col-sm-2 control-label color-label"></label> -->
|
<!-- <label class="col-sm-2 control-label color-label"></label> -->
|
||||||
@ -189,9 +200,7 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<nav class="navbar navbar-default navbar-fixed-bottom">
|
<nav class="navbar navbar-default navbar-fixed-bottom">
|
||||||
<div class="container">
|
<div class="container">
|
||||||
<div class="navbar-header">
|
<div class="navbar-header">
|
||||||
@ -214,21 +223,16 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</nav>
|
</nav>
|
||||||
|
|
||||||
<!-- request js from internet CDN -->
|
<!-- request js from internet CDN -->
|
||||||
<!-- <script src="https://code.jquery.com/jquery-3.1.1.min.js" integrity="sha256-hVVnYaiADRTO2PzUGmuLJr8BLUSjGIZsDYGmIJLv2b8=" crossorigin="anonymous"></script> -->
|
<!-- <script src="https://code.jquery.com/jquery-3.1.1.min.js" integrity="sha256-hVVnYaiADRTO2PzUGmuLJr8BLUSjGIZsDYGmIJLv2b8=" crossorigin="anonymous"></script> -->
|
||||||
<!-- <script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha384-Tc5IQib027qvyjSMfHjOMaLkfuWVxZxUPnCJA7l2mCWNIpG9mGCD8wGNIcPD7Txa" crossorigin="anonymous"></script> -->
|
<!-- <script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha384-Tc5IQib027qvyjSMfHjOMaLkfuWVxZxUPnCJA7l2mCWNIpG9mGCD8wGNIcPD7Txa" crossorigin="anonymous"></script> -->
|
||||||
<!-- <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery-minicolors/2.2.4/jquery.minicolors.min.js" integrity="sha256-XAFQ9dZ6hy8p/GRhU8h/8pMvM1etymiJLZW1CiHV3bQ=" crossorigin="anonymous"></script> -->
|
<!-- <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery-minicolors/2.2.4/jquery.minicolors.min.js" integrity="sha256-XAFQ9dZ6hy8p/GRhU8h/8pMvM1etymiJLZW1CiHV3bQ=" crossorigin="anonymous"></script> -->
|
||||||
<!-- <script src="https://cdnjs.cloudflare.com/ajax/libs/reconnecting-websocket/1.0.0/reconnecting-websocket.min.js" integrity="sha256-A4JwlcDvqO4JXpvEtvWY1RH8JAEMu5W21wP8GUXLUNs=" crossorigin="anonymous"></script> -->
|
<!-- <script src="https://cdnjs.cloudflare.com/ajax/libs/reconnecting-websocket/1.0.0/reconnecting-websocket.min.js" integrity="sha256-A4JwlcDvqO4JXpvEtvWY1RH8JAEMu5W21wP8GUXLUNs=" crossorigin="anonymous"></script> -->
|
||||||
|
|
||||||
<!-- request js from the ESP8266 web server -->
|
<!-- request js from the ESP8266 web server -->
|
||||||
<script src="js/jquery-3.1.1.min.js"></script>
|
<script src="js/jquery-3.1.1.min.js"></script>
|
||||||
<script src="js/bootstrap.min.js"></script>
|
<script src="js/bootstrap.min.js"></script>
|
||||||
<script src="js/minicolors.min.js"></script>
|
<script src="js/minicolors.min.js"></script>
|
||||||
<script src="js/r-websocket.min.js"></script>
|
<script src="js/r-websocket.min.js"></script>
|
||||||
|
|
||||||
<script src="js/app.js"></script>
|
<script src="js/app.js"></script>
|
||||||
|
|
||||||
</body>
|
</body>
|
||||||
|
|
||||||
</html>
|
</html>
|
||||||
|
@ -50,6 +50,7 @@
|
|||||||
<!-- request js from the ESP8266 web server -->
|
<!-- request js from the ESP8266 web server -->
|
||||||
<script src="js/jquery-3.1.1.min.js"></script>
|
<script src="js/jquery-3.1.1.min.js"></script>
|
||||||
<script src="js/bootstrap.min.js"></script>
|
<script src="js/bootstrap.min.js"></script>
|
||||||
|
<script src="js/r-websocket.min.js"></script>
|
||||||
|
|
||||||
<script src="js/simple.js"></script>
|
<script src="js/simple.js"></script>
|
||||||
|
|
||||||
|
BIN
gallery/DSC_8613.JPG
Normal file
After Width: | Height: | Size: 5.1 MiB |
BIN
gallery/DSC_8614.JPG
Normal file
After Width: | Height: | Size: 5.3 MiB |
BIN
gallery/DSC_8615.JPG
Normal file
After Width: | Height: | Size: 5.8 MiB |
BIN
gallery/DSC_8618.JPG
Normal file
After Width: | Height: | Size: 5.7 MiB |
BIN
gallery/DSC_8621.JPG
Normal file
After Width: | Height: | Size: 6.5 MiB |
BIN
gallery/DSC_8622.JPG
Normal file
After Width: | Height: | Size: 6.2 MiB |
BIN
gallery/DSC_8623.JPG
Normal file
After Width: | Height: | Size: 6.0 MiB |
BIN
gallery/DSC_8624.JPG
Normal file
After Width: | Height: | Size: 6.1 MiB |
BIN
gallery/circuit.jpg
Normal file
After Width: | Height: | Size: 190 KiB |
BIN
gallery/circuit_logic_level_Steckplatine.jpg
Normal file
After Width: | Height: | Size: 236 KiB |
BIN
gallery/interface.jpg
Normal file
After Width: | Height: | Size: 314 KiB |
BIN
gallery/rgb_preview2.gif
Normal file
After Width: | Height: | Size: 13 MiB |
BIN
gallery/thumb.JPG
Normal file
After Width: | Height: | Size: 2.4 MiB |