.. note:: ¡Hola! Bienvenido a la Comunidad de Entusiastas de SunFounder para Raspberry Pi, Arduino y ESP32 en Facebook. Profundiza en Raspberry Pi, Arduino y ESP32 con otros entusiastas. **¿Por qué unirse?** - **Soporte experto**: Resuelve problemas postventa 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**: Obtén acceso anticipado a nuevos anuncios de productos y avances. - **Descuentos especiales**: Disfruta de descuentos exclusivos en nuestros productos más nuevos. - **Promociones y sorteos festivos**: Participa en sorteos y promociones navideñas. 👉 ¿Listo para explorar y crear con nosotros? Haz clic en [|link_sf_facebook|] y únete hoy mismo! .. _2.1.1_py_pi5: 2.1.1 Botón ================ Introducción ------------------- En este proyecto, aprenderemos cómo encender o apagar el LED usando un botón. Componentes necesarios -------------------------------- En este proyecto, necesitamos los siguientes componentes. .. image:: ../python_pi5/img/2.1.1_Button_list.png Es definitivamente conveniente comprar un kit completo, aquí está el enlace: .. list-table:: :widths: 20 20 20 :header-rows: 1 * - Nombre - ELEMENTOS EN ESTE KIT - ENLACE * - Kit Raphael - 337 - |link_Raphael_kit| También puedes comprarlos por separado en los siguientes enlaces. .. list-table:: :widths: 30 20 :header-rows: 1 * - INTRODUCCIÓN DE COMPONENTES - 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_led` - |link_led_buy| * - :ref:`cpn_button` - |link_button_buy| Diagrama esquemático ------------------------- Utiliza un botón normalmente abierto como entrada para Raspberry Pi, la conexión se muestra en el diagrama esquemático a continuación. Cuando se presiona el botón, el GPIO18 se convierte en un nivel alto (3.3V). Podemos detectar el estado del GPIO18 a través de la programación. Es decir, si el GPIO18 se convierte en nivel alto, significa que el botón está presionado. Puedes ejecutar el código correspondiente cuando se presiona el botón, y entonces el LED se encenderá. .. note:: El pin más largo del LED es el ánodo y el más corto es el cátodo. .. image:: ../python_pi5/img/2.1.1_Button_schematic_1.png .. image:: ../python_pi5/img/2.1.1_Button_schematic_2.png Procedimientos Experimentales --------------------------------- **Paso 1**: Construir el circuito. .. image:: ../python_pi5/img/2.1.1_Button_circuit.png **Paso 2**: Abrir el archivo de código. .. raw:: html .. code-block:: cd ~/raphael-kit/python-pi5 **Paso 3**: Ejecutar el código. .. raw:: html .. code-block:: sudo python3 2.1.1_Button_zero.py Ahora, presiona el botón y el LED se encenderá; suelta el botón y el LED se apagará. .. warning:: Si recibe el mensaje de error ``RuntimeError: Cannot determine SOC peripheral base address``, consulte :ref:`faq_soc` **Código** .. note:: Puedes **Modificar/Restablecer/Copiar/Ejecutar/Detener** el código a continuación. Pero antes de eso, necesitas ir a la ruta del código fuente como ``raphael-kit/python-pi5``. Después de modificar el código, puedes ejecutarlo directamente para ver el efecto. .. raw:: html .. code-block:: python #!/usr/bin/env python3 from gpiozero import LED, Button # Importar las clases LED y Button de gpiozero from signal import pause # Importar la función pause del módulo signal # Inicializar un objeto LED en el pin GPIO 17 led = LED(17) # Inicializar un objeto Button en el pin GPIO 18 button = Button(18) # Vincular el evento "when_pressed" del botón al método on() del LED button.when_pressed = led.on # Vincular el evento "when_released" del botón al método off() del LED button.when_released = led.off # Ejecutar un bucle de eventos que espera eventos del botón y mantiene el script en ejecución pause() **Explicación del Código** #. El script está escrito en Python3 e importa las clases ``LED`` y ``Button`` de la biblioteca ``gpiozero``, y ``pause`` del módulo ``signal``. .. code-block:: python #!/usr/bin/env python3 from gpiozero import LED, Button # Importar las clases LED y Button de gpiozero from signal import pause # Importar la función pause del módulo signal #. Inicializa un objeto ``LED`` en el pin GPIO 17 y un objeto ``Button`` en el pin GPIO 18. .. code-block:: python # Inicializar un objeto LED en el pin GPIO 17 led = LED(17) # Inicializar un objeto Button en el pin GPIO 18 button = Button(18) #. Configura manejadores de eventos para que el LED se encienda cuando se presione el botón y se apague cuando se suelte el botón. .. code-block:: python # Vincular el evento "when_pressed" del botón al método on() del LED button.when_pressed = led.on # Vincular el evento "when_released" del botón al método off() del LED button.when_released = led.off #. Esto mantiene el script en ejecución en un bucle de eventos, esperando los eventos de presionar y soltar el botón. .. code-block:: python # Ejecutar un bucle de eventos que espera eventos del botón y mantiene el script en ejecución pause()