.. note:: Ciao e benvenuto nella Community di Appassionati di SunFounder per Raspberry Pi, Arduino ed ESP32 su Facebook! Esplora a fondo il mondo di Raspberry Pi, Arduino ed ESP32 insieme a tanti altri appassionati. **Perché Unirsi?** - **Supporto da Esperti**: Risolvi problemi post-vendita e 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 agli annunci dei nuovi prodotti e a contenuti inediti. - **Sconti Speciali**: Approfitta di sconti esclusivi sui nostri prodotti più recenti. - **Promozioni Festive e Giveaway**: Partecipa a concorsi e promozioni festive. 👉 Pronto a esplorare e creare con noi? Clicca su [|link_sf_facebook|] e unisciti oggi stesso! .. _1.3.1_py_pi5: 1.3.1 Motore ============= Introduzione ----------------- In questo progetto impareremo a utilizzare L293D per pilotare un motore DC e farlo ruotare in senso orario e antiorario. Poiché il motore DC richiede una corrente maggiore, per motivi di sicurezza utilizziamo il modulo di alimentazione per alimentare i motori. Componenti Necessari ------------------------------ In questo progetto, abbiamo bisogno dei seguenti componenti. .. image:: ../python_pi5/img/1.3.1_motor_list.png Schema Elettrico ------------------ .. image:: ../python_pi5/img/1.3.1_motor_schematic.png Procedure Sperimentali --------------------------- **Passo 1:** Costruisci il circuito. .. image:: ../python_pi5/img/1.3.1_motor_circuit.png .. note:: Il modulo di alimentazione può essere collegato a una batteria da 9V utilizzando il connettore per batteria incluso nel kit. Inserisci il cappuccio del jumper del modulo di alimentazione nelle strisce bus da 5V della breadboard. .. image:: ../python_pi5/img/1.3.1_motor_battery.jpeg **Passo 2**: Entra nella cartella del codice. .. raw:: html .. code-block:: cd ~/davinci-kit-for-raspberry-pi/python-pi5 **Passo 3**: Esegui. .. raw:: html .. code-block:: sudo python3 1.3.1_Motor.py Quando il codice viene eseguito, il motore ruota prima in senso orario per 5 secondi, quindi si ferma per 5 secondi, dopodiché ruota in senso antiorario per 5 secondi e si ferma successivamente per altri 5 secondi. Questa serie di azioni verrà ripetuta continuamente. .. warning:: Se compare l'errore ``RuntimeError: Cannot determine SOC peripheral base address``, consulta :ref:`faq_soc` **Codice** .. note:: Puoi **Modificare/Reimpostare/Copiare/Eseguire/Interrompere** il codice qui sotto. Prima di farlo, però, vai al percorso del codice sorgente, come ``davinci-kit-for-raspberry-pi/python-pi5``. Dopo aver modificato il codice, potrai eseguirlo direttamente per vedere il risultato. .. raw:: html .. code-block:: python #!/usr/bin/env python3 from gpiozero import Motor from time import sleep # Inizializza il motore con GPIO Zero, specificando i pin GPIO per avanzamento (17), retro (27) e abilitazione (22) motor = Motor(forward=17, backward=27, enable=22) try: # Funzione principale per controllare la direzione e il movimento del motore. # Alterna la rotazione del motore tra senso orario e antiorario con fermate intermedie. actions = {'CW': motor.forward, 'CCW': motor.backward, 'STOP': motor.stop} # Definisce le azioni del motore per leggibilità while True: # Ciclo per eseguire le azioni definite e controllare la direzione del motore for action in ['CW', 'STOP', 'CCW', 'STOP']: actions[action]() # Esegue l'azione corrente (avanzamento, stop, retro, stop) print(f"{action}") # Mostra l'azione corrente nella console sleep(5) # Pausa di 5 secondi prima di passare alla prossima azione except KeyboardInterrupt: # Gestisce l'interruzione da tastiera (es. Ctrl+C) per fermare il programma in modo sicuro pass **Spiegazione del Codice** #. Queste istruzioni di importazione richiamano la classe ``Motor`` dalla libreria ``gpiozero`` e la funzione ``sleep`` dal modulo ``time``. .. code-block:: python #!/usr/bin/env python3 from gpiozero import Motor from time import sleep #. Questa linea inizializza un oggetto ``Motor``, specificando i pin GPIO per avanzamento (17), retro (27) e abilitazione (22). .. code-block:: python # Inizializza il motore con GPIO Zero, specificando i pin GPIO per avanzamento (17), retro (27) e abilitazione (22) motor = Motor(forward=17, backward=27, enable=22) #. Le azioni per il controllo del motore sono definite in un dizionario per leggibilità. Un ciclo infinito (`while True`) esegue queste azioni, mantenendole per 5 secondi ciascuna. .. code-block:: python try: # Funzione principale per controllare la direzione e il movimento del motore. # Alterna la rotazione del motore tra senso orario e antiorario con fermate intermedie. actions = {'CW': motor.forward, 'CCW': motor.backward, 'STOP': motor.stop} # Definisce le azioni del motore per leggibilità while True: # Ciclo per eseguire le azioni definite e controllare la direzione del motore for action in ['CW', 'STOP', 'CCW', 'STOP']: actions[action]() # Esegue l'azione corrente (avanzamento, stop, retro, stop) print(f"{action}") # Mostra l'azione corrente nella console sleep(5) # Pausa di 5 secondi prima di passare alla prossima azione #. Questo segmento consente di terminare il programma in modo sicuro tramite un'interruzione da tastiera (Ctrl+C) senza generare errori. .. code-block:: python except KeyboardInterrupt: # Gestisce l'interruzione da tastiera (es. Ctrl+C) per fermare il programma in modo sicuro pass