.. note::
Ciao, benvenuto nella community di SunFounder Raspberry Pi & Arduino & ESP32 su Facebook! Approfondisci le tue conoscenze su Raspberry Pi, Arduino ed ESP32 insieme ad altri appassionati.
**Perché unirti a noi?**
- **Supporto Esperto**: Risolvi i problemi post-vendita e le sfide tecniche con l'aiuto della nostra comunità e del nostro team.
- **Impara e Condividi**: Scambia suggerimenti e tutorial per migliorare le tue competenze.
- **Anteprime Esclusive**: Ottieni accesso anticipato agli annunci di nuovi prodotti e alle anteprime.
- **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 subito!
.. _1.3.2_c:
1.3.2 Servo
=================
Introduzione
--------------
In questo progetto, impareremo come far ruotare un servo.
Componenti Necessari
------------------------------
In questo progetto, abbiamo bisogno dei seguenti componenti.
.. image:: ../img/list_1.3.2.png
È sicuramente conveniente acquistare un kit completo, ecco il link:
.. list-table::
:widths: 20 20 20
:header-rows: 1
* - Nome
- COMPONENTI NEL KIT
- LINK
* - Raphael Kit
- 337
- |link_Raphael_kit|
Puoi anche acquistarli separatamente dai link seguenti.
.. list-table::
:widths: 30 20
:header-rows: 1
* - INTRODUZIONE AI COMPONENTI
- LINK PER L'ACQUISTO
* - :ref:`cpn_gpio_extension_board`
- |link_gpio_board_buy|
* - :ref:`cpn_breadboard`
- |link_breadboard_buy|
* - :ref:`cpn_wires`
- |link_wires_buy|
* - :ref:`cpn_servo`
- |link_servo_buy|
Schema Elettrico
---------------------
.. image:: ../img/image337.png
Procedure Sperimentali
---------------------------
**Passo 1:** Costruisci il circuito.
.. image:: ../img/image125.png
**Passo 2**: Entra nella cartella del codice.
.. raw:: html
.. code-block::
cd ~/raphael-kit/c/1.3.2
**Passo 3**: Compila il codice.
.. raw:: html
.. code-block::
gcc 1.3.2_Servo.c -lwiringPi
**Passo 4**: Esegui il file eseguibile.
.. raw:: html
.. code-block::
sudo ./a.out
Dopo l'esecuzione del programma, il servo ruoterà da
0 gradi a 180 gradi, e poi da 180 gradi a 0 gradi, ciclicamente.
.. note::
Se il codice non funziona o appare un errore come: \"wiringPi.h: No such file or directory\", fai riferimento a :ref:`install_wiringpi`.
**Codice**
.. code-block:: c
#include
#include
#include
#define ServoPin 1 //definisci il servo su GPIO1
long Map(long value,long fromLow,long fromHigh,long toLow,long toHigh){
return (toHigh-toLow)*(value-fromLow) / (fromHigh-fromLow) + toLow;
}
void setAngle(int pin, int angle){ //Crea una funzione per controllare l'angolo del servo.
if(angle < 0)
angle = 0;
if(angle > 180)
angle = 180;
softPwmWrite(pin,Map(angle, 0, 180, 5, 25));
}
int main(void)
{
int i;
if(wiringPiSetup() == -1){ //quando l'inizializzazione di wiring fallisce, stampa messaggio a schermo
printf("setup wiringPi failed !");
return 1;
}
softPwmCreate(ServoPin, 0, 200); //inizializza il pin PWM del servo
while(1){
for(i=0;i<181;i++){ // Lascia ruotare il servo da 0 a 180 gradi. setAngle(ServoPin,i);
delay(2);
}
delay(1000);
for(i=181;i>-1;i--){ // Lascia ruotare il servo da 180 a 0 gradi. setAngle(ServoPin,i);
delay(2);
}
delay(1000);
}
return 0;
}
**Spiegazione del Codice**
.. code-block:: c
long Map(long value,long fromLow,long fromHigh,long toLow,long toHigh){
return (toHigh-toLow)*(value-fromLow) / (fromHigh-fromLow) + toLow;
}
Crea una funzione ``Map()`` per mappare i valori nel codice seguente.
.. code-block:: c
void setAngle(int pin, int angle){ //Crea una funzione per controllare l'angolo del servo.
if(angle < 0)
angle = 0;
if(angle > 180)
angle = 180;
softPwmWrite(pin,Map(angle, 0, 180, 5, 25));
}
Crea una funzione, ``setAngle()`` per impostare l'angolo del servo.
.. code-block:: c
softPwmWrite(pin,Map(angle,0,180,5,25));
Questa funzione può cambiare il ciclo di lavoro del PWM.
Per far ruotare il servo da 0 a 180°, la larghezza dell'impulso deve variare
tra 0,5ms e 2,5ms quando il periodo è di 20ms; nella
funzione, ``softPwmCreate()``, abbiamo impostato che il periodo è
200x100us=20ms, quindi dobbiamo mappare 0 ~ 180 a 5x100us ~ 25x100us.
Il prototipo di questa funzione è mostrato di seguito.
.. code-block::
int softPwmCreate(int pin,int initialValue,int pwmRange);
* ``pin``: Qualsiasi pin GPIO del Raspberry Pi può essere impostato come pin PWM.
* ``initialValue``: La larghezza dell'impulso iniziale è pari a initialValue moltiplicato per 100us.
* ``pwmRange``: il periodo del PWM è pari a pwmRange moltiplicato per 100us.
Immagine del Fenomeno
---------------------------
.. image:: ../img/image126.jpeg