.. note:: Bonjour et bienvenue dans la Communauté Facebook des passionnés de Raspberry Pi, Arduino et ESP32 de SunFounder ! Plongez plus profondément dans l'univers des Raspberry Pi, Arduino et ESP32 avec d'autres passionnés. **Pourquoi rejoindre ?** - **Support d'experts** : Résolvez les problèmes après-vente et les défis techniques avec l'aide de notre communauté et de notre équipe. - **Apprendre et partager** : Échangez des astuces et des tutoriels pour améliorer vos compétences. - **Aperçus exclusifs** : Accédez en avant-première aux annonces de nouveaux produits et aux aperçus. - **Réductions spéciales** : Profitez de réductions exclusives sur nos produits les plus récents. - **Promotions festives et cadeaux** : Participez à des cadeaux et des promotions de vacances. 👉 Prêt à explorer et à créer avec nous ? Cliquez [|link_sf_facebook|] et rejoignez-nous aujourd'hui ! .. _1.3.2_c: 1.3.2 Servo ================= Introduction -------------- Dans ce projet, nous allons apprendre à faire tourner un servo-moteur. Required Components ------------------------------ Dans ce projet, nous avons besoin des composants suivants. .. image:: ../img/list_1.3.2.png Il est définitivement pratique d'acheter un kit complet, voici le lien : .. list-table:: :widths: 20 20 20 :header-rows: 1 * - Name - ITEMS IN THIS KIT - LINK * - Raphael Kit - 337 - |link_Raphael_kit| Vous pouvez également les acheter séparément aux liens ci-dessous. .. list-table:: :widths: 30 20 :header-rows: 1 * - INTRODUCTION DES COMPOSANTS - LIEN D'ACHAT * - :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| Schematic Diagram ----------------- .. image:: ../img/image337.png Experimental Procedures ----------------------- **Step 1:** Construisez le circuit. .. image:: ../img/image125.png **Step 2**: Accédez au dossier du code. .. raw:: html .. code-block:: cd ~/raphael-kit/c/1.3.2 **Step 3**: Compilez le code. .. raw:: html .. code-block:: gcc 1.3.2_Servo.c -lwiringPi **Step 4**: Exécutez le fichier exécutable. .. raw:: html .. code-block:: sudo ./a.out Après l'exécution du programme, le servo va tourner de 0 degrés à 180 degrés, puis de 180 degrés à 0 degrés, en boucle. .. note:: Si cela ne fonctionne pas après exécution, ou s'il y a un message d'erreur : "wiringPi.h : Aucun fichier ou répertoire de ce type", veuillez vous référer à :ref:`install_wiringpi`. **Code** .. code-block:: c #include #include #include #define ServoPin 1 //define the servo to 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){ //Create a funtion to control the angle of the 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){ //when initialize wiring failed,print message to screen printf("setup wiringPi failed !"); return 1; } softPwmCreate(ServoPin, 0, 200); //initialize PMW pin of servo while(1){ for(i=0;i<181;i++){ // Let servo rotate from 0 to 180. setAngle(ServoPin,i); delay(2); } delay(1000); for(i=181;i>-1;i--){ // Let servo rotate from 180 to 0. setAngle(ServoPin,i); delay(2); } delay(1000); } return 0; } **Explication du Code** .. code-block:: c long Map(long value,long fromLow,long fromHigh,long toLow,long toHigh){ return (toHigh-toLow)*(value-fromLow) / (fromHigh-fromLow) + toLow; } Créer une fonction ``Map()`` pour mapper la valeur dans le code suivant. .. code-block:: c void setAngle(int pin, int angle){ //Create a funtion to control the angle of the servo. if(angle < 0) angle = 0; if(angle > 180) angle = 180; softPwmWrite(pin,Map(angle, 0, 180, 5, 25)); } Créer une fonction, ``setAngle()`` pour écrire l'angle sur le servo. .. code-block:: c softPwmWrite(pin,Map(angle,0,180,5,25)); Cette fonction peut changer le cycle de service du PWM. Pour faire tourner le servo de 0 à 180 °, la largeur d'impulsion doit changer dans la plage de 0,5 ms à 2,5 ms lorsque la période est de 20 ms ; dans la fonction, ``softPwmCreate()`` , nous avons défini que la période est 200x100us=20ms, nous devons donc mapper 0 ~ 180 à 5x100us ~ 25x100us. Le prototype de cette fonction est montré ci-dessous. .. code-block:: int softPwmCreate(int pin,int initialValue,int pwmRange); * ``pin``: N'importe quelle broche GPIO du Raspberry Pi peut être définie comme broche PWM. * ``initialValue``: La largeur d'impulsion initiale est cette valeur initiale multipliée par 100us. * ``pwmRange``: la période du PWM est cette plage PWM multipliée par 100us. Photo du Phénomène ----------------------- .. image:: ../img/image126.jpeg