.. note::
Ciao, benvenuto nella Community di appassionati di SunFounder Raspberry Pi & Arduino & ESP32 su Facebook! Approfondisci Raspberry Pi, Arduino ed ESP32 insieme ad altri appassionati.
**Perché unirti 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 competenze.
- **Anteprime esclusive**: Ottieni accesso anticipato agli annunci di nuovi prodotti e alle anteprime.
- **Sconti speciali**: Approfitta di sconti esclusivi sui nostri prodotti più recenti.
- **Promozioni festive e omaggi**: Partecipa a omaggi e promozioni festive.
👉 Pronto a esplorare e creare con noi? Clicca su [|link_sf_facebook|] e unisciti oggi stesso!
.. _1.1.4_c_pi5:
1.1.4 Display a 7 Segmenti
=============================
Introduzione
-----------------
Proviamo a pilotare un display a 7 segmenti per mostrare una cifra da 0 a 9 e da A a F.
Componenti necessari
------------------------------
In questo progetto, abbiamo bisogno dei seguenti componenti.
.. image:: ../img/list_7_segment.png
È 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 acquistarli separatamente dai link sottostanti.
.. list-table::
:widths: 30 20
:header-rows: 1
* - INTRODUZIONE COMPONENTI
- LINK PER L'ACQUISTO
* - :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_7_segment`
- |link_7segment_buy|
* - :ref:`cpn_74hc595`
- |link_74hc595_buy|
Schema di Collegamento
--------------------------
Collega il pin ST_CP del 74HC595 al GPIO18 del Raspberry Pi, SH_CP al GPIO27,
DS al GPIO17, e le uscite parallele ai 7 segmenti del display LED. Inserisci
i dati nel pin DS per il registro a scorrimento quando SH_CP (l'ingresso del
clock del registro a scorrimento) è al fronte di salita, e nel registro di
memoria quando ST_CP (l'ingresso del clock della memoria) è al fronte di salita.
Poi puoi controllare gli stati di SH_CP e ST_CP tramite i GPIO del Raspberry Pi
per trasformare i dati in ingresso seriale in dati in uscita parallela, risparmiando
così i GPIO del Raspberry Pi e pilotando il display.
============ ======== ======== ===
T-Board Name physical wiringPi BCM
GPIO17 Pin 11 0 17
GPIO18 Pin 12 1 18
GPIO27 Pin 13 2 27
============ ======== ======== ===
.. image:: ../img/schematic_7_segment.png
Procedure Sperimentali
------------------------------
**Passo 1:** Costruisci il circuito.
.. image:: ../img/image73.png
**Passo 2:** Accedi alla cartella del codice.
.. raw:: html
.. code-block::
cd ~/raphael-kit/c/1.1.4/
**Passo 3:** Compila il codice.
.. raw:: html
.. code-block::
gcc 1.1.4_7-Segment.c -lwiringPi
**Passo 4:** Esegui il file eseguibile.
.. raw:: html
.. code-block::
sudo ./a.out
Dopo l'esecuzione del codice, vedrai il display a 7 segmenti mostrare le cifre da 0 a 9, e le lettere da A a F.
.. note::
Se non funziona dopo l'esecuzione o appare un errore come: \"wiringPi.h: No such file or directory\", consulta :ref:`install_wiringpi_pi5`.
**Codice**
.. code-block:: c
#include
#include
#define SDI 0 //ingresso dati seriale
#define RCLK 1 //ingresso clock memoria (STCP)
#define SRCLK 2 //ingresso clock registro a scorrimento (SHCP)
unsigned char SegCode[16] = {0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71};
void init(void){
pinMode(SDI, OUTPUT);
pinMode(RCLK, OUTPUT);
pinMode(SRCLK, OUTPUT);
digitalWrite(SDI, 0);
digitalWrite(RCLK, 0);
digitalWrite(SRCLK, 0);
}
void hc595_shift(unsigned char dat){
int i;
for(i=0;i<8;i++){
digitalWrite(SDI, 0x80 & (dat << i));
digitalWrite(SRCLK, 1);
delay(1);
digitalWrite(SRCLK, 0);
}
digitalWrite(RCLK, 1);
delay(1);
digitalWrite(RCLK, 0);
}
int main(void){
int i;
if(wiringPiSetup() == -1){ //quando l'inizializzazione di wiring fallisce, stampa un messaggio a schermo
printf("setup wiringPi failed !");
return 1;
}
init();
while(1){
for(i=0;i<16;i++){
printf("Print %1X on Segment\n", i); // %X means hex output
hc595_shift(SegCode[i]);
delay(500);
}
}
return 0;
}
**Spiegazione del Codice**
.. code-block:: c
unsigned char SegCode[16] = {0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71};
Una matrice di codici di segmento da 0 a F in esadecimale (catodo comune).
.. code-block:: c
void init(void){
pinMode(SDI, OUTPUT);
pinMode(RCLK, OUTPUT);
pinMode(SRCLK, OUTPUT);
digitalWrite(SDI, 0);
digitalWrite(RCLK, 0);
digitalWrite(SRCLK, 0);
}
Imposta i pin ds, st_cp, sh_cp come OUTPUT, e lo stato iniziale a 0.
.. code-block:: c
void hc595_shift(unsigned char dat){}
Assegna un valore a 8 bit al registro a scorrimento del 74HC595.
.. code-block:: c
digitalWrite(SDI, 0x80 & (dat << i));
Assegna il dato dat a SDI (DS) bit per bit. Supponiamo che dat=0x3f (0011 1111, quando i=2, 0x3f si sposterà a sinistra (<<) di 2 bit. 1111 1100 (0x3f << 2) & 1000 0000 (0x80) = 1000 0000, è vero.
.. code-block:: c
digitalWrite(SRCLK, 1);
Il valore iniziale di SRCLK era impostato su 0, e qui è impostato su 1, per generare un impulso di salita, quindi sposta i dati DS nel registro a scorrimento.
.. code-block:: c
digitalWrite(RCLK, 1);
Il valore iniziale di RCLK era impostato su 0, e qui è impostato su 1, per generare un impulso di salita, quindi sposta i dati dal registro a scorrimento al registro di memoria.
.. code-block:: c
while(1){
for(i=0;i<16;i++){
printf("Print %1X on Segment\n", i); // %X means hex output
hc595_shift(SegCode[i]);
delay(500);
}
}
In questo ciclo for, usiamo ``%1X`` per stampare i come numero esadecimale. Applica i per trovare il codice del segmento corrispondente nell'array ``SegCode[]``, e utilizza ``hc595_shift()`` per trasferire il codice SegCode nel registro a scorrimento del 74HC595.
.. note::
Il formato esadecimale dei numeri da 0 a 15 è (0, 1, 2, 3, 4, 5, 6, 7, 8, 9, A, B, C, D, E, F)
**Immagine del Fenomeno**
.. image:: ../img/image74.jpeg