.. note::
Hallo, willkommen in der SunFounder Raspberry Pi & Arduino & ESP32 Enthusiasten-Community auf Facebook! Tauchen Sie tiefer in Raspberry Pi, Arduino und ESP32 mit anderen Enthusiasten ein.
**Warum beitreten?**
- **Expertenunterstützung**: Lösen Sie nach dem Kauf auftretende Probleme und technische Herausforderungen mit Hilfe unserer Community und unseres Teams.
- **Lernen & Teilen**: Tauschen Sie Tipps und Tutorials aus, um Ihre Fähigkeiten zu verbessern.
- **Exklusive Vorschauen**: Erhalten Sie frühzeitigen Zugang zu neuen Produktankündigungen und Vorschauen.
- **Spezielle Rabatte**: Genießen Sie exklusive Rabatte auf unsere neuesten Produkte.
- **Festliche Aktionen und Gewinnspiele**: Nehmen Sie an Gewinnspielen und festlichen Aktionen teil.
👉 Bereit, mit uns zu entdecken und zu kreieren? Klicken Sie auf [|link_sf_facebook|] und treten Sie noch heute bei!
1.1.3 LED-Bargraph
======================
Einführung
-------------
In diesem Projekt werden wir die Lichter auf dem LED-Bargraph nacheinander zum Leuchten bringen.
Komponenten
----------------
.. image:: img/list_led_bar.png
Schaltplan
-------------------------
.. image:: img/schematic_led_bar.png
Experimentelle Vorgehensweise
------------------------------
**Schritt 1**: Bauen Sie die Schaltung auf.
.. note::
Achten Sie auf die Richtung beim Anschließen. Wenn Sie es rückwärts anschließen, leuchtet es nicht.
.. image:: img/image66.png
**Schritt 2**: Gehen Sie zum Ordner des Codes.
.. raw:: html
.. code-block::
cd ~/davinci-kit-for-raspberry-pi/nodejs/
**Schritt 3**: Kompilieren Sie den Code.
.. raw:: html
.. code-block::
sudo node led_bar_graph.js
Nachdem der Code ausgeführt wurde, sehen Sie, dass die LEDs auf der LED-Bar regelmäßig ein- und ausgeschaltet werden.
**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);
**Code Erklärung**
.. code-block:: js
var pins = [17,18,27,22,23,24,25,2,3,8];
Da das LED-Bargraph mehrere Pins verwendet, erstellen wir ein konstantes Array ``pins``, um sie in Gruppen zu speichern.
.. code-block:: js
var leds = [];
for (let i = 0; i < pins.length; i++) {
leds[i] = new Gpio(pins[i], { mode: Gpio.OUTPUT });
}
Instanziieren Sie diese Pins als LEDs-Objekte mit einer for-Schleife.
.. 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);
}
}
}
Implementieren Sie eine ``oddLedBarGraph()``-Funktion, um die LEDs auf den
ungeraden Ziffern des LED-Bargraphs zum Leuchten zu bringen.
.. 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);
}
};
}
Implementieren Sie eine ``evenLedBarGraph()``-Funktion, um die LEDs auf den
geraden Ziffern des LED-Bargraphs zum Leuchten zu bringen.
.. code-block:: js
var odd_even = 0;
setInterval(() => {
odd_even = (odd_even + 1) % 2;
if (odd_even == 1) {
oddLedBarGraph();
} else {
evenLedBarGraph();
}
}, 500);
Der Betriebszustand der LED wird alle 500 ms gewechselt.
Phänomenbild
---------------------------
.. image:: img/image67.jpeg