.. note::
Ciao e benvenuto nella SunFounder Raspberry Pi & Arduino & ESP32 Enthusiasts Community su Facebook! Approfondisci l’utilizzo di Raspberry Pi, Arduino ed ESP32 con altri appassionati.
**Perché unirsi a noi?**
- **Supporto Esperto**: Risolvi problemi post-vendita e sfide tecniche con l’aiuto della nostra comunità e del nostro team.
- **Impara e Condividi**: Scambia consigli e tutorial per migliorare le tue abilità.
- **Anteprime Esclusive**: Accedi anticipatamente agli annunci di nuovi prodotti e alle anteprime.
- **Sconti Speciali**: Godi di sconti esclusivi sui nostri ultimi prodotti.
- **Promozioni Festive e Giveaway**: Partecipa a giveaway e promozioni durante le festività.
👉 Pronto a esplorare e creare con noi? Clicca su [|link_sf_facebook|] e unisciti oggi!
.. _py_pi5_btr_indicator:
3.1.5 Indicatore di Batteria
===============================
.. note::
.. image:: ../img/mcp3008_and_adc0834.jpg
:width: 25%
:align: left
A seconda della versione del kit, identifica se hai **ADC0834** o **MCP3008** e procedi con la sezione corrispondente.
Introduzione
---------------
In questo progetto, creeremo un dispositivo indicatore di batteria che
potrà visualizzare visivamente il livello di carica della batteria su un
Bargraph LED.
.. warning::
Non utilizzare componenti della batteria che superano i 3,3V per evitare sovraccarichi che potrebbero danneggiare il chip o il Raspberry Pi.
Componenti Necessari
----------------------
Per questo progetto, abbiamo bisogno dei seguenti componenti.
.. image:: ../python_pi5/img/4.1.11_battery_indicator_list.png
:align: center
.. È sicuramente conveniente acquistare un kit completo; ecco il link:
.. .. list-table::
.. :widths: 20 20 20
.. :header-rows: 1
.. * - Nome
.. - COMPONENTI IN QUESTO KIT
.. - LINK
.. * - Raphael Kit
.. - 337
.. - |link_Raphael_kit|
.. Puoi anche acquistare i componenti singolarmente dai link qui sotto.
.. .. list-table::
.. :widths: 30 20
.. :header-rows: 1
.. * - INTRODUZIONE AI COMPONENTI
.. - LINK PER L’ACQUISTO
.. * - :ref:`gpio_extension_board`
.. - |link_gpio_board_buy|
.. * - :ref:`breadboard`
.. - |link_breadboard_buy|
.. * - :ref:`wires`
.. - |link_wires_buy|
.. * - :ref:`resistor`
.. - |link_resistor_buy|
.. * - :ref:`bar_graph`
.. - \-
.. * - :ref:`adc0834`
.. - \-
Schema Elettrico
-----------------
============ ======== ======== ===
T-Board Name physical 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
Procedure Sperimentali
------------------------
**Passo 1:** Costruisci il circuito.
.. image:: ../python_pi5/img/4.1.11_battery_indicator_circuit.png
**Passo 2:** Accedi alla cartella del codice.
.. raw:: html
.. code-block::
cd ~/davinci-kit-for-raspberry-pi/python-pi5
**Passo 3:** Esegui il file eseguibile.
.. raw:: html
.. code-block::
sudo python3 3.1.5_BatteryIndicator.py
Dopo aver avviato il programma, collega separatamente un filo di uscita al 3°
pin dell’ADC0834 e al GND, quindi connettili ai due poli di una batteria.
Potrai vedere l’accensione del LED corrispondente sul Bargraph LED che
visualizza il livello di carica (intervallo di misura: 0-5V).
.. warning::
Se appare l’errore ``RuntimeError: Cannot determine SOC peripheral base address``, fai riferimento a :ref:`faq_soc`
**Codice**
.. note::
Puoi **Modificare/Ripristinare/Copiare/Eseguire/Interrompere** il codice qui sotto. Prima di tutto, però, accedi al percorso del codice sorgente come ``davinci-kit-for-raspberry-pi/python-pi5``. Dopo aver modificato il codice, puoi eseguirlo direttamente per vedere l’effetto.
.. raw:: html
.. code-block:: python
#!/usr/bin/env python3
from gpiozero import LED
import ADC0834
import time
# Elenco dei pin GPIO a cui sono collegati i LED
ledPins = [25, 12, 16, 20, 21, 5, 6, 13, 19, 26]
# Inizializza gli oggetti LED per ciascun pin nella lista
leds = [LED(pin) for pin in ledPins]
# Configura il modulo ADC0834
ADC0834.setup()
def LedBarGraph(value):
# Spegne tutti i LED
for i in range(10):
leds[i].off()
# Accende i LED fino al valore specificato
for i in range(value):
leds[i].on()
try:
# Ciclo principale per aggiornare continuamente il Bargraph LED
while True:
# Legge il valore analogico dall'ADC0834
analogVal = ADC0834.getResult()
# Converte il valore analogico nel livello del Bargraph LED
LedBarGraph(int(analogVal/25))
except KeyboardInterrupt:
# Spegne tutti i LED quando il programma viene interrotto
for i in range(10):
leds[i].off()
**Spiegazione del Codice**
#. Questa sezione importa le librerie necessarie. ``gpiozero`` serve per controllare i LED, ``ADC0834`` per interfacciarsi con il modulo ADC, e ``time`` per operazioni temporali.
.. code-block:: python
#!/usr/bin/env python3
from gpiozero import LED
import ADC0834
import time
#. Definisce i pin GPIO a cui sono collegati i LED e inizializza un array di oggetti LED per ciascun pin, permettendo di controllare facilmente ogni LED nell'array.
.. code-block:: python
# Elenco dei pin GPIO a cui sono collegati i LED
ledPins = [25, 12, 16, 20, 21, 5, 6, 13, 19, 26]
# Inizializza gli oggetti LED per ciascun pin nella lista
leds = [LED(pin) for pin in ledPins]
#. Inizializza il modulo ADC0834 per la conversione analogico-digitale.
.. code-block:: python
# Configura il modulo ADC0834
ADC0834.setup()
#. Questa funzione spegne tutti i LED e accende un numero di LED basato sul valore di input, creando effettivamente una rappresentazione grafica a barre.
.. code-block:: python
def LedBarGraph(value):
# Spegne tutti i LED
for i in range(10):
leds[i].off()
# Accende i LED fino al valore specificato
for i in range(value):
leds[i].on()
#. Legge continuamente il valore analogico dall'ADC0834 e aggiorna il Bargraph LED in base a questo valore. Il valore analogico è scalato su un intervallo di 0-10 per i 10 LED.
.. code-block:: python
try:
# Ciclo principale per aggiornare continuamente il Bargraph LED
while True:
# Legge il valore analogico dall'ADC0834
analogVal = ADC0834.getResult()
# Converte il valore analogico nel livello del Bargraph LED
LedBarGraph(int(analogVal/25))
#. Assicura che tutti i LED siano spenti quando il programma viene interrotto (ad esempio, premendo Ctrl+C).
.. code-block:: python
except KeyboardInterrupt:
# Spegne tutti i LED quando il programma viene interrotto
for i in range(10):
leds[i].off()