.. 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 !
.. _4.1.11_py_pi5:
4.1.8 Indicateur de Batterie
===================================
.. note::
.. image:: ../img/mcp3008_and_adc0834.jpg
:width: 25%
:align: left
Selon la version de votre kit, identifiez si vous disposez d’un **ADC0834** ou d’un **MCP3008** et suivez la section correspondante.
Introduction
--------------
Dans ce projet, nous allons créer un dispositif d'indication de batterie qui
peut afficher visuellement le niveau de la batterie sur le Bargraph LED.
Composants nécessaires
------------------------------
Pour ce projet, nous avons besoin des composants suivants.
.. image:: ../python_pi5/img/4.1.11_battery_indicator_list.png
:align: center
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 via les liens ci-dessous.
.. list-table::
:widths: 30 20
:header-rows: 1
* - INTRODUCTION AUX COMPOSANTS
- 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`
- \-
* - :ref:`cpn_adc0834`
- \-
Schéma
-------------------
============ ======== ======== ===
Nom T-Board Physique wiringPi BCM
GPIO17 Pin 11 0 17
GPIO18 Pin 12 1 18
GPIO27 Pin 13 2 27
GPIO25 Pin 22 6 25
GPIO12 Pin 32 26 12
GPIO16 Pin 36 27 16
GPIO20 Pin 38 28 20
GPIO21 Pin 40 29 21
GPIO5 Pin 29 21 5
GPIO6 Pin 31 22 6
GPIO13 Pin 33 23 13
GPIO19 Pin 35 24 19
GPIO26 Pin 37 25 26
============ ======== ======== ===
.. image:: ../python_pi5/img/4.1.11_battery_indicator_schematic.png
:align: center
Procédures expérimentales
------------------------------
**Étape 1 :** Construire le circuit.
.. image:: ../python_pi5/img/4.1.11_battery_indicator_circuit.png
**Étape 2 :** Accédez au dossier du code.
.. raw:: html
.. code-block::
cd ~/raphael-kit/python-pi5
**Étape 3 :** Exécutez le fichier exécutable.
.. raw:: html
.. code-block::
sudo python3 4.1.11_BatteryIndicator_zero.py
Après le démarrage du programme, connectez séparément un fil de sortie au 3ème
pin de l'ADC0834 et à la masse, puis connectez-les aux deux pôles d'une batterie.
Vous verrez la LED correspondante sur le Bargraph LED s'allumer pour afficher le
niveau de charge (plage de mesure : 0-5V).
.. warning::
Si vous recevez le message d'erreur ``RuntimeError: Cannot determine SOC peripheral base address``, veuillez consulter :ref:`faq_soc`
**Code**
.. note::
Vous pouvez **Modifier/Réinitialiser/Copier/Exécuter/Arrêter** le code ci-dessous. Mais avant cela, vous devez accéder au chemin du code source comme ``raphael-kit/python-pi5``. Après avoir modifié le code, vous pouvez l'exécuter directement pour voir l'effet.
.. raw:: html
.. code-block:: python
#!/usr/bin/env python3
from gpiozero import LED
import ADC0834
import time
# List of GPIO pins to which LEDs are connected
ledPins = [25, 12, 16, 20, 21, 5, 6, 13, 19, 26]
# Initialize LED objects for each pin in the list
leds = [LED(pin) for pin in ledPins]
# Setup ADC0834 module
ADC0834.setup()
def LedBarGraph(value):
# Turn off all LEDs
for i in range(10):
leds[i].off()
# Turn on LEDs up to the specified value
for i in range(value):
leds[i].on()
try:
# Main loop to continuously update LED bar graph
while True:
# Read analog value from ADC0834
analogVal = ADC0834.getResult()
# Convert analog value to LED bar graph level
LedBarGraph(int(analogVal/25))
except KeyboardInterrupt:
# Turn off all LEDs when program is interrupted
for i in range(10):
leds[i].off()
**Explication du Code**
#. Cette section importe les bibliothèques nécessaires. ``gpiozero`` est utilisée pour contrôler les LED, ``ADC0834`` pour interfacer avec le module ADC, et ``time`` pour les opérations liées au temps.
.. code-block:: python
#!/usr/bin/env python3
from gpiozero import LED
import ADC0834
import time
#. Définit les broches GPIO auxquelles les LED sont connectées et initialise un tableau d'objets LED pour chaque broche. Cela permet de contrôler facilement chaque LED du tableau.
.. code-block:: python
# List of GPIO pins to which LEDs are connected
ledPins = [25, 12, 16, 20, 21, 5, 6, 13, 19, 26]
# Initialize LED objects for each pin in the list
leds = [LED(pin) for pin in ledPins]
#. Initialise le module ADC0834 pour la conversion analogique-numérique.
.. code-block:: python
# Setup ADC0834 module
ADC0834.setup()
#. Cette fonction éteint toutes les LED puis allume un certain nombre de LED en fonction de la valeur d'entrée, créant ainsi une représentation en barres graphiques.
.. code-block:: python
def LedBarGraph(value):
# Turn off all LEDs
for i in range(10):
leds[i].off()
# Turn on LEDs up to the specified value
for i in range(value):
leds[i].on()
#. Lit continuellement la valeur analogique de l'ADC0834 et met à jour le bargraphe LED en fonction de cette valeur. La valeur analogique est réduite à une plage de 0-10 pour les 10 LED.
.. code-block:: python
try:
# Main loop to continuously update LED bar graph
while True:
# Read analog value from ADC0834
analogVal = ADC0834.getResult()
# Convert analog value to LED bar graph level
LedBarGraph(int(analogVal/25))
#. S'assure que toutes les LED sont éteintes lorsque le programme est interrompu (par exemple, en appuyant sur Ctrl+C).
.. code-block:: python
except KeyboardInterrupt:
# Turn off all LEDs when program is interrupted
for i in range(10):
leds[i].off()