.. note:: ¡Hola! Bienvenido a la Comunidad de Entusiastas de SunFounder para Raspberry Pi, Arduino y ESP32 en Facebook. Sumérgete más en Raspberry Pi, Arduino y ESP32 con otros entusiastas. **¿Por qué unirte?** - **Soporte experto**: Resuelve problemas post-venta y desafíos técnicos con la ayuda de nuestra comunidad y equipo. - **Aprende y comparte**: Intercambia consejos y tutoriales para mejorar tus habilidades. - **Vistas previas exclusivas**: Obtén acceso anticipado a anuncios de nuevos productos y adelantos. - **Descuentos especiales**: Disfruta de descuentos exclusivos en nuestros productos más nuevos. - **Promociones y sorteos festivos**: Participa en sorteos y promociones de temporada. 👉 ¿Listo para explorar y crear con nosotros? Haz clic en [|link_sf_facebook|] y únete hoy mismo! .. _2.1.1_py: 2.1.1 Botón ================= Introducción -------------------- En este proyecto, aprenderemos cómo encender o apagar un LED usando un botón. Componentes Necesarios -------------------------------- En este proyecto, necesitamos los siguientes componentes. .. image:: ../img/list_2.1.1_Button.png Es definitivamente conveniente comprar un kit completo, aquí tienes 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 enlaces a continuación. .. list-table:: :widths: 30 20 :header-rows: 1 * - INTRODUCCIÓN DEL 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_led` - |link_led_buy| * - :ref:`cpn_button` - |link_button_buy| Diagrama Esquemático ------------------------- Usa un botón normalmente abierto como entrada para la Raspberry Pi, la conexión se muestra en el diagrama esquemático a continuación. Cuando se presiona el botón, el GPIO18 pasará a nivel bajo (0V). Podemos detectar el estado del GPIO18 mediante programación. Es decir, si el GPIO18 cambia a nivel bajo, significa que el botón está presionado. Puedes ejecutar el código correspondiente cuando se presiona el botón, y luego 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:: ../img/image302.png .. image:: ../img/image303.png Procedimientos Experimentales --------------------------------- **Paso 1**: Construye el circuito. .. image:: ../img/image152.png **Paso 2**: Abre el archivo de código. .. raw:: html .. code-block:: cd ~/raphael-kit/python **Paso 3**: Ejecuta el código. .. raw:: html .. code-block:: sudo python3 2.1.1_Button.py Ahora, presiona el botón, y el LED se encenderá; presiona el botón nuevamente, y el LED se apagará. Al mismo tiempo, el estado del LED se imprimirá en la pantalla. **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``. 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 LedPin = 17 # Establecer GPIO17 como pin del LED BtnPin = 18 # Establecer GPIO18 como pin del botón # Establecer el estado del LED a True(APAGADO) Led_status = True # Definir una función de configuración para algunos ajustes def setup(): # Establecer los modos GPIO a numeración BCM GPIO.setmode(GPIO.BCM) # Establecer el modo de LedPin a salida, # y nivel inicial a alto (3.3v) GPIO.setup(LedPin, GPIO.OUT, initial=GPIO.HIGH) # Establecer el modo de BtnPin a entrada, # y elevar a alto (3.3V) GPIO.setup(BtnPin, GPIO.IN) # Definir una función de callback para el botón def swLed(ev=None): global Led_status # Cambiar el estado del LED(encendido-->apagado; apagado-->encendido) Led_status = not Led_status GPIO.output(LedPin, Led_status) if Led_status: print ('LED OFF...') else: print ('...LED ON') # Definir una función principal para el proceso principal def main(): # Configurar una detección de caída en BtnPin, # y función de callback para swLed GPIO.add_event_detect(BtnPin, GPIO.FALLING, callback=swLed) while True: # No hacer nada. time.sleep(1) # Definir una función de destrucción para limpiar todo después # de que el script haya terminado def destroy(): # Apagar LED GPIO.output(LedPin, GPIO.HIGH) # Liberar recursos GPIO.cleanup() # Si ejecutas este script directamente, haz: if __name__ == '__main__': setup() try: main() # Cuando se presiona 'Ctrl+C', el programa # destroy() será ejecutado. except KeyboardInterrupt: destroy() **Explicación del Código** .. code-block:: python LedPin = 17 Configurar GPIO17 como pin del LED. .. code-block:: python BtnPin = 18 Configurar GPIO18 como pin del botón. .. code-block:: python GPIO.add_event_detect(BtnPin, GPIO.FALLING, callback=swLed) Configurar una detección de caída en BtnPin, y cuando el valor de BtnPin cambie de un nivel alto a un nivel bajo, significa que el botón ha sido presionado. El siguiente paso es llamar a la función swLed. .. code-block:: python def swLed(ev=None): global Led_status # Cambiar el estado del LED (encendido-->apagado; apagado-->encendido) Led_status = not Led_status GPIO.output(LedPin, Led_status) Definir una función de callback como callback del botón. Cuando el botón es presionado por primera vez, y la condición, not Led_status es falsa, se llama a la función GPIO.output() para encender el LED. Cuando el botón se presiona nuevamente, el estado del LED se convertirá de falso a verdadero, por lo tanto, el LED se apagará. Imagen del Fenómeno ^^^^^^^^^^^^^^^^^^^^^^ .. image:: ../img/image153.jpeg