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);
}
}