ESP8266 - Bande de LED NeoPixel

La bande LED NeoPixel RGB est composée de LED dont la couleur et la luminosité peuvent être ajustées individuellement. Ce tutoriel vous explique comment utiliser l'ESP8266 pour contrôler la bande LED NeoPixel RGB. En détail, nous apprendrons :

Nous avons besoin d'utiliser seulement une broche numérique de l'ESP8266 pour contrôler toutes les LED de la bande.

Préparation du matériel

1×ESP8266 NodeMCU
1×USB Cable Type-C
1×NeoPixel RGB LED Strip
1×1000uF Capacitor
1×470Ω resistor
1×5V Power Adapter
1×DC Power Jack
1×Jumper Wires
1×(Optional) 5V Power Adapter for ESP8266
1×(Recommended) Screw Terminal Expansion Board for ESP8266
1×(Recommended) Power Splitter For ESP8266 Type-C

Or you can buy the following sensor kits:

1×DIYables Sensor Kit (30 sensors/displays)
1×DIYables Sensor Kit (18 sensors/displays)
Divulgation : Certains des liens fournis dans cette section sont des liens affiliés Amazon. Nous pouvons recevoir une commission pour tout achat effectué via ces liens, sans coût supplémentaire pour vous. Nous vous remercions de votre soutien.

À propos de la bande LED RGB NeoPixel

Brochage de la bande LED NeoPixel

La bande LED NeoPixel RGB possède trois broches qui nécessitent des connexions spécifiques :

  • La broche GND doit être reliée à GND (0V)
  • La broche VCC doit être connectée aux 5V d'une source d'alimentation externe
  • La broche Din est la broche qui reçoit le signal de commande et doit être reliée à une broche ESP8266.
Brochage NeoPixel

※ Note:

La séquence des broches peut varier en fonction du fabricant. Il est IMPÉRATIF d'utiliser les marquages imprimés sur la bande LED.

Diagramme de câblage

Schéma de câblage de la bande LED RGB NeoPixel ESP8266 NodeMCU

This image is created using Fritzing. Click to enlarge image

Voir plus dans Brochage ESP8266. et Comment alimenter l'ESP8266..

Comment programmer une bande LED RGB NeoPixel

  • Créez un objet NeoPixel
#define PIN_NEO_PIXEL D1 // Le pin ESP8266 qui se connecte au NeoPixel #define NUM_PIXELS 30 // Le nombre de LEDs (pixels) sur le NeoPixel Adafruit_NeoPixel NeoPixel(NUM_PIXELS, PIN_NEO_PIXEL, NEO_GRB + NEO_KHZ800);
  • Bande avec 30 LED
  • Initialise la bande NeoPixel qui contient 30 lumières.
NeoPixel.begin(); // INITIALISE l'objet de bande NeoPixel (REQUIS)
  • Spécifiez la couleur de chaque LED (appelée un pixel).
NeoPixel.setPixelColor(pixel, NeoPixel.Color(255, 0, 0));
  • Ajustez la luminosité de toutes les bandes.
NeoPixel.setBrightness(100); // une valeur de 0 à 255

※ Note:

NeoPixel.setBrightness() est utilisé pour ajuster la luminosité de tous les pixels sur la bande LED. Pour régler la luminosité de chaque pixel individuellement, nous pouvons mettre à l'échelle les valeurs de couleur (R, G, B) avec le même rapport.

Les valeurs définies par NeoPixel.setBrightness() et NeoPixel.setPixelColor() ne seront appliquées que lorsque NeoPixel.show() est exécuté.

Code ESP8266

Le code ci-dessous effectue les séquences suivantes :

  • Transformez les pixels en vert un par un avec un délai entre chaque pixel
  • Éteint tous les pixels pendant deux secondes
  • Allume tous les pixels en rouge simultanément pendant deux secondes
  • Répète ce processus à l'infini
/* * Ce code ESP8266 NodeMCU a été développé par newbiely.fr * Ce code ESP8266 NodeMCU est mis à disposition du public sans aucune restriction. * Pour des instructions complètes et des schémas de câblage, veuillez visiter: * https://newbiely.fr/tutorials/esp8266/esp8266-neopixel-led-strip */ #include <Adafruit_NeoPixel.h> #define PIN_NEO_PIXEL D1 // The ESP8266 pin that connects to NeoPixel #define NUM_PIXELS 30 // The number of LEDs (pixels) on NeoPixel Adafruit_NeoPixel NeoPixel(NUM_PIXELS, PIN_NEO_PIXEL, NEO_GRB + NEO_KHZ800); void setup() { NeoPixel.begin(); // INITIALIZE NeoPixel strip object (REQUIRED) } void loop() { NeoPixel.clear(); // set all pixel colors to 'off'. It only takes effect if pixels.show() is called // turn pixels to green one by one with delay between each pixel for (int pixel = 0; pixel < NUM_PIXELS; pixel++) { // for each pixel NeoPixel.setPixelColor(pixel, NeoPixel.Color(0, 255, 0)); // it only takes effect if pixels.show() is called NeoPixel.show(); // send the updated pixel colors to the NeoPixel hardware. delay(DELAY_INTERVAL); // pause between each pixel } // turn off all pixels for two seconds NeoPixel.clear(); NeoPixel.show(); // send the updated pixel colors to the NeoPixel hardware. delay(2000); // off time // turn on all pixels to red at the same time for two seconds for (int pixel = 0; pixel < NUM_PIXELS; pixel++) { // for each pixel NeoPixel.setPixelColor(pixel, NeoPixel.Color(255, 0, 0)); // it only takes effect if pixels.show() is called } NeoPixel.show(); // send the updated pixel colors to the NeoPixel hardware. delay(2000); // on time // turn off all pixels for one seconds NeoPixel.clear(); NeoPixel.show(); // send the updated pixel colors to the NeoPixel hardware. delay(2000); // off time }

Étapes rapides

Pour commencer avec ESP8266 sur Arduino IDE, suivez ces étapes :

  • Consultez le tutoriel Installation du logiciel ESP8266. si c'est votre première utilisation de l'ESP8266.
  • Câblez les composants comme indiqué dans le schéma.
  • Connectez la carte ESP8266 à votre ordinateur à l'aide d'un câble USB.
  • Ouvrez Arduino IDE sur votre ordinateur.
  • Choisissez la bonne carte ESP8266, telle que (par exemple NodeMCU 1.0 (Module ESP-12E)), et son port COM respectif.
  • Cliquez sur l'icône Libraries dans la barre gauche de l'Arduino IDE.
  • Recherchez "Adafruit NeoPixel" et localisez la bibliothèque NeoPixel d'Adafruit.
  • Ensuite, appuyez sur le bouton Install pour installer la bibliothèque NeoPixel.
Bibliothèque NeoPixel ESP8266 NodeMCU
  • Copiez le code et ouvrez-le dans l'IDE Arduino.
  • Cliquez sur le bouton Upload pour envoyer le code à l'ESP8266.
  • Vérifiez l'effet LED.

※ Note:

Pour tout effet LED complexe, nous proposons le service de programmation payant

Vidéo

※ OUR MESSAGES

  • Please feel free to share the link of this tutorial. However, Please do not use our content on any other websites. We invested a lot of effort and time to create the content, please respect our work!