.. note::
Hola, ¡bienvenido a la Comunidad de Entusiastas de SunFounder para Raspberry Pi, Arduino y ESP32 en Facebook! Sumérgete en el mundo de Raspberry Pi, Arduino y ESP32 con otros entusiastas.
**¿Por qué unirse?**
- **Soporte experto**: Resuelve problemas post-venta y desafíos técnicos con la ayuda de nuestra comunidad y equipo.
- **Aprender y compartir**: Intercambia consejos y tutoriales para mejorar tus habilidades.
- **Previews exclusivos**: Accede anticipadamente a anuncios de nuevos productos y adelantos exclusivos.
- **Descuentos especiales**: Disfruta de descuentos exclusivos en nuestros productos más recientes.
- **Promociones festivas y sorteos**: Participa en sorteos y promociones especiales.
👉 ¿Listo para explorar y crear con nosotros? Haz clic en [|link_sf_facebook|] y únete hoy mismo!
.. _1.1.5_py:
1.1.5 Pantalla de 7 Segmentos de 4 Dígitos
==============================================
Introducción
--------------------
A continuación, sigue conmigo para intentar controlar la pantalla de 7 segmentos de 4 dígitos.
Componentes necesarios
---------------------------------
En este proyecto, necesitamos los siguientes componentes.
.. image:: ../img/list_4_digit.png
Es definitivamente conveniente comprar un kit completo, aquí está el enlace:
.. list-table::
:widths: 20 20 20
:header-rows: 1
* - Nombre
- ITEMS IN THIS KIT
- LINK
* - Kit Raphael
- 337
- |link_Raphael_kit|
También puedes comprarlos por separado en los enlaces a continuación.
.. list-table::
:widths: 30 20
:header-rows: 1
* - INTRODUCCIÓN AL COMPONENTE
- ENLACE DE COMPRA
* - :ref:`cpn_gpio_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|
Diagrama Esquemático
--------------------------
.. list-table::
:header-rows: 1
* - Nombre
- T-Board
- wiringPi
- BCM
* - GPIO17
- Pin 11
- 0
- 17
* - GPIO27
- Pin 13
- 2
- 27
* - GPIO22
- Pin 15
- 3
- 22
* - SPIMOSI
- Pin 19
- 12
- 10
* - GPIO18
- Pin 12
- 1
- 18
* - GPIO23
- Pin 16
- 4
- 23
* - GPIO24
- Pin 18
- 5
- 24
.. image:: ../img/schmatic_4_digit.png
Procedimientos Experimentales
----------------------------------
**Paso 1**: Monta el circuito.
.. image:: ../img/image80.png
**Paso 2:** Ve a la carpeta del código.
.. raw:: html
.. code-block::
cd ~/raphael-kit/python/
**Paso 3:** Ejecuta el archivo.
.. raw:: html
.. code-block::
sudo python3 1.1.5_4-Digit.py
Después de ejecutar el código, el programa realiza un conteo, aumentando en 1 cada segundo, y la pantalla de 4 dígitos muestra el conteo.
**Código**
.. note::
Puedes **Modificar/Resetear/Copiar/Ejecutar/Detener** el código a continuación. Pero antes, necesitas ir a la ruta del código fuente como ``raphael-kit/python``. Después de modificar el código, puedes ejecutarlo directamente para ver el efecto.
.. raw:: html
.. code-block:: python
import RPi.GPIO as GPIO
import time
import threading
SDI = 24
RCLK = 23
SRCLK = 18
placePin = (10, 22, 27, 17)
number = (0xc0, 0xf9, 0xa4, 0xb0, 0x99, 0x92, 0x82, 0xf8, 0x80, 0x90)
counter = 0
timer1 = 0
def clearDisplay():
for i in range(8):
GPIO.output(SDI, 1)
GPIO.output(SRCLK, GPIO.HIGH)
GPIO.output(SRCLK, GPIO.LOW)
GPIO.output(RCLK, GPIO.HIGH)
GPIO.output(RCLK, GPIO.LOW)
def hc595_shift(data):
for i in range(8):
GPIO.output(SDI, 0x80 & (data << i))
GPIO.output(SRCLK, GPIO.HIGH)
GPIO.output(SRCLK, GPIO.LOW)
GPIO.output(RCLK, GPIO.HIGH)
GPIO.output(RCLK, GPIO.LOW)
def pickDigit(digit):
for i in placePin:
GPIO.output(i,GPIO.LOW)
GPIO.output(placePin[digit], GPIO.HIGH)
def timer():
global counter
global timer1
timer1 = threading.Timer(1.0, timer)
timer1.start()
counter += 1
print("%d" % counter)
def loop():
global counter
while True:
clearDisplay()
pickDigit(0)
hc595_shift(number[counter % 10])
clearDisplay()
pickDigit(1)
hc595_shift(number[counter % 100//10])
clearDisplay()
pickDigit(2)
hc595_shift(number[counter % 1000//100])
clearDisplay()
pickDigit(3)
hc595_shift(number[counter % 10000//1000])
def setup():
GPIO.setmode(GPIO.BCM)
GPIO.setup(SDI, GPIO.OUT)
GPIO.setup(RCLK, GPIO.OUT)
GPIO.setup(SRCLK, GPIO.OUT)
for i in placePin:
GPIO.setup(i, GPIO.OUT)
global timer1
timer1 = threading.Timer(1.0, timer)
timer1.start()
def destroy(): # When "Ctrl+C" is pressed, the function is executed.
global timer1
GPIO.cleanup()
timer1.cancel() # cancel the timer
if __name__ == '__main__':
setup()
try:
loop()
except KeyboardInterrupt:
destroy()
**Explicación del Código**
.. code-block:: python
placePin = (10, 22, 27, 17)
Estos cuatro pines controlan los pines de ánodo común de las pantallas de 7 segmentos de cuatro dígitos.
.. code-block:: python
number = (0xc0, 0xf9, 0xa4, 0xb0, 0x99, 0x92, 0x82, 0xf8, 0x80, 0x90)
Un arreglo de códigos de segmento del 0 al 9 en hexadecimal (ánodo común).
.. code-block:: python
def clearDisplay():
for i in range(8):
GPIO.output(SDI, 1)
GPIO.output(SRCLK, GPIO.HIGH)
GPIO.output(SRCLK, GPIO.LOW)
GPIO.output(RCLK, GPIO.HIGH)
GPIO.output(RCLK, GPIO.LOW)
Escribe "1" ocho veces en SDI, para que los ocho LEDs en la pantalla de 7 segmentos se apaguen y así borrar el contenido mostrado.
.. code-block:: python
def pickDigit(digit):
for i in placePin:
GPIO.output(i,GPIO.LOW)
GPIO.output(placePin[digit], GPIO.HIGH)
Selecciona la posición del valor. Solo una posición debe estar habilitada cada vez. La posición habilitada se establecerá en alto.
.. code-block:: python
def loop():
global counter
while True:
clearDisplay()
pickDigit(0)
hc595_shift(number[counter % 10])
clearDisplay()
pickDigit(1)
hc595_shift(number[counter % 100//10])
clearDisplay()
pickDigit(2)
hc595_shift(number[counter % 1000//100])
clearDisplay()
pickDigit(3)
hc595_shift(number[counter % 10000//1000])
La función se utiliza para establecer el número mostrado en la pantalla de 7 segmentos de 4 dígitos.
Primero, activa el cuarto segmento de la pantalla y escribe el número de una cifra. Luego, activa el tercer segmento de la pantalla y escribe la cifra de las decenas; después, activa el segundo y el primer segmento de la pantalla respectivamente, y escribe las cifras de las centenas y los millares respectivamente. Debido a que la velocidad de actualización es muy rápida, vemos una pantalla completa de cuatro dígitos.
.. code-block:: python
timer1 = threading.Timer(1.0, timer)
timer1.start()
El módulo threading es el módulo de subprocesos común en Python, y Timer es la subclase de este.
El prototipo del código es:
.. code-block:: python
class threading.Timer(interval, function, args=[], kwargs={})
Después del intervalo, se ejecutará la función. Aquí, el intervalo es 1.0, y la función es timer().
start() significa que el Timer comenzará en este punto.
.. code-block:: python
def timer():
global counter
global timer1
timer1 = threading.Timer(1.0, timer)
timer1.start()
counter += 1
print("%d" % counter)
Después de que el Timer llega a 1.0s, se llama a la función Timer; se suma 1 al contador, y se usa nuevamente el Timer para ejecutarse repetidamente cada segundo.
Imagen del Fenómeno
-----------------------
.. image:: ../img/image81.jpeg