.. note::
Ciao, benvenuto nella Community di appassionati di Raspberry Pi, Arduino e ESP32 di SunFounder su Facebook! Approfondisci il tuo viaggio con Raspberry Pi, Arduino ed ESP32 insieme ad altri appassionati.
**Perché unirti a noi?**
- **Supporto esperto**: Risolvi i problemi post-vendita e le sfide tecniche con l'aiuto della nostra community e del nostro team.
- **Impara e Condividi**: Scambia consigli e tutorial per migliorare le tue competenze.
- **Anteprime esclusive**: Ottieni accesso anticipato a nuovi annunci di prodotti e anteprime.
- **Sconti speciali**: Godi di sconti esclusivi sui nostri prodotti più recenti.
- **Promozioni e concorsi festivi**: Partecipa a concorsi e promozioni durante le festività.
👉 Pronto a esplorare e creare con noi? Clicca su [|link_sf_facebook|] e unisciti oggi stesso!
.. _1.1.5_js:
1.1.5 Display a 7 segmenti a 4 cifre
=======================================
Introduzione
--------------------
Ora proviamo a controllare un display a 7 segmenti a 4 cifre.
Componenti necessari
---------------------------------
In questo progetto, abbiamo bisogno dei seguenti componenti.
.. image:: img/list_4_digit.png
È sicuramente conveniente acquistare un kit completo, ecco il link:
.. list-table::
:widths: 20 20 20
:header-rows: 1
* - Nome
- OGGETTI 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 AI 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_4_digit`
- \-
* - :ref:`cpn_74hc595`
- |link_74hc595_buy|
.. note::
In questo progetto, per il display a 7 segmenti a 4 cifre dobbiamo utilizzare il modello BS; se usi il modello AS potrebbe non accendersi.
Schema elettrico
----------------------
.. image:: img/schmatic_4_digit.png
Procedure sperimentali
---------------------------
**Passo 1**: Costruisci il circuito.
.. image:: img/image80.png
**Passo 2**: Vai alla cartella del codice.
.. raw:: html
.. code-block::
cd ~/raphael-kit/nodejs/
**Passo 3**: Esegui il codice.
.. raw:: html
.. code-block::
sudo node 4_digit_7_segment_display.js
Dopo l'esecuzione del codice, il programma inizia a contare, aumentando di 1 ogni secondo, e il display a 7 segmenti a 4 cifre visualizza il conteggio.
**Codice**
.. code-block:: js
const Gpio = require('pigpio').Gpio;
var counter = 0;
const number = [0xc0, 0xf9, 0xa4, 0xb0, 0x99, 0x92, 0x82, 0xf8, 0x80, 0x90]; //per BS
const SDI = new Gpio(24, { mode: Gpio.OUTPUT });
const RCLK = new Gpio(23, { mode: Gpio.OUTPUT });
const SRCLK = new Gpio(18, { mode: Gpio.OUTPUT });
const pin1 = new Gpio(10, { mode: Gpio.OUTPUT });
const pin2 = new Gpio(22, { mode: Gpio.OUTPUT });
const pin3 = new Gpio(27, { mode: Gpio.OUTPUT });
const pin4 = new Gpio(17, { mode: Gpio.OUTPUT });
const placePin = [pin1, pin2, pin3, pin4];
function clearDisplay() {
hc595_shift(0xff); //per BS
}
function hc595_shift(dat) {
for (let j = 0; j < 8; j++) {
let code = 0x80 & (dat << j);
if (code != 0) {
code = 1;
}
SDI.digitalWrite(code);
SRCLK.trigger(1,1);
}
RCLK.trigger(1,1);
}
function pickDigit(digit) {
for(let i=0;i<4;i++){
placePin[i].digitalWrite(0);
}
placePin[digit].digitalWrite(1);
}
let digit = -1
setInterval(() => {
digit = (digit +1)% 4
clearDisplay();
pickDigit(digit);
switch(digit){
case 0:
hc595_shift(number[Math.floor(counter % 10)]);
break;
case 1:
hc595_shift(number[Math.floor(counter % 100 / 10)]);
break;
case 2:
hc595_shift(number[Math.floor(counter % 1000 / 100)]);
break;
case 3:
hc595_shift(number[Math.floor(counter % 10000 / 1000)]);
break;
}
}, 5);
setInterval(() => {
counter++;
}, 1000);
**Spiegazione del codice**
.. code-block:: js
const pin1 = new Gpio(10, {mode: Gpio.OUTPUT});
const pin2 = new Gpio(25, {mode: Gpio.OUTPUT});
const pin3 = new Gpio(27, {mode: Gpio.OUTPUT});
const pin4 = new Gpio(17, {mode: Gpio.OUTPUT});
const placePin = [pin1,pin2,pin3,pin4];
Inizializza i pin 10, 25, 27 e 17 in modalità output e posizionali nell'array ``placePin`` per facilitare il controllo dell'anodo comune del display a 7 segmenti a quattro cifre.
.. code-block:: js
const number = [0xc0, 0xf9, 0xa4, 0xb0, 0x99, 0x92, 0x82, 0xf8, 0x80, 0x90];
Definisci un array costante ``number`` per rappresentare il codice esadecimale dei segmenti da 0 a 9 (anodo comune).
.. code-block:: js
function clearDisplay() {
hc595_shift(0xff);
}
Scrivi 0xff per spegnere il display digitale.
.. code-block:: js
function pickDigit(digit) {
for(let i=0;i<4;i++){
placePin[i].digitalWrite(0);
}
placePin[digit].digitalWrite(1);
}
Seleziona la posizione del valore.
Ogni volta, solo una posizione deve essere attivata.
La posizione attivata verrà impostata su alto.
.. code-block:: js
let digit = -1
setInterval(() => {
digit = (digit +1)% 4
clearDisplay();
pickDigit(digit);
switch(digit){
case 0:
hc595_shift(number[Math.floor(counter % 10)]);
break;
case 1:
hc595_shift(number[Math.floor(counter % 100 / 10)]);
break;
case 2:
hc595_shift(number[Math.floor(counter % 1000 / 100)]);
break;
case 3:
hc595_shift(number[Math.floor(counter % 10000 / 1000)]);
break;
}
}, 5);
Questo codice viene utilizzato per impostare il numero visualizzato sul display a 7 segmenti a 4 cifre.
Prima, attiva il quarto segmento del display e scrivi il numero delle unità.
Poi attiva il terzo segmento del display e inserisci il numero delle decine;
successivamente, attiva rispettivamente il secondo e il primo segmento del display
e inserisci rispettivamente le centinaia e le migliaia. Poiché la velocità di aggiornamento è molto rapida, vediamo un display completo a quattro cifre.
.. code-block:: js
setInterval(() => {
counter++;
}, 1000);
Aggiungi uno al ``counter``
(il display a quattro cifre visualizza il numero aumentato di uno)
ogni secondo che passa.
Immagine del fenomeno
--------------------------
.. image:: img/image81.jpeg