.. note:: ¡Hola! Bienvenido a la comunidad de entusiastas de SunFounder para Raspberry Pi, Arduino y ESP32 en Facebook. Únete para profundizar en Raspberry Pi, Arduino y ESP32 junto a otros apasionados. **¿Por qué unirte?** - **Soporte de Expertos**: 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. - **Avances Exclusivos**: Obtén acceso anticipado a anuncios de nuevos productos y vistas previas. - **Descuentos Especiales**: Disfruta de descuentos exclusivos en nuestros productos más recientes. - **Promociones Festivas y Sorteos**: Participa en sorteos y promociones de temporada. 👉 ¿Listo para explorar y crear con nosotros? Haz clic en [|link_sf_facebook|] y únete hoy. 3.1.10 Alarma ===================== Introducción ----------------- En este curso, vamos a crear un dispositivo de alarma manual. Puedes reemplazar el interruptor de palanca con un termistor o un sensor fotosensible para hacer una alarma de temperatura o de luz. Componentes --------------- .. image:: img/list_Alarm_Bell.png :align: center Diagrama Esquemático ------------------------- ============ ======== ======== === T-Board Name physical wiringPi BCM GPIO17 Pin 11 0 17 GPIO18 Pin 12 1 18 GPIO27 Pin 13 2 27 GPIO22 Pin 15 3 22 ============ ======== ======== === .. image:: img/Schematic_three_one10.png :align: center Procedimientos Experimentales --------------------------------- **Paso 1**: Construye el circuito. .. image:: img/image266.png :alt: Alarm Bell_bb :width: 800 **Para Usuarios de Lenguaje C** ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ **Paso 2**: Cambia de directorio. .. raw:: html .. code-block:: cd ~/davinci-kit-for-raspberry-pi/c/3.1.10/ **Paso 3**: Compila. .. raw:: html .. code-block:: gcc 3.1.10_AlarmBell.c -lwiringPi -lpthread **Paso 4**: Ejecuta. .. raw:: html .. code-block:: sudo ./a.out Después de iniciar el programa, el interruptor de palanca se moverá hacia la derecha, y el zumbador emitirá sonidos de alarma. Al mismo tiempo, los LED rojo y verde parpadearán a una cierta frecuencia. .. note:: Si no funciona después de ejecutarlo, o aparece un mensaje de error: \"wiringPi.h: No such file or directory", consulta :ref:`faq_c_nowork`. **Explicación del Código** .. code-block:: c #include  En este código, se usa una nueva biblioteca, pthread.h, que es un conjunto de bibliotecas de hilos comunes y permite la implementación de multihilos. Añadimos el parámetro **-lpthread** al momento de la compilación para que el LED y el zumbador funcionen de manera independiente. .. code-block:: c void *ledWork(void *arg){        while(1) { if(flag==0){ pthread_exit(NULL); } digitalWrite(ALedPin,HIGH); delay(500); digitalWrite(ALedPin,LOW); digitalWrite(BLedPin,HIGH); delay(500); digitalWrite(BLedPin,LOW); } } La función ledWork() se encarga de configurar el estado de funcionamiento de estos 2 LEDs: mantiene el LED verde encendido durante 0,5 s y luego se apaga; de manera similar, mantiene el LED rojo encendido durante 0,5 s y luego se apaga. .. code-block:: c void *buzzWork(void *arg){ while(1) { if(flag==0){ pthread_exit(NULL); } if((note>=800)||(note<=130)){             pitch = -pitch; } note=note+pitch; softToneWrite(BeepPin,note); delay(10); } } La función buzzWork() se utiliza para configurar el estado de funcionamiento del zumbador. Aquí establecemos la frecuencia entre 130 y 800, acumulando o decayendo en intervalos de 20. .. code-block:: c void on(){     flag = 1;     if(softToneCreate(BeepPin) == -1){         printf("setup softTone failed !"); return; }     pthread_t tLed;      pthread_create(&tLed,NULL,ledWork,NULL);     pthread_t tBuzz;   pthread_create(&tBuzz,NULL,buzzWork,NULL); } En la función on(): 1) Definimos la marca "flag=1", lo que indica el fin del hilo de control. 2) Creamos un pin de tono controlado por software **BeepPin**. 3) Creamos dos hilos independientes para que el LED y el zumbador puedan funcionar al mismo tiempo. **pthread_t tLed:** Declara un hilo **tLed**. **pthread_create(&tLed,NULL,ledWork,NULL):** Crea el hilo, y su prototipo es el siguiente: .. code-block:: int pthread_create(pthread_t *restrict tidp,const pthread_attr_t *restrict_attr, void*(*start_rtn)(void*),void *restrict arg); **Retorno del Valor** Si tiene éxito, devuelve "**0**"; de lo contrario, devuelve el **número de error** "\"**-1**\"". **Parámetros** | El primer parámetro es un puntero al identificador del hilo. | El segundo se usa para establecer el atributo del hilo. | El tercero es la dirección de inicio de la función de ejecución del hilo. | El último es el que ejecuta la función. .. code-block:: c void off(){     flag = 0; softToneStop(BeepPin); digitalWrite(ALedPin,LOW); digitalWrite(BLedPin,LOW); } La función off() define \"flag=0\" para salir de los hilos **ledWork** y **buzzWork** y luego apaga el zumbador y los LED. .. code-block:: c int main(){        setup();     int lastState = 0; while(1){         int currentState = digitalRead(switchPin);         if ((currentState == 1)&&(lastState==0)){ on(); }         else if((currentState == 0)&&(lastState==1)){ off(); }         lastState=currentState; }     return 0; } Main() contiene todo el proceso del programa: primero lee el valor del interruptor deslizante; si el interruptor se cambia a la derecha (la lectura es 1), se llama a la función on(), el zumbador emite sonidos y los LED rojo y verde parpadean. De lo contrario, el zumbador y los LED permanecen apagados. **Para Usuarios de Lenguaje Python** ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ **Paso 2:** Cambia de directorio. .. raw:: html .. code-block:: cd ~/davinci-kit-for-raspberry-pi/python/ **Paso 3:** Ejecuta. .. raw:: html .. code-block:: sudo python3 3.1.10_AlarmBell.py Después de iniciar el programa, el interruptor de palanca se moverá hacia la derecha, y el zumbador emitirá sonidos de alarma. Al mismo tiempo, los LED rojo y verde parpadearán a una cierta frecuencia. **Código** .. note:: Puedes **Modificar/Restablecer/Copiar/Ejecutar/Detener** el código a continuación. Pero antes, necesitas dirigirte a la ruta del código fuente, como ``davinci-kit-for-raspberry-pi/python``. .. raw:: html .. code-block:: python import RPi.GPIO as GPIO import time import threading BeepPin=22 ALedPin=17 BLedPin=27 switchPin=18 Buzz=0 flag =0 note=150 pitch=20 def setup(): GPIO.setmode(GPIO.BCM) GPIO.setup(BeepPin, GPIO.OUT) GPIO.setup(ALedPin,GPIO.OUT,initial=GPIO.LOW) GPIO.setup(BLedPin,GPIO.OUT,initial=GPIO.LOW) GPIO.setup(switchPin,GPIO.IN) global Buzz Buzz=GPIO.PWM(BeepPin,note) def ledWork(): while flag: GPIO.output(ALedPin,GPIO.HIGH) time.sleep(0.5) GPIO.output(ALedPin,GPIO.LOW) GPIO.output(BLedPin,GPIO.HIGH) time.sleep(0.5) GPIO.output(BLedPin,GPIO.LOW) def buzzerWork(): global pitch global note while flag: if note >= 800 or note <=130: pitch = -pitch note = note + pitch Buzz.ChangeFrequency(note) time.sleep(0.01) def on(): global flag flag = 1 Buzz.start(50) tBuzz = threading.Thread(target=buzzerWork) tBuzz.start() tLed = threading.Thread(target=ledWork) tLed.start() def off(): global flag flag = 0 Buzz.stop() GPIO.output(ALedPin,GPIO.LOW) GPIO.output(BLedPin,GPIO.LOW) def main(): lastState=0 while True: currentState =GPIO.input(switchPin) if currentState == 1 and lastState == 0: on() elif currentState == 0 and lastState == 1: off() lastState=currentState def destroy(): off() GPIO.cleanup() if __name__ == '__main__': setup() try: main() except KeyboardInterrupt: destroy() **Explicación del Código** .. code-block:: python import threading Aquí importamos el módulo **Threading**, que permite ejecutar múltiples tareas simultáneamente, mientras que los programas normales solo pueden ejecutar el código de arriba hacia abajo. Con los módulos **Threading**, el LED y el zumbador pueden funcionar por separado. .. code-block:: python def ledWork():     while flag: GPIO.output(ALedPin,GPIO.HIGH) time.sleep(0.5) GPIO.output(ALedPin,GPIO.LOW) GPIO.output(BLedPin,GPIO.HIGH) time.sleep(0.5) GPIO.output(BLedPin,GPIO.LOW) La función ledWork() ayuda a establecer el estado de funcionamiento de estos 2 LEDs: mantiene el LED verde encendido durante 0,5 s y luego se apaga; de manera similar, mantiene el LED rojo encendido durante 0,5 s y luego se apaga. .. code-block:: python def buzzerWork():     global pitch     global note     while flag:         if note >= 800 or note <=130:             pitch = -pitch         note = note + pitch  Buzz.ChangeFrequency(note) time.sleep(0.01) La función buzzWork() se utiliza para configurar el estado de funcionamiento del zumbador. Aquí establecemos la frecuencia entre 130 y 800, acumulando o decayendo en intervalos de 20. .. code-block:: python def on():     global flag     flag = 1 Buzz.start(50)     tBuzz = threading.Thread(target=buzzerWork)  tBuzz.start()     tLed = threading.Thread(target=ledWork)  tLed.start() En la función on(): 1) Definimos la marca \"flag=1\", lo que indica el inicio del hilo de control. 2) Inicia el Buzz y establece el ciclo de trabajo al 50%. 3) Crea **2** hilos separados para que el LED y el zumbador puedan funcionar al mismo tiempo. tBuzz = threading.Thread(target=buzzerWork) **:** Crea el hilo, cuyo prototipo es el siguiente: class threading.Thread(group=None, target=None, name=None, args=(), kwargs={}, \*, daemon=None) Entre los métodos de construcción, el parámetro principal es **target**, al cual necesitamos asignar un objeto invocable (en este caso, las funciones **ledWork** y **BuzzWork** ) a **target**. Luego se llama a **start()** para iniciar el objeto del hilo, por ejemplo, tBuzz.start() se usa para iniciar el hilo tBuzz recién creado. .. code-block:: python def off():     global flag     flag = 0 Buzz.stop() GPIO.output(ALedPin,GPIO.LOW) GPIO.output(BLedPin,GPIO.LOW) La función off() define \"flag=0\" para salir de los hilos **ledWork** y **buzzWork** y luego apaga el zumbador y los LED. .. code-block:: python def main(): lastState=0     while True:         currentState =GPIO.input(switchPin)         if currentState == 1 and lastState == 0: on()         elif currentState == 0 and lastState == 1: off() lastState=currentState Main() contiene todo el proceso del programa: primero lee el valor del interruptor deslizante; si el interruptor se cambia a la derecha (la lectura es 1), se llama a la función on(), el zumbador emite sonidos y los LEDs rojo y verde parpadean. De lo contrario, el zumbador y los LEDs permanecen apagados. Imagen del Fenómeno ------------------------ .. image:: img/image267.jpeg :align: center