meta données pour cette page
  •  

// Par Alexandre Castonguay, basé sur le code de "NeoPixel Ring simple sketch (c) 2013 Shae Erisson"
// publié sous la licence GPLv3 pour correspondre au reste de la bibliothèque Adafruit néopixel
// Utilisez les appels de fonction "allumer(int,int);" et "eteindre(int,int);" 
 
#include <Adafruit_NeoPixel.h>
#include <avr/power.h>
 
// Sur quelle broche (PIN) de l'arduino sont connectés les néopixels?

#define PIN            6    // la broche PWM qui controlera les néopixels
 
// Combien de néopixels sont connectés sur l'arduino?
#define NUMPIXELS      8  
 
// Lorsque nous configurons la bibliothèque néopixel , nous devons déclarer le nombre de néopixels et de
// broches à utiliser pour envoyer des signaux.
// Notez que pour les plus vieilles versions de néopixels, vous pourriez avoir besoin de changer le troisième paramètre - voir "strandtest"
// Allez voir les exemples pour plus d'information sur les valeurs possibles
 
Adafruit_NeoPixel pixels = Adafruit_NeoPixel(NUMPIXELS, PIN, NEO_GRB + NEO_KHZ800); 
 
 
void setup() {

  pixels.begin(); // Ceci initialise les néopixels dans la bibliothèque
  Serial.begin(9600);
}
 
void loop() {
  // Pour un jeu de néopixels le premier néopixel est 0, le deuxième est 1, et ainsi de suite
  pixels.show(); // Nécessaire pour initialiser les néopixels, ici, ils seront tous éteints
   
  for(int i=0;i<NUMPIXELS;i++){ // boucle qui va faire un cycle entre tous les néopixels
     Serial.print("allume DEL : "); // afficher le numéro du néopixel dans le moniteur série
     Serial.println(i);
     allumer(i,2); // appel de la fonction "allumer()" voir plus bas sa définition 
     delay(15); // delai pour la période de temps (en millisecondes)
     }
    
   for(int i=0;i<NUMPIXELS;i++){
      eteindre(i,5);
      delay(20); 
      }   
}

 void allumer(int DEL,int delai){ // le premier argument est le numéro du néopixel et le second est l'intervalle
    for(int fi=0;fi<255;fi++){
       pixels.setPixelColor(DEL, pixels.Color(fi,fi,fi)); // allume de 0 a 255
       pixels.show();
       delay(delai); // temps de pause entre chaque augmentation d'intensité, va faire varier la longueur de la gradation
            }
       }
        
        void eteindre(int DEL,int delai){ // le premier argument est la lumiere et le second est l'intervalle
    for(int fo=255;fo>=0;fo--){
      Serial.print("eteint DEL: ");
      Serial.println(DEL);
      Serial.print("avec fondu au noir de valeur : ");
      Serial.println(fo);
       
       pixels.setPixelColor(DEL, pixels.Color(fo,fo,fo)); // eteint de 255 a 0
       pixels.show();
       delay(delai);
            }
       }