Add Animartrix
This commit is contained in:
parent
7d84de6690
commit
61d3eafa1d
10
usermods/usermod_v2_animartrix/readme.md
Normal file
10
usermods/usermod_v2_animartrix/readme.md
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
# Usermods API v2 example usermod
|
||||||
|
|
||||||
|
In this usermod file you can find the documentation on how to take advantage of the new version 2 usermods!
|
||||||
|
|
||||||
|
## Installation
|
||||||
|
|
||||||
|
Copy `usermod_v2_animartrix.h` to the wled00 directory.
|
||||||
|
Uncomment the corresponding lines in `usermods_list.cpp` and compile!
|
||||||
|
_(You shouldn't need to actually install this, it does nothing useful)_
|
||||||
|
|
447
usermods/usermod_v2_animartrix/usermod_v2_animartrix.h
Normal file
447
usermods/usermod_v2_animartrix/usermod_v2_animartrix.h
Normal file
@ -0,0 +1,447 @@
|
|||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include "wled.h"
|
||||||
|
#include <ANIMartRIX.h>
|
||||||
|
|
||||||
|
#warning WLEDMM usermod: CC BY-NC 3.0 licensed effects by Stefan Petrick, include this usermod only if you accept the terms!
|
||||||
|
//========================================================================================================================
|
||||||
|
|
||||||
|
|
||||||
|
static const char _data_FX_mode_Module_Experiment10[] PROGMEM = "💡Module_Experiment10 ☾@;;1";
|
||||||
|
static const char _data_FX_mode_Module_Experiment9[] PROGMEM = "💡Module_Experiment9 ☾@;;1";
|
||||||
|
static const char _data_FX_mode_Module_Experiment8[] PROGMEM = "💡Module_Experiment8 ☾@;;1";
|
||||||
|
static const char _data_FX_mode_Module_Experiment7[] PROGMEM = "💡Module_Experiment7 ☾@;;1";
|
||||||
|
static const char _data_FX_mode_Module_Experiment6[] PROGMEM = "💡Module_Experiment6 ☾@;;1";
|
||||||
|
static const char _data_FX_mode_Module_Experiment5[] PROGMEM = "💡Module_Experiment5 ☾@;;1";
|
||||||
|
static const char _data_FX_mode_Module_Experiment4[] PROGMEM = "💡Module_Experiment4 ☾@;;1";
|
||||||
|
static const char _data_FX_mode_Zoom2[] PROGMEM = "💡Zoom2 ☾@;;1";
|
||||||
|
static const char _data_FX_mode_Module_Experiment3[] PROGMEM = "💡Module_Experiment3 ☾@;;1";
|
||||||
|
static const char _data_FX_mode_Module_Experiment2[] PROGMEM = "💡Module_Experiment2 ☾@;;1";
|
||||||
|
static const char _data_FX_mode_Module_Experiment1[] PROGMEM = "💡Module_Experiment1 ☾@;;1";
|
||||||
|
static const char _data_FX_mode_Parametric_Water[] PROGMEM = "💡Parametric_Water ☾@;;1";
|
||||||
|
static const char _data_FX_mode_Water[] PROGMEM = "💡Water ☾@;;1";
|
||||||
|
static const char _data_FX_mode_Complex_Kaleido_6[] PROGMEM = "💡Complex_Kaleido_6 ☾@;;1";
|
||||||
|
static const char _data_FX_mode_Complex_Kaleido_5[] PROGMEM = "💡Complex_Kaleido_5 ☾@;;1";
|
||||||
|
static const char _data_FX_mode_Complex_Kaleido_4[] PROGMEM = "💡Complex_Kaleido_4 ☾@;;1";
|
||||||
|
static const char _data_FX_mode_Complex_Kaleido_3[] PROGMEM = "💡Complex_Kaleido_3 ☾@;;1";
|
||||||
|
static const char _data_FX_mode_Complex_Kaleido_2[] PROGMEM = "💡Complex_Kaleido_2 ☾@;;1";
|
||||||
|
static const char _data_FX_mode_Complex_Kaleido[] PROGMEM = "💡Complex_Kaleido ☾@;;1";
|
||||||
|
static const char _data_FX_mode_SM10[] PROGMEM = "💡SM10 ☾@;;1";
|
||||||
|
static const char _data_FX_mode_SM9[] PROGMEM = "💡SM9 ☾@;;1";
|
||||||
|
static const char _data_FX_mode_SM8[] PROGMEM = "💡SM8 ☾@;;1";
|
||||||
|
static const char _data_FX_mode_SM7[] PROGMEM = "💡SM7 ☾@;;1";
|
||||||
|
static const char _data_FX_mode_SM6[] PROGMEM = "💡SM6 ☾@;;1";
|
||||||
|
static const char _data_FX_mode_SM5[] PROGMEM = "💡SM5 ☾@;;1";
|
||||||
|
static const char _data_FX_mode_SM4[] PROGMEM = "💡SM4 ☾@;;1";
|
||||||
|
static const char _data_FX_mode_SM3[] PROGMEM = "💡SM3 ☾@;;1";
|
||||||
|
static const char _data_FX_mode_SM2[] PROGMEM = "💡SM2 ☾@;;1";
|
||||||
|
static const char _data_FX_mode_SM1[] PROGMEM = "💡SM1 ☾@;;1";
|
||||||
|
static const char _data_FX_mode_Big_Caleido[] PROGMEM = "💡Big_Caleido ☾@;;1";
|
||||||
|
static const char _data_FX_mode_RGB_Blobs5[] PROGMEM = "💡RGB_Blobs5 ☾@;;1";
|
||||||
|
static const char _data_FX_mode_RGB_Blobs4[] PROGMEM = "💡RGB_Blobs4 ☾@;;1";
|
||||||
|
static const char _data_FX_mode_RGB_Blobs3[] PROGMEM = "💡RGB_Blobs3 ☾@;;1";
|
||||||
|
static const char _data_FX_mode_RGB_Blobs2[] PROGMEM = "💡RGB_Blobs2 ☾@;;1";
|
||||||
|
static const char _data_FX_mode_RGB_Blobs[] PROGMEM = "💡RGB_Blobs ☾@;;1";
|
||||||
|
static const char _data_FX_mode_Polar_Waves[] PROGMEM = "💡Polar_Waves ☾@;;1";
|
||||||
|
static const char _data_FX_mode_Slow_Fade[] PROGMEM = "💡Slow_Fade ☾@;;1";
|
||||||
|
static const char _data_FX_mode_Zoom[] PROGMEM = "💡Zoom ☾@;;1";
|
||||||
|
static const char _data_FX_mode_Hot_Blob[] PROGMEM = "💡Hot_Blob ☾@;;1";
|
||||||
|
static const char _data_FX_mode_Spiralus2[] PROGMEM = "💡Spiralus2 ☾@;;1";
|
||||||
|
static const char _data_FX_mode_Spiralus[] PROGMEM = "💡Spiralus ☾@;;1";
|
||||||
|
static const char _data_FX_mode_Yves[] PROGMEM = "💡Yves ☾@;;1";
|
||||||
|
static const char _data_FX_mode_Scaledemo1[] PROGMEM = "💡Scaledemo1 ☾@;;1";
|
||||||
|
static const char _data_FX_mode_Lava1[] PROGMEM = "💡Lava1 ☾@;;1";
|
||||||
|
static const char _data_FX_mode_Caleido3[] PROGMEM = "💡Caleido3 ☾@;;1";
|
||||||
|
static const char _data_FX_mode_Caleido2[] PROGMEM = "💡Caleido2 ☾@;;1";
|
||||||
|
static const char _data_FX_mode_Caleido1[] PROGMEM = "💡Caleido1 ☾@;;1";
|
||||||
|
static const char _data_FX_mode_Distance_Experiment[] PROGMEM = "💡Distance_Experiment ☾@;;1";
|
||||||
|
static const char _data_FX_mode_Center_Field[] PROGMEM = "💡Center_Field ☾@;;1";
|
||||||
|
static const char _data_FX_mode_Waves[] PROGMEM = "💡Waves ☾@;;1";
|
||||||
|
static const char _data_FX_mode_Chasing_Spirals[] PROGMEM = "💡Chasing_Spirals ☾@;;1";
|
||||||
|
static const char _data_FX_mode_Rotating_Blob[] PROGMEM = "💡Rotating_Blob ☾@;;1";
|
||||||
|
|
||||||
|
|
||||||
|
class ANIMartRIXMod:public ANIMartRIX {
|
||||||
|
public:
|
||||||
|
void initEffect() {
|
||||||
|
if (SEGENV.call == 0) {
|
||||||
|
init(SEGMENT.virtualWidth(), SEGMENT.virtualHeight(), false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
void setPixelColor(int x, int y, rgb pixel) {
|
||||||
|
SEGMENT.setPixelColorXY(x, y, CRGB(pixel.red, pixel.green, pixel.blue));
|
||||||
|
}
|
||||||
|
void setPixelColor(int index, rgb pixel) {
|
||||||
|
SEGMENT.setPixelColor(index, CRGB(pixel.red, pixel.green, pixel.blue));
|
||||||
|
}
|
||||||
|
|
||||||
|
// Add any extra custom effects not part of the ANIMartRIX libary here
|
||||||
|
};
|
||||||
|
ANIMartRIXMod anim;
|
||||||
|
|
||||||
|
uint16_t mode_Module_Experiment10() {
|
||||||
|
anim.initEffect();
|
||||||
|
anim.Module_Experiment10();
|
||||||
|
return FRAMETIME;
|
||||||
|
}
|
||||||
|
uint16_t mode_Module_Experiment9() {
|
||||||
|
anim.initEffect();
|
||||||
|
anim.Module_Experiment9();
|
||||||
|
return FRAMETIME;
|
||||||
|
}
|
||||||
|
uint16_t mode_Module_Experiment8() {
|
||||||
|
anim.initEffect();
|
||||||
|
anim.Module_Experiment8();
|
||||||
|
return FRAMETIME;
|
||||||
|
}
|
||||||
|
uint16_t mode_Module_Experiment7() {
|
||||||
|
anim.initEffect();
|
||||||
|
anim.Module_Experiment7();
|
||||||
|
return FRAMETIME;
|
||||||
|
}
|
||||||
|
uint16_t mode_Module_Experiment6() {
|
||||||
|
anim.initEffect();
|
||||||
|
anim.Module_Experiment6();
|
||||||
|
return FRAMETIME;
|
||||||
|
}
|
||||||
|
uint16_t mode_Module_Experiment5() {
|
||||||
|
anim.initEffect();
|
||||||
|
anim.Module_Experiment5();
|
||||||
|
return FRAMETIME;
|
||||||
|
}
|
||||||
|
uint16_t mode_Module_Experiment4() {
|
||||||
|
anim.initEffect();
|
||||||
|
anim.Module_Experiment4();
|
||||||
|
return FRAMETIME;
|
||||||
|
}
|
||||||
|
uint16_t mode_Zoom2() {
|
||||||
|
anim.initEffect();
|
||||||
|
anim.Zoom2();
|
||||||
|
return FRAMETIME;
|
||||||
|
}
|
||||||
|
uint16_t mode_Module_Experiment3() {
|
||||||
|
anim.initEffect();
|
||||||
|
anim.Module_Experiment3();
|
||||||
|
return FRAMETIME;
|
||||||
|
}
|
||||||
|
uint16_t mode_Module_Experiment2() {
|
||||||
|
anim.initEffect();
|
||||||
|
anim.Module_Experiment2();
|
||||||
|
return FRAMETIME;
|
||||||
|
}
|
||||||
|
uint16_t mode_Module_Experiment1() {
|
||||||
|
anim.initEffect();
|
||||||
|
anim.Module_Experiment1();
|
||||||
|
return FRAMETIME;
|
||||||
|
}
|
||||||
|
uint16_t mode_Parametric_Water() {
|
||||||
|
anim.initEffect();
|
||||||
|
anim.Parametric_Water();
|
||||||
|
return FRAMETIME;
|
||||||
|
}
|
||||||
|
uint16_t mode_Water() {
|
||||||
|
anim.initEffect();
|
||||||
|
anim.Water();
|
||||||
|
return FRAMETIME;
|
||||||
|
}
|
||||||
|
uint16_t mode_Complex_Kaleido_6() {
|
||||||
|
anim.initEffect();
|
||||||
|
anim.Complex_Kaleido_6();
|
||||||
|
return FRAMETIME;
|
||||||
|
}
|
||||||
|
uint16_t mode_Complex_Kaleido_5() {
|
||||||
|
anim.initEffect();
|
||||||
|
anim.Complex_Kaleido_5();
|
||||||
|
return FRAMETIME;
|
||||||
|
}
|
||||||
|
uint16_t mode_Complex_Kaleido_4() {
|
||||||
|
anim.initEffect();
|
||||||
|
anim.Complex_Kaleido_4();
|
||||||
|
return FRAMETIME;
|
||||||
|
}
|
||||||
|
uint16_t mode_Complex_Kaleido_3() {
|
||||||
|
anim.initEffect();
|
||||||
|
anim.Complex_Kaleido_3();
|
||||||
|
return FRAMETIME;
|
||||||
|
}
|
||||||
|
uint16_t mode_Complex_Kaleido_2() {
|
||||||
|
anim.initEffect();
|
||||||
|
anim.Complex_Kaleido_2();
|
||||||
|
return FRAMETIME;
|
||||||
|
}
|
||||||
|
uint16_t mode_Complex_Kaleido() {
|
||||||
|
anim.initEffect();
|
||||||
|
anim.Complex_Kaleido();
|
||||||
|
return FRAMETIME;
|
||||||
|
}
|
||||||
|
uint16_t mode_SM10() {
|
||||||
|
anim.initEffect();
|
||||||
|
anim.SM10();
|
||||||
|
return FRAMETIME;
|
||||||
|
}
|
||||||
|
uint16_t mode_SM9() {
|
||||||
|
anim.initEffect();
|
||||||
|
anim.SM9();
|
||||||
|
return FRAMETIME;
|
||||||
|
}
|
||||||
|
uint16_t mode_SM8() {
|
||||||
|
anim.initEffect();
|
||||||
|
anim.SM8();
|
||||||
|
return FRAMETIME;
|
||||||
|
}
|
||||||
|
// uint16_t mode_SM7() {
|
||||||
|
// anim.initEffect();
|
||||||
|
// anim.SM7();
|
||||||
|
//
|
||||||
|
// return FRAMETIME;
|
||||||
|
// }
|
||||||
|
uint16_t mode_SM6() {
|
||||||
|
anim.initEffect();
|
||||||
|
anim.SM6();
|
||||||
|
return FRAMETIME;
|
||||||
|
}
|
||||||
|
uint16_t mode_SM5() {
|
||||||
|
anim.initEffect();
|
||||||
|
anim.SM5();
|
||||||
|
return FRAMETIME;
|
||||||
|
}
|
||||||
|
uint16_t mode_SM4() {
|
||||||
|
anim.initEffect();
|
||||||
|
anim.SM4();
|
||||||
|
return FRAMETIME;
|
||||||
|
}
|
||||||
|
uint16_t mode_SM3() {
|
||||||
|
anim.initEffect();
|
||||||
|
anim.SM3();
|
||||||
|
return FRAMETIME;
|
||||||
|
}
|
||||||
|
uint16_t mode_SM2() {
|
||||||
|
anim.initEffect();
|
||||||
|
anim.SM2();
|
||||||
|
return FRAMETIME;
|
||||||
|
}
|
||||||
|
uint16_t mode_SM1() {
|
||||||
|
anim.initEffect();
|
||||||
|
anim.SM1();
|
||||||
|
return FRAMETIME;
|
||||||
|
}
|
||||||
|
uint16_t mode_Big_Caleido() {
|
||||||
|
anim.initEffect();
|
||||||
|
anim.Big_Caleido();
|
||||||
|
return FRAMETIME;
|
||||||
|
}
|
||||||
|
uint16_t mode_RGB_Blobs5() {
|
||||||
|
anim.RGB_Blobs5();
|
||||||
|
return FRAMETIME;
|
||||||
|
}
|
||||||
|
uint16_t mode_RGB_Blobs4() {
|
||||||
|
anim.initEffect();
|
||||||
|
anim.RGB_Blobs4();
|
||||||
|
return FRAMETIME;
|
||||||
|
}
|
||||||
|
uint16_t mode_RGB_Blobs3() {
|
||||||
|
anim.initEffect();
|
||||||
|
anim.RGB_Blobs3();
|
||||||
|
return FRAMETIME;
|
||||||
|
}
|
||||||
|
uint16_t mode_RGB_Blobs2() {
|
||||||
|
anim.initEffect();
|
||||||
|
anim.RGB_Blobs2();
|
||||||
|
return FRAMETIME;
|
||||||
|
}
|
||||||
|
uint16_t mode_RGB_Blobs() {
|
||||||
|
anim.initEffect();
|
||||||
|
anim.RGB_Blobs();
|
||||||
|
return FRAMETIME;
|
||||||
|
}
|
||||||
|
uint16_t mode_Polar_Waves() {
|
||||||
|
anim.initEffect();
|
||||||
|
anim.Polar_Waves();
|
||||||
|
return FRAMETIME;
|
||||||
|
}
|
||||||
|
uint16_t mode_Slow_Fade() {
|
||||||
|
anim.initEffect();
|
||||||
|
anim.Slow_Fade();
|
||||||
|
return FRAMETIME;
|
||||||
|
}
|
||||||
|
uint16_t mode_Zoom() {
|
||||||
|
anim.initEffect();
|
||||||
|
anim.Zoom();
|
||||||
|
return FRAMETIME;
|
||||||
|
}
|
||||||
|
uint16_t mode_Hot_Blob() {
|
||||||
|
anim.initEffect();
|
||||||
|
anim.Hot_Blob();
|
||||||
|
return FRAMETIME;
|
||||||
|
}
|
||||||
|
uint16_t mode_Spiralus2() {
|
||||||
|
anim.initEffect();
|
||||||
|
anim.Spiralus2();
|
||||||
|
return FRAMETIME;
|
||||||
|
}
|
||||||
|
uint16_t mode_Spiralus() {
|
||||||
|
anim.initEffect();
|
||||||
|
anim.Spiralus();
|
||||||
|
return FRAMETIME;
|
||||||
|
}
|
||||||
|
uint16_t mode_Yves() {
|
||||||
|
anim.initEffect();
|
||||||
|
anim.Yves();
|
||||||
|
return FRAMETIME;
|
||||||
|
}
|
||||||
|
uint16_t mode_Scaledemo1() {
|
||||||
|
anim.initEffect();
|
||||||
|
anim.Scaledemo1();
|
||||||
|
return FRAMETIME;
|
||||||
|
}
|
||||||
|
uint16_t mode_Lava1() {
|
||||||
|
anim.initEffect();
|
||||||
|
anim.Lava1();
|
||||||
|
return FRAMETIME;
|
||||||
|
}
|
||||||
|
uint16_t mode_Caleido3() {
|
||||||
|
anim.initEffect();
|
||||||
|
anim.Caleido3();
|
||||||
|
return FRAMETIME;
|
||||||
|
}
|
||||||
|
uint16_t mode_Caleido2() {
|
||||||
|
anim.initEffect();
|
||||||
|
anim.Caleido2();
|
||||||
|
return FRAMETIME;
|
||||||
|
}
|
||||||
|
uint16_t mode_Caleido1() {
|
||||||
|
anim.initEffect();
|
||||||
|
anim.Caleido1();
|
||||||
|
return FRAMETIME;
|
||||||
|
}
|
||||||
|
uint16_t mode_Distance_Experiment() {
|
||||||
|
anim.initEffect();
|
||||||
|
anim.Distance_Experiment();
|
||||||
|
return FRAMETIME;
|
||||||
|
}
|
||||||
|
uint16_t mode_Center_Field() {
|
||||||
|
anim.initEffect();
|
||||||
|
anim.Center_Field();
|
||||||
|
return FRAMETIME;
|
||||||
|
}
|
||||||
|
uint16_t mode_Waves() {
|
||||||
|
anim.initEffect();
|
||||||
|
anim.Waves();
|
||||||
|
return FRAMETIME;
|
||||||
|
}
|
||||||
|
uint16_t mode_Chasing_Spirals() {
|
||||||
|
anim.initEffect();
|
||||||
|
anim.Chasing_Spirals();
|
||||||
|
return FRAMETIME;
|
||||||
|
}
|
||||||
|
uint16_t mode_Rotating_Blob() {
|
||||||
|
anim.initEffect();
|
||||||
|
anim.Rotating_Blob();
|
||||||
|
return FRAMETIME;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
class AnimartrixUsermod : public Usermod {
|
||||||
|
protected:
|
||||||
|
bool enabled = false; //WLEDMM
|
||||||
|
const char *_name; //WLEDMM
|
||||||
|
bool initDone = false; //WLEDMM
|
||||||
|
unsigned long lastTime = 0; //WLEDMM
|
||||||
|
|
||||||
|
public:
|
||||||
|
|
||||||
|
AnimartrixUsermod(const char *name, bool enabled) {
|
||||||
|
this->_name = name;
|
||||||
|
this->enabled = enabled;
|
||||||
|
} //WLEDMM
|
||||||
|
|
||||||
|
|
||||||
|
void setup() {
|
||||||
|
|
||||||
|
strip.addEffect(255, &mode_Module_Experiment10, _data_FX_mode_Module_Experiment10);
|
||||||
|
strip.addEffect(255, &mode_Module_Experiment9, _data_FX_mode_Module_Experiment9);
|
||||||
|
strip.addEffect(255, &mode_Module_Experiment8, _data_FX_mode_Module_Experiment8);
|
||||||
|
strip.addEffect(255, &mode_Module_Experiment7, _data_FX_mode_Module_Experiment7);
|
||||||
|
strip.addEffect(255, &mode_Module_Experiment6, _data_FX_mode_Module_Experiment6);
|
||||||
|
strip.addEffect(255, &mode_Module_Experiment5, _data_FX_mode_Module_Experiment5);
|
||||||
|
strip.addEffect(255, &mode_Module_Experiment4, _data_FX_mode_Module_Experiment4);
|
||||||
|
strip.addEffect(255, &mode_Zoom2, _data_FX_mode_Zoom2);
|
||||||
|
strip.addEffect(255, &mode_Module_Experiment3, _data_FX_mode_Module_Experiment3);
|
||||||
|
strip.addEffect(255, &mode_Module_Experiment2, _data_FX_mode_Module_Experiment2);
|
||||||
|
strip.addEffect(255, &mode_Module_Experiment1, _data_FX_mode_Module_Experiment1);
|
||||||
|
strip.addEffect(255, &mode_Parametric_Water, _data_FX_mode_Parametric_Water);
|
||||||
|
strip.addEffect(255, &mode_Water, _data_FX_mode_Water);
|
||||||
|
strip.addEffect(255, &mode_Complex_Kaleido_6, _data_FX_mode_Complex_Kaleido_6);
|
||||||
|
strip.addEffect(255, &mode_Complex_Kaleido_5, _data_FX_mode_Complex_Kaleido_5);
|
||||||
|
strip.addEffect(255, &mode_Complex_Kaleido_4, _data_FX_mode_Complex_Kaleido_4);
|
||||||
|
strip.addEffect(255, &mode_Complex_Kaleido_3, _data_FX_mode_Complex_Kaleido_3);
|
||||||
|
strip.addEffect(255, &mode_Complex_Kaleido_2, _data_FX_mode_Complex_Kaleido_2);
|
||||||
|
strip.addEffect(255, &mode_Complex_Kaleido, _data_FX_mode_Complex_Kaleido);
|
||||||
|
strip.addEffect(255, &mode_SM10, _data_FX_mode_SM10);
|
||||||
|
strip.addEffect(255, &mode_SM9, _data_FX_mode_SM9);
|
||||||
|
strip.addEffect(255, &mode_SM8, _data_FX_mode_SM8);
|
||||||
|
// strip.addEffect(255, &mode_SM7, _data_FX_mode_SM7);
|
||||||
|
strip.addEffect(255, &mode_SM6, _data_FX_mode_SM6);
|
||||||
|
strip.addEffect(255, &mode_SM5, _data_FX_mode_SM5);
|
||||||
|
strip.addEffect(255, &mode_SM4, _data_FX_mode_SM4);
|
||||||
|
strip.addEffect(255, &mode_SM3, _data_FX_mode_SM3);
|
||||||
|
strip.addEffect(255, &mode_SM2, _data_FX_mode_SM2);
|
||||||
|
strip.addEffect(255, &mode_SM1, _data_FX_mode_SM1);
|
||||||
|
strip.addEffect(255, &mode_Big_Caleido, _data_FX_mode_Big_Caleido);
|
||||||
|
strip.addEffect(255, &mode_RGB_Blobs5, _data_FX_mode_RGB_Blobs5);
|
||||||
|
strip.addEffect(255, &mode_RGB_Blobs4, _data_FX_mode_RGB_Blobs4);
|
||||||
|
strip.addEffect(255, &mode_RGB_Blobs3, _data_FX_mode_RGB_Blobs3);
|
||||||
|
strip.addEffect(255, &mode_RGB_Blobs2, _data_FX_mode_RGB_Blobs2);
|
||||||
|
strip.addEffect(255, &mode_RGB_Blobs, _data_FX_mode_RGB_Blobs);
|
||||||
|
strip.addEffect(255, &mode_Polar_Waves, _data_FX_mode_Polar_Waves);
|
||||||
|
strip.addEffect(255, &mode_Slow_Fade, _data_FX_mode_Slow_Fade);
|
||||||
|
strip.addEffect(255, &mode_Zoom, _data_FX_mode_Zoom);
|
||||||
|
strip.addEffect(255, &mode_Hot_Blob, _data_FX_mode_Hot_Blob);
|
||||||
|
strip.addEffect(255, &mode_Spiralus2, _data_FX_mode_Spiralus2);
|
||||||
|
strip.addEffect(255, &mode_Spiralus, _data_FX_mode_Spiralus);
|
||||||
|
strip.addEffect(255, &mode_Yves, _data_FX_mode_Yves);
|
||||||
|
strip.addEffect(255, &mode_Scaledemo1, _data_FX_mode_Scaledemo1);
|
||||||
|
strip.addEffect(255, &mode_Lava1, _data_FX_mode_Lava1);
|
||||||
|
strip.addEffect(255, &mode_Caleido3, _data_FX_mode_Caleido3);
|
||||||
|
strip.addEffect(255, &mode_Caleido2, _data_FX_mode_Caleido2);
|
||||||
|
strip.addEffect(255, &mode_Caleido1, _data_FX_mode_Caleido1);
|
||||||
|
strip.addEffect(255, &mode_Distance_Experiment, _data_FX_mode_Distance_Experiment);
|
||||||
|
strip.addEffect(255, &mode_Center_Field, _data_FX_mode_Center_Field);
|
||||||
|
strip.addEffect(255, &mode_Waves, _data_FX_mode_Waves);
|
||||||
|
strip.addEffect(255, &mode_Chasing_Spirals, _data_FX_mode_Chasing_Spirals);
|
||||||
|
strip.addEffect(255, &mode_Rotating_Blob, _data_FX_mode_Rotating_Blob);
|
||||||
|
|
||||||
|
initDone = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
void loop() {
|
||||||
|
if (!enabled || strip.isUpdating()) return;
|
||||||
|
|
||||||
|
// do your magic here
|
||||||
|
if (millis() - lastTime > 1000) {
|
||||||
|
//USER_PRINTLN("I'm alive!");
|
||||||
|
lastTime = millis();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void addToJsonInfo(JsonObject& root)
|
||||||
|
{
|
||||||
|
char myStringBuffer[16]; // buffer for snprintf()
|
||||||
|
JsonObject user = root["u"];
|
||||||
|
if (user.isNull()) user = root.createNestedObject("u");
|
||||||
|
|
||||||
|
JsonArray infoArr = user.createNestedArray(FPSTR(_name));
|
||||||
|
|
||||||
|
String uiDomString = F("Animartrix requires the Creative Commons Attribution License CC BY-NC 3.0");
|
||||||
|
infoArr.add(uiDomString);
|
||||||
|
}
|
||||||
|
|
||||||
|
uint16_t getId()
|
||||||
|
{
|
||||||
|
return USERMOD_ID_ANIMARTRIX;
|
||||||
|
}
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -132,6 +132,7 @@
|
|||||||
#define USERMOD_ID_PWM_OUTPUTS 38 //Usermod "usermod_pwm_outputs.h
|
#define USERMOD_ID_PWM_OUTPUTS 38 //Usermod "usermod_pwm_outputs.h
|
||||||
#define USERMOD_ID_SHT 39 //Usermod "usermod_sht.h
|
#define USERMOD_ID_SHT 39 //Usermod "usermod_sht.h
|
||||||
#define USERMOD_ID_KLIPPER 40 // Usermod Klipper percentage
|
#define USERMOD_ID_KLIPPER 40 // Usermod Klipper percentage
|
||||||
|
#define USERMOD_ID_ANIMARTRIX 93 //Usermod "usermod_v2_animartrix.h"
|
||||||
|
|
||||||
//Access point behavior
|
//Access point behavior
|
||||||
#define AP_BEHAVIOR_BOOT_NO_CONN 0 //Open AP when no connection after boot
|
#define AP_BEHAVIOR_BOOT_NO_CONN 0 //Open AP when no connection after boot
|
||||||
|
@ -189,6 +189,9 @@
|
|||||||
#include "../usermods/pwm_outputs/usermod_pwm_outputs.h"
|
#include "../usermods/pwm_outputs/usermod_pwm_outputs.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef USERMOD_ANIMARTRIX
|
||||||
|
#include "../usermods/usermod_v2_animartrix/usermod_v2_animartrix.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
void registerUsermods()
|
void registerUsermods()
|
||||||
{
|
{
|
||||||
@ -357,4 +360,8 @@ void registerUsermods()
|
|||||||
#ifdef USERMOD_SHT
|
#ifdef USERMOD_SHT
|
||||||
usermods.add(new ShtUsermod());
|
usermods.add(new ShtUsermod());
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef USERMOD_ANIMARTRIX
|
||||||
|
usermods.add(new AnimartrixUsermod("Animartrix", false));
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user