preprefinal
This commit is contained in:
parent
f56ee193d0
commit
a18f9c6ac5
5 changed files with 239 additions and 52 deletions
|
@ -30,6 +30,10 @@ class leds
|
||||||
uint16_t _prev_state = 0;
|
uint16_t _prev_state = 0;
|
||||||
Adafruit_NeoPixel * _stripe;
|
Adafruit_NeoPixel * _stripe;
|
||||||
|
|
||||||
|
int _tcr_firstPixelHue;
|
||||||
|
int _tcr_b ;
|
||||||
|
|
||||||
|
|
||||||
uint8_t _s = 0;
|
uint8_t _s = 0;
|
||||||
uint16_t _h = 0;
|
uint16_t _h = 0;
|
||||||
|
|
||||||
|
@ -64,10 +68,13 @@ class leds
|
||||||
void setColor(uint32_t color);
|
void setColor(uint32_t color);
|
||||||
void rainbowCycle();
|
void rainbowCycle();
|
||||||
bool do_rainbowCycle();
|
bool do_rainbowCycle();
|
||||||
|
void theaterChaseRainbow();
|
||||||
};
|
};
|
||||||
|
|
||||||
leds::leds(Adafruit_NeoPixel * stripe, uint32_t * state_flag, uint16_t state_mask, uint16_t H, uint8_t S, unsigned int pixel_first, unsigned int pixel_last )
|
leds::leds(Adafruit_NeoPixel * stripe, uint32_t * state_flag, uint16_t state_mask, uint16_t H, uint8_t S, unsigned int pixel_first, unsigned int pixel_last )
|
||||||
{
|
{
|
||||||
|
_tcr_firstPixelHue = 0;
|
||||||
|
_tcr_b = 0;
|
||||||
_state_flag = state_flag;
|
_state_flag = state_flag;
|
||||||
_state_mask = state_mask;
|
_state_mask = state_mask;
|
||||||
_h = H;
|
_h = H;
|
||||||
|
@ -296,6 +303,26 @@ bool leds::_fade_off()
|
||||||
return _fade(false);
|
return _fade(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void leds::theaterChaseRainbow()
|
||||||
|
{
|
||||||
|
if((millis() - _last_rainbowcycle) > WAIT_RAINBOWCYCLE_MS)
|
||||||
|
{
|
||||||
|
_last_rainbowcycle = millis();
|
||||||
|
_tcr_b++;
|
||||||
|
if(_tcr_b >= 3)
|
||||||
|
_tcr_b = 0;
|
||||||
|
clear(); // Set all pixels in RAM to 0 (off)
|
||||||
|
for(int c=_tcr_b; c<_pixel_nr; c += 3)
|
||||||
|
{
|
||||||
|
int hue = _tcr_firstPixelHue + c * 65536L / _pixel_nr;
|
||||||
|
uint32_t color = _stripe->gamma32(_stripe->ColorHSV(hue)); // hue -> RGB
|
||||||
|
_pixels[c].color = color;
|
||||||
|
}
|
||||||
|
_setLeds();
|
||||||
|
_tcr_firstPixelHue += 65536 / 90; // One cycle of color wheel over 90 frames
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
void leds::rainbowCycle()
|
void leds::rainbowCycle()
|
||||||
{
|
{
|
||||||
|
|
|
@ -9,7 +9,7 @@
|
||||||
//#include "eeprom.h"
|
//#include "eeprom.h"
|
||||||
|
|
||||||
//eeprom flash;
|
//eeprom flash;
|
||||||
const unsigned long SZENE_TIMEOUT_TO_SET_TO_DEFAULT_MS = 30000;
|
const unsigned long SZENE_TIMEOUT_TO_SET_TO_DEFAULT_MS = 600000;
|
||||||
|
|
||||||
///---- OLED ----
|
///---- OLED ----
|
||||||
|
|
||||||
|
@ -23,12 +23,12 @@ const size_t PIN_MP3_RX = 25 ; //D2;
|
||||||
const size_t PIN_MP3_TX = 26 ; //D3;
|
const size_t PIN_MP3_TX = 26 ; //D3;
|
||||||
|
|
||||||
const uint8_t SONG_EINE_INSEL = 1;
|
const uint8_t SONG_EINE_INSEL = 1;
|
||||||
const uint8_t SONG_WEIHNACHTSBAECKEREI = 2;
|
const uint8_t SONG_WEIHNACHTSBAECKEREI = 3;
|
||||||
const uint8_t SONG_WEIHNACHTSBAHN = 3;
|
const uint8_t SONG_WEIHNACHTSBAHN = 5;
|
||||||
const uint8_t SONG_OH_TANNEBAUM = 4;
|
const uint8_t SONG_OH_TANNEBAUM = 7;
|
||||||
const uint8_t SONG_DISCO_MARYSBOYCHILD = 5;
|
const uint8_t SONG_DISCO_MARYSBOYCHILD = 9;
|
||||||
const uint8_t SONG_DISCO_LASTCHRISTMAS = 6;
|
const uint8_t SONG_DISCO_LASTCHRISTMAS = 11;
|
||||||
const uint8_t SONG_DISCO_DOTHEYKNOWITSCHRISTMAS = 7;
|
const uint8_t SONG_DISCO_DOTHEYKNOWITSCHRISTMAS = 13;
|
||||||
|
|
||||||
mp3 mp3ply(PIN_MP3_RX, PIN_MP3_TX);
|
mp3 mp3ply(PIN_MP3_RX, PIN_MP3_TX);
|
||||||
|
|
||||||
|
|
|
@ -102,7 +102,8 @@ unsigned long mp3::is_playing()
|
||||||
String answer = player->decodeMP3Answer();
|
String answer = player->decodeMP3Answer();
|
||||||
if(answer.indexOf(STARTED_STRING) > -1)
|
if(answer.indexOf(STARTED_STRING) > -1)
|
||||||
{
|
{
|
||||||
return(millis() - _play_since_ms);
|
//return(millis() - _play_since_ms);
|
||||||
|
return 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Serial.printf("MP3 Player is not playing\n");
|
Serial.printf("MP3 Player is not playing\n");
|
||||||
|
|
|
@ -92,7 +92,7 @@ void train::set_pwm(uint8_t pwm_value) {
|
||||||
}
|
}
|
||||||
_fade_step = pwm_value;
|
_fade_step = pwm_value;
|
||||||
ledcWrite(_pwmchannel, pwm_value);
|
ledcWrite(_pwmchannel, pwm_value);
|
||||||
Serial.printf("PWM '%s' set to value %d\n", _name, pwm_value);
|
//Serial.printf("PWM '%s' set to value %d\n", _name, pwm_value);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
197
src/main.cpp
197
src/main.cpp
|
@ -18,12 +18,15 @@ void updateNVS();
|
||||||
|
|
||||||
unsigned int licht_all_count = 0;
|
unsigned int licht_all_count = 0;
|
||||||
unsigned int move_all_count = 0;
|
unsigned int move_all_count = 0;
|
||||||
|
unsigned int disco_all_count = 0;
|
||||||
unsigned long last_updated_NVS = 0;
|
unsigned long last_updated_NVS = 0;
|
||||||
|
|
||||||
bool licht_is_fading = false;
|
bool licht_is_fading = false;
|
||||||
|
bool mp3_isused = false;
|
||||||
|
|
||||||
void setup() {
|
void setup() {
|
||||||
Serial.begin(115200);
|
Serial.begin(115200);
|
||||||
|
randomSeed(analogRead(0));
|
||||||
|
|
||||||
taster_aussen_licht.begin();
|
taster_aussen_licht.begin();
|
||||||
taster_aussen_move.begin();
|
taster_aussen_move.begin();
|
||||||
|
@ -40,11 +43,12 @@ void setup() {
|
||||||
NVS.begin();
|
NVS.begin();
|
||||||
licht_all_count = NVS.getInt("licht");
|
licht_all_count = NVS.getInt("licht");
|
||||||
move_all_count = NVS.getInt("move");
|
move_all_count = NVS.getInt("move");
|
||||||
|
disco_all_count = NVS.getInt("disco");
|
||||||
|
|
||||||
moni.init();
|
moni.init();
|
||||||
moni.setBrigthness(100);
|
moni.setBrigthness(100);
|
||||||
|
|
||||||
licht_state_flag = LSTERNBILD1 | LSTERNBILD2 | LSTERNBILD3 | LSTERNE1 | LSTERNE2 | LBAUHOF | LBURG | LTANNE;
|
licht_state_flag = LSTERNBILD1 | LSTERNBILD2 | LSTERNBILD3 | LSTERNE1 | LSTERNE2 | LTANNE;
|
||||||
mp3ply.begin();
|
mp3ply.begin();
|
||||||
mp3ply.stop();
|
mp3ply.stop();
|
||||||
|
|
||||||
|
@ -72,7 +76,6 @@ void loop() {
|
||||||
set_lichtszene();
|
set_lichtszene();
|
||||||
set_moveszene();
|
set_moveszene();
|
||||||
licht_is_fading = licht_update();
|
licht_is_fading = licht_update();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool next_licht_szene_possible = true;
|
bool next_licht_szene_possible = true;
|
||||||
|
@ -111,6 +114,8 @@ void set_lichtszene()
|
||||||
}
|
}
|
||||||
if(millis() - szene_overall_time_ms > SZENE_TIMEOUT_TO_SET_TO_DEFAULT_MS)
|
if(millis() - szene_overall_time_ms > SZENE_TIMEOUT_TO_SET_TO_DEFAULT_MS)
|
||||||
{
|
{
|
||||||
|
szene_overall_time_ms = millis();
|
||||||
|
Serial.printf("Setting Licht backt to default night withe Tannenbaum\n");
|
||||||
licht_state_flag = LSTERNBILD1 | LSTERNBILD2 | LSTERNBILD3 | LSTERNE1 | LSTERNE2 | LTANNE;
|
licht_state_flag = LSTERNBILD1 | LSTERNBILD2 | LSTERNBILD3 | LSTERNE1 | LSTERNE2 | LTANNE;
|
||||||
licht_szene = 0;
|
licht_szene = 0;
|
||||||
taster_aussen_licht.reset();
|
taster_aussen_licht.reset();
|
||||||
|
@ -141,7 +146,7 @@ void set_moveszene()
|
||||||
}
|
}
|
||||||
|
|
||||||
const byte TANNENBAUM_VOL = 20;
|
const byte TANNENBAUM_VOL = 20;
|
||||||
const unsigned long TANNENBAUM_PLAY_MUSIC_MS = 60000;
|
const unsigned long TANNENBAUM_PLAY_MUSIC_MS = 135000;
|
||||||
typedef enum {TA_INIT = 0, TA_LIGHT_READY, TA_START_PLAYING ,TA_MIN_PLAYING,TA_PLAYING, TA_STOP_PLAYING, TA_FINSIHED} szene_tanne_t;
|
typedef enum {TA_INIT = 0, TA_LIGHT_READY, TA_START_PLAYING ,TA_MIN_PLAYING,TA_PLAYING, TA_STOP_PLAYING, TA_FINSIHED} szene_tanne_t;
|
||||||
szene_tanne_t tanne_state = TA_INIT;
|
szene_tanne_t tanne_state = TA_INIT;
|
||||||
void szene_oh_tannebaum()
|
void szene_oh_tannebaum()
|
||||||
|
@ -157,9 +162,14 @@ void szene_oh_tannebaum()
|
||||||
case TA_LIGHT_READY:
|
case TA_LIGHT_READY:
|
||||||
if(licht_is_fading == false)
|
if(licht_is_fading == false)
|
||||||
{
|
{
|
||||||
|
if(mp3_isused == true)
|
||||||
|
tanne_state = TA_FINSIHED;
|
||||||
|
else{
|
||||||
|
mp3_isused = true;
|
||||||
tanne_state = TA_START_PLAYING;
|
tanne_state = TA_START_PLAYING;
|
||||||
Serial.printf("All lights are ready for Oh Tannebaum\n");
|
Serial.printf("All lights are ready for Oh Tannebaum\n");
|
||||||
mp3ply.play_vol(2, TANNENBAUM_VOL);
|
mp3ply.play_vol(SONG_OH_TANNEBAUM, TANNENBAUM_VOL);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case TA_START_PLAYING:
|
case TA_START_PLAYING:
|
||||||
|
@ -176,17 +186,15 @@ void szene_oh_tannebaum()
|
||||||
tanne_state = TA_PLAYING;
|
tanne_state = TA_PLAYING;
|
||||||
break;
|
break;
|
||||||
case TA_PLAYING:
|
case TA_PLAYING:
|
||||||
if(msecs - szene_time_ms > TANNENBAUM_PLAY_MUSIC_MS || taster_aussen_licht.pressed() == true || mp3ply.is_playing() == 0)
|
if(msecs - szene_time_ms > TANNENBAUM_PLAY_MUSIC_MS || taster_aussen_licht.pressed() == true )
|
||||||
tanne_state = TA_STOP_PLAYING;
|
tanne_state = TA_STOP_PLAYING;
|
||||||
break;
|
break;
|
||||||
case TA_STOP_PLAYING:
|
case TA_STOP_PLAYING:
|
||||||
if(mp3ply.fade_out() == false)
|
if(mp3ply.fade_out() == false)
|
||||||
{
|
{
|
||||||
//if(mp3ply.is_playing() == 0)
|
|
||||||
//{
|
|
||||||
Serial.printf("Oh Tannebaum faded out and stopped\n");
|
Serial.printf("Oh Tannebaum faded out and stopped\n");
|
||||||
tanne_state = TA_FINSIHED;
|
tanne_state = TA_FINSIHED;
|
||||||
//}
|
mp3_isused = false;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case TA_FINSIHED:
|
case TA_FINSIHED:
|
||||||
|
@ -306,14 +314,14 @@ void szene_tag_dorf()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
unsigned int zugunten_error = 0;
|
unsigned int zugunten_error = 0;
|
||||||
const unsigned int ZUGUNTEN_MAX_ERROR_COUNT = 5;
|
const unsigned int ZUGUNTEN_MAX_ERROR_COUNT = 5;
|
||||||
const unsigned long ZUGUNTEN_DRIVES_TO_STATION_MS = 5000;
|
const unsigned long ZUGUNTEN_DRIVES_TO_STATION_MS = 5000;
|
||||||
const unsigned long ZUGUNTEN_STOPPED_AT_STATION_MS = 5000;
|
const unsigned long ZUGUNTEN_STOPPED_AT_STATION_MS = 5000;
|
||||||
const unsigned long ZUGUNTEN_MAX_TIME_TO_HOME_MS = 15000; ///timeout time
|
const unsigned long ZUGUNTEN_MAX_TIME_TO_HOME_MS = 15000; ///timeout time
|
||||||
typedef enum {ZU_INIT = 0, ZU_AT_HOME , ZU_DRIVES_TO_STATION, ZU_STOPPES_AT_STATION, ZU_STOPPED_AT_STATION, ZU_DRIVES_HOME, ZU_STOPPES_AT_HOME} szene_zugunten_t;
|
typedef enum {ZU_INIT = 0, ZU_AT_HOME , ZU_DRIVES_TO_STATION, ZU_STOPPES_AT_STATION, ZU_STOPPED_AT_STATION, ZU_DRIVES_HOME, ZU_STOPPES_AT_HOME, ZU_STOPPED_PLAYING, ZU_DONE} szene_zugunten_t;
|
||||||
szene_zugunten_t zugunten_state = ZU_INIT;
|
szene_zugunten_t zugunten_state = ZU_INIT;
|
||||||
|
bool mp3_zugunten = false;
|
||||||
void move_zugunten()
|
void move_zugunten()
|
||||||
{
|
{
|
||||||
unsigned long msecs = millis();
|
unsigned long msecs = millis();
|
||||||
|
@ -323,9 +331,23 @@ void move_zugunten()
|
||||||
Serial.printf("Zugunten fährt\n");
|
Serial.printf("Zugunten fährt\n");
|
||||||
taster_train_unten.reset();
|
taster_train_unten.reset();
|
||||||
if (zugunten_error > ZUGUNTEN_MAX_ERROR_COUNT)
|
if (zugunten_error > ZUGUNTEN_MAX_ERROR_COUNT)
|
||||||
zugunten_state = ZU_STOPPES_AT_HOME;
|
{
|
||||||
|
zugunten_state = ZU_DONE;
|
||||||
|
Serial.printf("Zugunten . More errors than allowed - will stop here.");
|
||||||
|
}
|
||||||
else
|
else
|
||||||
|
{
|
||||||
zugunten_state = ZU_AT_HOME;
|
zugunten_state = ZU_AT_HOME;
|
||||||
|
if(mp3_isused == false)
|
||||||
|
{
|
||||||
|
Serial.printf("Playing Eine Insel\n");
|
||||||
|
mp3ply.play_vol(SONG_EINE_INSEL, 20);
|
||||||
|
mp3_zugunten = true;
|
||||||
|
mp3_isused = true;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
mp3_zugunten = false;
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
case ZU_AT_HOME:
|
case ZU_AT_HOME:
|
||||||
szene_time_ms = msecs;
|
szene_time_ms = msecs;
|
||||||
|
@ -370,23 +392,37 @@ void move_zugunten()
|
||||||
break;
|
break;
|
||||||
case ZU_STOPPES_AT_HOME:
|
case ZU_STOPPES_AT_HOME:
|
||||||
if(zugunten.fade_off() == false)
|
if(zugunten.fade_off() == false)
|
||||||
|
zugunten_state = ZU_STOPPED_PLAYING;
|
||||||
|
break;
|
||||||
|
case ZU_STOPPED_PLAYING:
|
||||||
|
if(mp3_zugunten == true)
|
||||||
{
|
{
|
||||||
zugunten_state = ZU_INIT;
|
if(mp3ply.fade_out() == false && mp3ply.is_playing() == 0)
|
||||||
|
{
|
||||||
|
zugunten_state = ZU_DONE;
|
||||||
|
mp3_isused = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
zugunten_state = ZU_DONE;
|
||||||
|
break;
|
||||||
|
case ZU_DONE:
|
||||||
next_move_szene_possible = true;
|
next_move_szene_possible = true;
|
||||||
taster_aussen_move.reset();
|
taster_aussen_move.reset();
|
||||||
|
zugunten_state = ZU_INIT;
|
||||||
Serial.printf("Zugunten stopped\n");
|
Serial.printf("Zugunten stopped\n");
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool mp3_zugoben = false;
|
||||||
unsigned int zugoben_error = 0;
|
unsigned int zugoben_error = 0;
|
||||||
const unsigned int ZUGOBEN_MAX_ERROR_COUNT = 5;
|
const unsigned int ZUGOBEN_MAX_ERROR_COUNT = 5;
|
||||||
const unsigned long ZUGOBEN_DRIVES_TO_BRIDGE_MS = 2000;
|
const unsigned long ZUGOBEN_DRIVES_TO_BRIDGE_MS = 2000;
|
||||||
const unsigned long ZUGOBEN_DRIVES_ON_BRIDGE_MS = 2000;
|
const unsigned long ZUGOBEN_DRIVES_ON_BRIDGE_MS = 2000;
|
||||||
const unsigned long ZUGOBEN_MAX_TIME_TO_HOME_MS = 10000; ///timeout time
|
const unsigned long ZUGOBEN_MAX_TIME_TO_HOME_MS = 10000; ///timeout time
|
||||||
const uint8_t ZUGOBEN_SPEED_ON_BRIDGE = 80;
|
const uint8_t ZUGOBEN_SPEED_ON_BRIDGE = 80;
|
||||||
typedef enum {ZO_INIT = 0, ZO_AT_HOME, ZO_DRIVES_TO_BRIDGE, ZO_DRIVES_SLOWDOWN_ON_BRIDGE, ZO_DRIVES_ON_BRIDGE, ZO_DRIVES_HOME, ZO_STOPPES_AT_HOME} szene_zugoben_t;
|
typedef enum {ZO_INIT = 0, ZO_AT_HOME, ZO_DRIVES_TO_BRIDGE, ZO_DRIVES_SLOWDOWN_ON_BRIDGE, ZO_DRIVES_ON_BRIDGE, ZO_DRIVES_HOME, ZO_STOPPES_AT_HOME,ZO_STOPPED_PLAYING,ZO_DONE} szene_zugoben_t;
|
||||||
szene_zugoben_t zugoben_state = ZO_INIT;
|
szene_zugoben_t zugoben_state = ZO_INIT;
|
||||||
void move_zugoben()
|
void move_zugoben()
|
||||||
{
|
{
|
||||||
|
@ -399,7 +435,18 @@ void move_zugoben()
|
||||||
if (zugoben_error > ZUGOBEN_MAX_ERROR_COUNT)
|
if (zugoben_error > ZUGOBEN_MAX_ERROR_COUNT)
|
||||||
zugoben_state = ZO_STOPPES_AT_HOME;
|
zugoben_state = ZO_STOPPES_AT_HOME;
|
||||||
else
|
else
|
||||||
|
{
|
||||||
|
if(mp3_isused == false)
|
||||||
|
{
|
||||||
|
Serial.printf("Playing Weihnachtsbahn\n");
|
||||||
|
mp3ply.play_vol(SONG_WEIHNACHTSBAHN, 20);
|
||||||
|
mp3_zugoben = true;
|
||||||
|
mp3_isused = true;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
mp3_zugoben = false;
|
||||||
zugoben_state = ZO_AT_HOME;
|
zugoben_state = ZO_AT_HOME;
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
case ZO_AT_HOME:
|
case ZO_AT_HOME:
|
||||||
szene_time_ms = msecs;
|
szene_time_ms = msecs;
|
||||||
|
@ -441,20 +488,34 @@ void move_zugoben()
|
||||||
break;
|
break;
|
||||||
case ZO_STOPPES_AT_HOME:
|
case ZO_STOPPES_AT_HOME:
|
||||||
if(zugoben.fade_off() == false)
|
if(zugoben.fade_off() == false)
|
||||||
|
zugoben_state = ZO_STOPPED_PLAYING;
|
||||||
|
break;
|
||||||
|
case ZO_STOPPED_PLAYING:
|
||||||
|
if(mp3_zugoben == true)
|
||||||
{
|
{
|
||||||
|
if(mp3ply.fade_out() == false && mp3ply.is_playing() == 0)
|
||||||
|
{
|
||||||
|
zugoben_state = ZO_DONE;
|
||||||
|
mp3_isused = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
zugoben_state = ZO_DONE;
|
||||||
|
break;
|
||||||
|
case ZO_DONE:
|
||||||
zugoben_state = ZO_INIT;
|
zugoben_state = ZO_INIT;
|
||||||
next_move_szene_possible = true;
|
next_move_szene_possible = true;
|
||||||
taster_aussen_move.reset();
|
taster_aussen_move.reset();
|
||||||
Serial.printf("Zugoben stopped at home\n");
|
Serial.printf("Zugoben stopped at home\n");
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool mp3_soben = false;
|
||||||
unsigned int soben_error = 0;
|
unsigned int soben_error = 0;
|
||||||
const unsigned int SOBEN_MAX_ERROR_COUNT = 5;
|
const unsigned int SOBEN_MAX_ERROR_COUNT = 5;
|
||||||
const unsigned long SOBEN_MAX_DRIVES_TIME_MS = 30000; ///timeout time
|
const unsigned long SOBEN_MAX_DRIVES_TIME_MS = 30000; ///timeout time
|
||||||
typedef enum {SO_INIT = 0, SO_AT_HOME, SO_DRIVES_HOME, SO_STOPPES_AT_HOME} szene_soben_t;
|
typedef enum {SO_INIT = 0, SO_AT_HOME, SO_DRIVES_HOME, SO_STOPPES_AT_HOME,SO_STOPPED_PLAYING, SO_DONE} szene_soben_t;
|
||||||
szene_soben_t soben_state = SO_INIT;
|
szene_soben_t soben_state = SO_INIT;
|
||||||
void move_schiene_oben()
|
void move_schiene_oben()
|
||||||
{
|
{
|
||||||
|
@ -467,7 +528,18 @@ void move_schiene_oben()
|
||||||
if(soben_error > SOBEN_MAX_ERROR_COUNT)
|
if(soben_error > SOBEN_MAX_ERROR_COUNT)
|
||||||
soben_state = SO_STOPPES_AT_HOME;
|
soben_state = SO_STOPPES_AT_HOME;
|
||||||
else
|
else
|
||||||
|
{
|
||||||
|
if(mp3_isused == false)
|
||||||
|
{
|
||||||
|
Serial.printf("Playing Weihnachtsbäckerei\n");
|
||||||
|
mp3ply.play_vol(SONG_WEIHNACHTSBAECKEREI, 20);
|
||||||
|
mp3_soben = true;
|
||||||
|
mp3_isused = true;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
mp3_soben = false;
|
||||||
soben_state = SO_AT_HOME;
|
soben_state = SO_AT_HOME;
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
case SO_AT_HOME:
|
case SO_AT_HOME:
|
||||||
szene_time_ms = millis();
|
szene_time_ms = millis();
|
||||||
|
@ -492,6 +564,21 @@ void move_schiene_oben()
|
||||||
break;
|
break;
|
||||||
case SO_STOPPES_AT_HOME:
|
case SO_STOPPES_AT_HOME:
|
||||||
relais_wolke_schiene.off();
|
relais_wolke_schiene.off();
|
||||||
|
soben_state = SO_STOPPED_PLAYING;
|
||||||
|
break;
|
||||||
|
case SO_STOPPED_PLAYING:
|
||||||
|
if(mp3_soben == true)
|
||||||
|
{
|
||||||
|
if(mp3ply.fade_out() == false && mp3ply.is_playing() == 0)
|
||||||
|
{
|
||||||
|
soben_state = SO_DONE;
|
||||||
|
mp3_isused = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
soben_state = SO_DONE;
|
||||||
|
break;
|
||||||
|
case SO_DONE:
|
||||||
soben_state = SO_INIT;
|
soben_state = SO_INIT;
|
||||||
next_move_szene_possible = true;
|
next_move_szene_possible = true;
|
||||||
taster_aussen_move.reset();
|
taster_aussen_move.reset();
|
||||||
|
@ -500,8 +587,6 @@ void move_schiene_oben()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
bool licht_update()
|
bool licht_update()
|
||||||
{
|
{
|
||||||
bool fade_updated = false;
|
bool fade_updated = false;
|
||||||
|
@ -541,8 +626,77 @@ bool licht_update()
|
||||||
return(fade_updated);
|
return(fade_updated);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void disco_licht()
|
||||||
|
{
|
||||||
|
led_sterne1.theaterChaseRainbow();
|
||||||
|
led_sterne2.theaterChaseRainbow();
|
||||||
|
led_sternbilder1.theaterChaseRainbow();
|
||||||
|
led_sternbilder2.theaterChaseRainbow();
|
||||||
|
led_sternbilder3.theaterChaseRainbow();
|
||||||
|
led_tanne.theaterChaseRainbow();
|
||||||
|
led_bauhof.theaterChaseRainbow();
|
||||||
|
led_burg.theaterChaseRainbow();
|
||||||
|
led_teich.theaterChaseRainbow();
|
||||||
|
led_back.theaterChaseRainbow();
|
||||||
|
|
||||||
|
licht.fade_off();
|
||||||
|
relais_spiegel.off();
|
||||||
|
rgb_leds.show();
|
||||||
|
}
|
||||||
|
|
||||||
|
const unsigned long MAX_DISCO_TIME = 120000;
|
||||||
void taster_abfrage()
|
void taster_abfrage()
|
||||||
{
|
{
|
||||||
|
if(next_licht_szene_possible == true && next_move_szene_possible == true && digitalRead(PIN_TASTER_AUSSEN_LICHT) == LOW && digitalRead(PIN_TASTER_AUSSEN_MOVE) == LOW)
|
||||||
|
{
|
||||||
|
unsigned long disco_time = millis();
|
||||||
|
disco_all_count++;
|
||||||
|
uint32_t stored_licht_state_flag = licht_state_flag;
|
||||||
|
|
||||||
|
uint8_t randSongNumber = random(0, 3);
|
||||||
|
Serial.printf("Disco! Playing Song %d\n", randSongNumber);
|
||||||
|
switch(randSongNumber)
|
||||||
|
{
|
||||||
|
case 0:
|
||||||
|
mp3ply.play_vol(SONG_DISCO_LASTCHRISTMAS,20);
|
||||||
|
break;
|
||||||
|
case 1:
|
||||||
|
mp3ply.play_vol(SONG_DISCO_DOTHEYKNOWITSCHRISTMAS,20);
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
mp3ply.play_vol(SONG_DISCO_MARYSBOYCHILD,20);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
mp3ply.play_vol(SONG_DISCO_LASTCHRISTMAS,20);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
while(mp3ply.is_playing() == 0)
|
||||||
|
{
|
||||||
|
disco_licht();
|
||||||
|
Serial.printf("Waiting until MP3 player starts\n");
|
||||||
|
delay(100);
|
||||||
|
}
|
||||||
|
while(millis() - disco_time < MAX_DISCO_TIME)
|
||||||
|
{
|
||||||
|
disco_licht();
|
||||||
|
Serial.printf("Playing Disco!!!\n");
|
||||||
|
}
|
||||||
|
while(mp3ply.fade_out()==true)
|
||||||
|
{delay(100);}
|
||||||
|
Serial.printf("Disco done.\n");
|
||||||
|
rgb_leds.clear();
|
||||||
|
rgb_leds.show();
|
||||||
|
licht_state_flag = 0;
|
||||||
|
licht_update();
|
||||||
|
licht_state_flag = stored_licht_state_flag;
|
||||||
|
while( true == licht_update())
|
||||||
|
{delay(1);}
|
||||||
|
taster_aussen_licht.reset();
|
||||||
|
taster_aussen_move.reset();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
if(next_licht_szene_possible == true)
|
if(next_licht_szene_possible == true)
|
||||||
{
|
{
|
||||||
if(taster_aussen_licht.pressed() == true)
|
if(taster_aussen_licht.pressed() == true)
|
||||||
|
@ -564,6 +718,7 @@ void taster_abfrage()
|
||||||
next_move_szene_possible = false;
|
next_move_szene_possible = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void updateNVS()
|
void updateNVS()
|
||||||
|
@ -580,6 +735,9 @@ void updateNVS()
|
||||||
case 2:
|
case 2:
|
||||||
NVS.setInt("move", move_all_count);
|
NVS.setInt("move", move_all_count);
|
||||||
break;
|
break;
|
||||||
|
case 3:
|
||||||
|
NVS.setInt("disco",disco_all_count);
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
value = 0;
|
value = 0;
|
||||||
}
|
}
|
||||||
|
@ -598,7 +756,8 @@ void show_counters()
|
||||||
}
|
}
|
||||||
moni.clear();
|
moni.clear();
|
||||||
moni.header("Zaehler");
|
moni.header("Zaehler");
|
||||||
moni.data(30,12,(uint64_t)licht_all_count, "Licht");
|
moni.data(20,12,(uint64_t)licht_all_count, "Licht");
|
||||||
|
moni.data(60,12, (uint64_t)disco_all_count, "Disco");
|
||||||
moni.data(100,12, (uint64_t)move_all_count, "Moves");
|
moni.data(100,12, (uint64_t)move_all_count, "Moves");
|
||||||
moni.data(15,38,(uint64_t)zugunten_error, "ZUErr");
|
moni.data(15,38,(uint64_t)zugunten_error, "ZUErr");
|
||||||
moni.data(60,38,(uint64_t)zugoben_error, "ZOErr");
|
moni.data(60,38,(uint64_t)zugoben_error, "ZOErr");
|
||||||
|
|
Loading…
Reference in a new issue