Benutzer-Werkzeuge

Webseiten-Werkzeuge


silentbase_neopixel:programmversion_0.7

Unterschiede

Hier werden die Unterschiede zwischen zwei Versionen angezeigt.

Link zu dieser Vergleichsansicht

Beide Seiten der vorigen RevisionVorhergehende Überarbeitung
Nächste Überarbeitung
Vorhergehende Überarbeitung
silentbase_neopixel:programmversion_0.7 [17.11.2016 09:49] Frickelpietsilentbase_neopixel:programmversion_0.7 [18.05.2023 12:16] (aktuell) – Externe Bearbeitung 127.0.0.1
Zeile 1: Zeile 1:
 ====== NeoPixel-Beleuchtung für SilentBase 800 Programmversion 0.7 ====== ====== NeoPixel-Beleuchtung für SilentBase 800 Programmversion 0.7 ======
-Die Weihnachtszeit steht vor der Tür. Daher wird ein neuer Effekt hinzugefügt, der den Stabthermometereffekt glitzern lässt.+Die Weihnachtszeit steht vor der Tür. Daher wurde ein neuer Effekt hinzugefügt, der den Stabthermometereffekt glitzern lässt. Außerdem wurden kleinere Verbesserungen am Code des Breathing-Effekts vorgenommen.
  
 Ältere Versionen: Ältere Versionen:
Zeile 11: Zeile 11:
 Hilfreiche Links: Hilfreiche Links:
   * http://www.tweaking4all.com/hardware/arduino/adruino-led-strip-effects/   * http://www.tweaking4all.com/hardware/arduino/adruino-led-strip-effects/
 +  * https://www.arduino.cc/en/Reference/Random
 +
 +ToDo: Mehr Effekte!
 +
 +Der Sketch enthält Code von [[https://www.baldengineer.com/millis-cookbook.html|Baldengineer]] und [[http://www.scynd.de/tutorials/arduino-tutorials/1-taster/1-2-taster-entprellt.html|Scynd]].
 +<code>
 +// Bibliotheken einbinden
 +#include <EEPROM.h>
 +#include <ResponsiveAnalogRead.h>
 +#include <Adafruit_NeoPixel.h>
 +
 +
 +// Definiert die Pins
 +#define buttonPin 7           // Taster
 +#define loadPin A0            // analoge Spannungsmessung
 +#define neoPin1 11            // Neopixel-Strip rechte Seite
 +#define neoPin2 12            // Neopixel-Strip linke Seite
 +
 +
 +// Definiert eine Adresse im EEPROM
 +int addr = 0;                 // An dieser Adresse wird später der ausgewählte Programmmodus gespeichert
 +
 +
 +// Definiert ein ResponsiveAnalogRead Objekt
 +ResponsiveAnalogRead rload(loadPin, true);
 +
 +
 +// Definiert die Variablen
 +int numPixels = 64;           // Anzahl der NeoPixel
 +int load;                     // Gibt später die Netzteillast in Prozent an
 +
 +int buttonstate = HIGH;       // aktuelles Signal vom Eingangspin
 +int buttonpressed = 0;        // abfragen ob Taster gedrückt war
 +int debouncetime = 200;       // Zeit für Entprellung ggf. anpassen
 +
 +float counter = 0;            // Zählwert für verschiedene Beleuchtungseffekte 
 +boolean sw1 = true;           // Schaltvariable für verschiedene Beleuchtungseffekte
 +boolean sw2 = true;           // Schaltvariable für verschiedene Beleuchtungseffekte
 +int i;
 +int j;
 +int k;
 +
 +byte programmode = 0;         // Programmmodus
 +
 +
 +// Definiert die NeoPixel-Strips
 +Adafruit_NeoPixel strip1 = Adafruit_NeoPixel(numPixels, neoPin1, NEO_GRBW + NEO_KHZ800);
 +Adafruit_NeoPixel strip2 = Adafruit_NeoPixel(numPixels, neoPin2, NEO_GRBW + NEO_KHZ800);
 +
 +
 +// Definiert die globalen RGBW-Werte
 +byte r = 0;
 +byte g = 0;
 +byte b = 0;
 +byte w = 0;
 +
 +
 +// Definiert die Tracking-Variablen für die IF-Abfragen
 +unsigned long previousMillisCalcLoad = 0;
 +unsigned long previousMillisNeoPixel = 0;
 +unsigned long previousMillisSerialPrint = 0;
 +unsigned long buttontime = 0;
 +unsigned long sparkle1on = 0;
 +unsigned long sparkle1off = 0;
 +unsigned long sparkle1ondelay = 100;
 +unsigned long sparkle1offdelay = 500;
 +unsigned long sparkle2on = 0;
 +unsigned long sparkle2off = 0;
 +unsigned long sparkle2ondelay = 100;
 +unsigned long sparkle2offdelay = 500;
 +
 +
 +// Definiert die Intervalle für die IF-Abfragen
 +int intervalCalcLoad = 500;      // Delay für Berechnung der Last
 +int intervalNeoPixel = 50;       // Delay für Ansteuerung der NeoPixel
 +int intervalSerialPrint = 1000;  // Delay für serielle Ausgabe
 +
 +
 +void setup() {
 +  // Initialisiere den Button-Pin
 +  pinMode(buttonPin, INPUT_PULLUP);
 +
 +  // Initialisiere die NeoPixel-Pins
 +  pinMode(neoPin1, OUTPUT);
 +  pinMode(neoPin2, OUTPUT);
 +
 +  // Initialisiere den analogen Pin 
 +  pinMode(loadPin, INPUT);
 +
 +  // Initialisiere die NeoPixel-Strips
 +  strip1.begin(); // Initialisiert das Neopixel
 +  strip1.show();  // Macht das NeoPixel sichtbar
 +  //strip1.clear(); // Macht das NeoPixel aus
 +  
 +  strip2.begin(); // Initialisiert das Neopixel
 +  strip2.show();  // Macht das NeoPixel sichtbar
 +  //strip2.clear(); // Macht das NeoPixel aus
 +
 +  // Lese den abgespeicherten Wert für den Programmmodus aus dem EEPROM
 +  programmode = EEPROM.read(addr);
 +
 +  // Initialisiere die serialle Schnittstelle
 +  Serial.begin(57600);
 +
 +delay (2000);
 +}
 +
 +
 +
 +void loop() {
 +// Lesen und entprellen des Tasters
 +  buttonstate = digitalRead(buttonPin);
 + 
 +  // Wenn der Taster gedrückt ist...
 +  if (buttonstate == LOW)
 +  {
 +    buttontime = millis();                      // aktualisiere tasterZeit
 +    buttonpressed = 1;                          // speichert, dass Taster gedrückt wurde
 +  }
 + 
 +  // Wenn die gewählte entprellZeit vergangen ist und der Taster gedrückt war...
 +  if ((millis() - buttontime > debouncetime) && buttonpressed == 1)
 +    {
 +      programmode++;                            // Programmmodus wird um +1 erhöht
 +      buttonpressed = 0;                        // setzt gedrückten Taster zurück
 +      r = 0;                                    // setzt den globalen Farbwert zurück
 +      g = 0;                                    // setzt den globalen Farbwert zurück
 +      b = 0;                                    // setzt den globalen Farbwert zurück
 +      w = 0;                                    // setzt den globalen Farbwert zurück
 +      EEPROM.write(addr, programmode);          // Schreibt den Programmmodus ins EEPROM
 +    }
 +  
 +
 +
 +// Aktuelle Zeit abfragen
 +  unsigned long currentMillis = millis();
 +
 +// Messen und Berechnen der Last des Netzteils
 +  if ((unsigned long)(currentMillis - previousMillisCalcLoad) >= intervalCalcLoad) {
 +  
 +     // Auslesen des analogen Eingangs (Last Netzteil)
 +     rload.update();
 +
 +     // Berechnung der Netzteillast in Prozent
 +     float rloadmin = 350; // Messwert bei minimaler Last
 +     float rloadmax = 700; // Messwert bei maximaler Last
 +     load = 100 - ((rloadmax - rload.getValue()) / (rloadmax - rloadmin)) * 100;
 +     
 +  //Speichere die aktuelle Zeit in die zughörige Variable
 +  previousMillisCalcLoad = currentMillis;
 +  }
 +
 +
 +
 +// Steuerung der NeoPixel-Strips
 +  // Beleuchtungseffekt für Programmmodus 0 (Atmen rot)
 +  if (programmode == 0) {
 +    if ((unsigned long)(currentMillis - previousMillisNeoPixel) >= intervalNeoPixel) {
 +
 +     if(load < 10) {       // Variable soll für diesen Effekt nicht kleiner als 10 werden
 +        load = 10;
 +        }
 +        
 +      // Ansteuerung der NeoPixel-Strips
 +      counter = counter + (0.05 * (load/10));
 +      if (counter >= 6.28) {
 +        counter = 0;
 +      }
 +        // fade led mit counter
 +        r = ((exp(sin(counter)) - 0.36787944) * 108.492061351);
 +        
 +      for (int i = 0; i < numPixels; i++) {
 +        strip1.setPixelColor(i, r, g, b, w);
 +        strip2.setPixelColor(i, r, g, b, w);
 +      }
 +      strip1.show();
 +      strip2.show();
 +   
 +    //Speichere die aktuelle Zeit in die zughörige Variable
 +    previousMillisNeoPixel = currentMillis;
 +    }
 +  }
 +
 +  //Beleuchtungseffekt für Programmmodus 1 (Atmen weiß)
 +  else if (programmode == 1) {
 +    if ((unsigned long)(currentMillis - previousMillisNeoPixel) >= intervalNeoPixel) {
 +
 +     if(load < 10) {       // Variable soll für diesen Effekt nicht kleiner als 10 werden
 +        load = 10;
 +        }
 +        
 +      // Ansteuerung der NeoPixel-Strips
 +      counter = counter + (0.05 * (load/10));
 +      if (counter >= 6.28) {
 +        counter = 0;
 +      }
 +        // fade led mit counter
 +        w = ((exp(sin(counter)) - 0.36787944) * 108.492061351);
 +        
 +      for (int i = 0; i < numPixels; i++) {
 +        strip1.setPixelColor(i, r, g, b, w);
 +        strip2.setPixelColor(i, r, g, b, w);
 +      }
 +      strip1.show();
 +      strip2.show();
 +   
 +    //Speichere die aktuelle Zeit in die zughörige Variable
 +    previousMillisNeoPixel = currentMillis;
 +    }
 +  }
 +
 +
 +  //Beleuchtungseffekt für Programmmodus 2 (Stabthermometer)
 +  else if (programmode == 2) {
 +    if ((unsigned long)(currentMillis - previousMillisNeoPixel) >= intervalNeoPixel) {
 +
 +      if(load > 63) {       // Variable soll für diesen Effekt nicht größer als 63 werden
 +        load = 63;
 +        }
 +      // Weißer Bereich
 +      for (int i = 0; i < 63; i++) {
 +      strip1.setPixelColor(i, r, g, b, 127);
 +      strip2.setPixelColor(i, r, g, b, 127);
 +      }
 +      // Roter Bereich      
 +      for (int i = 63; i > (63 - load); i--) {
 +        strip1.setPixelColor(i, 127, g, b, w);
 +        strip2.setPixelColor(i, 127, g, b, w);
 +      }
 +      strip1.show();
 +      strip2.show();
 +   
 +    //Speichere die aktuelle Zeit in die zughörige Variable
 +    previousMillisNeoPixel = currentMillis;
 +    }
 +  }
 +
 +
 +  //Beleuchtungseffekt für Programmmodus 3 (Stabthermometer mit Glitzer)
 +  else if (programmode == 3) {
 +    if ((unsigned long)(currentMillis - previousMillisNeoPixel) >= intervalNeoPixel) {
 +
 +      if(load > 63) {       // Variable soll für diesen Effekt nicht größer als 63 werden
 +        load = 63;
 +        }
 +      // Blauer Bereich
 +      for (int i = 0; i < 63; i++) {
 +      strip1.setPixelColor(i, r, g, 127, w);
 +      strip2.setPixelColor(i, r, g, 127, w);
 +      }
 +      // Roter Bereich     
 +      for (int i = 63; i > (63 - load); i--) {
 +        strip1.setPixelColor(i, 127, g, b, w);
 +        strip2.setPixelColor(i, 127, g, b, w);
 +      }
 +
 +      // Sparkle NeoPixel-Strip 1
 +      if(sw1)
 +        {
 +          strip1.setPixelColor(j, r, g, b, 255);
 +          if(millis() - sparkle1on >= sparkle1ondelay)
 +          {
 +          sparkle1offdelay = random (100, 1000);
 +          sparkle1off = millis();
 +          sw1 = !sw1;
 +          }
 +        }
 +        if(!sw1)
 +          {
 +          if(millis() - sparkle1off >= sparkle1offdelay)
 +              {
 +                j = random(0, 63);
 +                sparkle1on = millis();
 +                sw1 = !sw1;       
 +              }
 +        } 
 +      // Sparkle NeoPixel-Strip 2
 +      if(sw2)
 +        {
 +          strip2.setPixelColor(k, r, g, b, 255);
 +          if(millis() - sparkle2on >= sparkle2ondelay)
 +          {
 +          sparkle2offdelay = random (100, 1000);
 +          sparkle2off = millis();
 +          sw2 = !sw2;
 +          }
 +        }
 +        if(!sw2)
 +          {
 +          if(millis() - sparkle2off >= sparkle2offdelay)
 +              {
 +                k = random(0, 63);
 +                sparkle2on = millis();
 +                sw2 = !sw2;       
 +              }
 +        } 
 +      // Sende die Daten an die Neopixel
 +      strip1.show();
 +      strip2.show();
 +   
 +    //Speichere die aktuelle Zeit in die zughörige Variable
 +    previousMillisNeoPixel = currentMillis;
 +    }
 +  }
 +
 +  
 +  // Wenn der Programmodus auf einen höheren Wert sprngt, wird er zurück auf 0 gesetzt und beginnt von vorne
 +  else {
 +    programmode = 0;
 +  }
 +
 +
 +// Ausgabe an die serielle Schnittstelle
 +  if ((unsigned long)(currentMillis - previousMillisSerialPrint) >= intervalSerialPrint) {
 +
 +     //Ausgabe der gemessenen Netzteillast an die sereille Schnittstelle
 +     //Serial.print("Last (gemessen): "); Serial.println(rlast);
 +
 +     //Ausgabe der berechneten Netzteillast an die sereille Schnittstelle
 +     Serial.print("Last (prozentual): "); Serial.print(load); Serial.println(" %");
 +
 +     //Ausgabe der Werte von ResponsiveAnalogRead
 +     Serial.print("Last (getRawValue): "); Serial.println(rload.getRawValue());
 +     Serial.print("Last (getValue): "); Serial.println(rload.getValue());
 +  
 +     // if the repsonsive value has change, print out 'changed'
 +     if(rload.hasChanged()) {
 +     Serial.println("\tchanged");
 +     }
 +     
 +     // Ausgabe Zustand Taster
 +     Serial.print("Taster: "); Serial.println(buttonstate);
 +
 +     // Ausgabe Programmzähler
 +     Serial.print("Programm Nr.: "); Serial.println(programmode);
 +
 +     // Ausgabe Zufallswerte
 +     Serial.print("Randomwert fuer j: "); Serial.println(j);
 +     Serial.print("Randomwert fuer t1: "); Serial.println(sparkle1offdelay);
 +     Serial.print("Randomwert fuer t2: "); Serial.println(sparkle2offdelay);
 +        
 +   //Speichere die aktuelle Zeit in die zughörige Variable
 +   previousMillisSerialPrint = currentMillis;
 +   }
 +
 +}
 +</code>
 +
 +Der Sketch verwendet 9.720 Bytes (30%) des Programmspeicherplatzes. Das Maximum sind 32.256 Bytes.
 +Globale Variablen verwenden 495 Bytes (24%) des dynamischen Speichers, 1.553 Bytes für lokale Variablen verbleiben. Das Maximum sind 2.048 Bytes.
 +
  
 Tags: #Arduino #NeoPixel Tags: #Arduino #NeoPixel
silentbase_neopixel/programmversion_0.7.1479372552.txt.gz · Zuletzt geändert: 18.05.2023 09:09 (Externe Bearbeitung)