.. note::
Bonjour et bienvenue dans la Communauté Facebook des passionnés de Raspberry Pi, Arduino et ESP32 de SunFounder ! Plongez plus profondément dans l'univers des Raspberry Pi, Arduino et ESP32 avec d'autres passionnés.
**Pourquoi rejoindre ?**
- **Support d'experts** : Résolvez les problèmes après-vente et les défis techniques avec l'aide de notre communauté et de notre équipe.
- **Apprendre et partager** : Échangez des astuces et des tutoriels pour améliorer vos compétences.
- **Aperçus exclusifs** : Accédez en avant-première aux annonces de nouveaux produits et aux aperçus.
- **Réductions spéciales** : Profitez de réductions exclusives sur nos produits les plus récents.
- **Promotions festives et cadeaux** : Participez à des cadeaux et des promotions de vacances.
👉 Prêt à explorer et à créer avec nous ? Cliquez [|link_sf_facebook|] et rejoignez-nous aujourd'hui !
.. _1.1.3_js:
1.1.3 Graphique à Barres LED
=================================
Introduction
----------------
Dans ce projet, nous allumons séquentiellement les lumières sur le graphique à barres LED.
Composants Requis
--------------------------------
Dans ce projet, nous avons besoin des composants suivants.
.. image:: img/list_led_bar.png
Il est certainement pratique d'acheter un kit complet, voici le lien :
.. list-table::
:widths: 20 20 20
:header-rows: 1
* - Nom
- ÉLÉMENTS DANS CE KIT
- LIEN
* - Kit Raphael
- 337
- |link_Raphael_kit|
Vous pouvez également les acheter séparément aux liens ci-dessous.
.. list-table::
:widths: 30 20
:header-rows: 1
* - INTRODUCTION DU COMPOSANT
- LIEN D'ACHAT
* - :ref:`cpn_gpio_extension_board`
- |link_gpio_board_buy|
* - :ref:`cpn_breadboard`
- |link_breadboard_buy|
* - :ref:`cpn_wires`
- |link_wires_buy|
* - :ref:`cpn_resistor`
- |link_resistor_buy|
* - :ref:`cpn_bar_graph`
- \-
Schéma de Connexion
-------------------------
.. image:: img/schematic_led_bar.png
Procédures Expérimentales
------------------------------
**Étape 1** : Construisez le circuit.
.. note::
Faites attention à la direction lors de la connexion. Si vous le connectez à l'envers, il ne s'allumera pas.
.. image:: img/image66.png
**Étape 2** : Allez dans le dossier du code.
.. raw:: html
.. code-block::
cd ~/raphael-kit/nodejs/
**Étape 3** : Compilez le code.
.. raw:: html
.. code-block::
sudo node led_bar_graph.js
Après l'exécution du code, vous verrez les LED sur le graphique à barres LED s'allumer et s'éteindre régulièrement.
**Code**
.. code-block:: js
const Gpio = require('pigpio').Gpio;
var pins = [17, 18, 27, 22, 23, 24, 25, 2, 3, 8];
var leds = [];
for (let i = 0; i < pins.length; i++) {
leds[i] = new Gpio(pins[i], { mode: Gpio.OUTPUT });
}
function oddLedBarGraph() {
for (let i = 0; i < leds.length; i++) {
if (i % 2 == 1) {
leds[i].digitalWrite(1);
} else {
leds[i].digitalWrite(0);
}
}
}
function evenLedBarGraph() {
for (let i = 0; i < leds.length; i++) {
if (i % 2 == 0) {
leds[i].digitalWrite(1);
} else {
leds[i].digitalWrite(0);
}
};
}
var odd_even = 0;
setInterval(() => {
odd_even = (odd_even + 1) % 2;
if (odd_even == 1) {
oddLedBarGraph();
} else {
evenLedBarGraph();
}
}, 500);
**Explication du code**
.. code-block:: js
var pins = [17,18,27,22,23,24,25,2,3,8];
Comme le graphique à barres LED utilisera plusieurs broches, nous créons un tableau constant ``pins`` pour les stocker en lot.
.. code-block:: js
var leds = [];
for (let i = 0; i < pins.length; i++) {
leds[i] = new Gpio(pins[i], { mode: Gpio.OUTPUT });
}
Instancier ces broches comme objets leds avec une boucle for.
.. code-block:: js
function oddLedBarGraph() {
for (let i = 0; i < leds.length; i++) {
if (i % 2 == 1) {
leds[i].digitalWrite(1);
} else {
leds[i].digitalWrite(0);
}
}
}
Implémenter une fonction ``oddLedBarGraph()`` pour faire s'allumer les LED sur les chiffres impairs du graphique à barres LED.
.. code-block:: js
function evenLedBarGraph() {
for (let i = 0; i < leds.length; i++) {
if (i % 2 == 0) {
leds[i].digitalWrite(1);
} else {
leds[i].digitalWrite(0);
}
};
}
Implémenter une fonction ``evenLedBarGraph()`` pour faire s'allumer les LED sur les chiffres pairs du graphique à barres LED.
.. code-block:: js
var odd_even = 0;
setInterval(() => {
odd_even = (odd_even + 1) % 2;
if (odd_even == 1) {
oddLedBarGraph();
} else {
evenLedBarGraph();
}
}, 500);
L'état de fonctionnement de la LED est commuté toutes les 500 ms.
Image du phénomène
---------------------------
.. image:: img/image67.jpeg