.. 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.1.4_js: 1.1.4 Afficheur à 7 segments ================================= Introduction ---------------- Essayons de piloter un afficheur à 7 segments pour afficher des chiffres de 0 à 9 et des lettres de A à F. Composants requis --------------------------------- Pour ce projet, nous avons besoin des composants suivants. .. image:: img/list_7_segment.png Il est définitivement pratique d'acheter un kit complet, voici le lien : .. list-table:: :widths: 20 20 20 :header-rows: 1 * - Nom - ARTICLES DANS CE KIT - LIEN * - Kit Raphael - 337 - |link_Raphael_kit| Vous pouvez également les acheter séparément via les liens ci-dessous. .. list-table:: :widths: 30 20 :header-rows: 1 * - INTRODUCTION AUX 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_resistor` - |link_resistor_buy| * - :ref:`cpn_7_segment` - |link_7segment_buy| * - :ref:`cpn_74hc595` - |link_74hc595_buy| Schéma de câblage --------------------- Connectez la broche ST_CP du 74HC595 au GPIO18 du Raspberry Pi, SH_CP au GPIO27, DS au GPIO17, et les ports de sortie parallèle aux 8 segments de l'afficheur à 7 segments. Entrez les données dans la broche DS pour le registre à décalage lorsque SH_CP (l'entrée d'horloge du registre à décalage) est sur le front montant, et pour le registre mémoire lorsque ST_CP (l'entrée d'horloge de la mémoire) est sur le front montant. Ensuite, vous pouvez contrôler les états de SH_CP et ST_CP via les GPIOs du Raspberry Pi pour transformer l'entrée de données série en sortie de données parallèle afin d'économiser les GPIOs du Raspberry Pi et piloter l'afficheur. .. image:: img/schematic_7_segment.png Procédures expérimentales ---------------------------- **Étape 1 :** Construisez le circuit. .. image:: img/image73.png **Étape 2 :** Accédez au dossier contenant le code. .. raw:: html .. code-block:: cd ~/raphael-kit/nodejs/ **Étape 3 :** Exécutez le code. .. raw:: html .. code-block:: sudo node 7-segment_display.js Après l'exécution du code, vous verrez l'afficheur 7 segments afficher de 0 à 9 et de A à F. **Code** .. code-block:: js const Gpio = require('pigpio').Gpio; const segCode = [0x3f, 0x06, 0x5b, 0x4f, 0x66, 0x6d, 0x7d, 0x07, 0x7f, 0x6f, 0x77, 0x7c, 0x39, 0x5e, 0x79, 0x71]; const SDI = new Gpio(17, { mode: Gpio.OUTPUT }); const RCLK = new Gpio(18, { mode: Gpio.OUTPUT }); const SRCLK = new Gpio(27, { mode: Gpio.OUTPUT }); function hc595_shift(dat) { for (let j = 0; j < 8; j++) { let code = 0x80 & (dat << j); if (code != 0) { code = 1; } SDI.digitalWrite(code); SRCLK.trigger(1,1); } RCLK.trigger(1,1); } let index = -1; setInterval(() => { index = (index+1)%16; hc595_shift(segCode[index]); }, 1000); **Explication du Code** .. code-block:: js const segCode = [0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71]; Définir un tableau de codes hexadécimaux (cathode commune) pour les segments de 0 à F. .. code-block:: js const SDI = new Gpio(17, { mode: Gpio.OUTPUT }); const RCLK = new Gpio(18, { mode: Gpio.OUTPUT }); const SRCLK = new Gpio(27, { mode: Gpio.OUTPUT }); Initialiser les broches 17, 18 et 27 en mode sortie, et les assigner respectivement à ``SDI``, ``RCLK`` et ``SRCLK``. .. code-block:: js function hc595_shift(dat) { for (let j = 0; j < 8; j++) { let code = 0x80 & (dat << j); if (code != 0) { code = 1; } SDI.digitalWrite(code); SRCLK.trigger(1,1); } RCLK.trigger(1,1); } Implémenter une fonction ``hc595_shift`` pour convertir les champs du tableau ``segCode`` en nombres et les afficher sur le tube numérique. .. code-block:: js let code = 0x80 & (dat << j); if (code != 0) { code = 1; } SDI.digitalWrite(code); Assigner les données de dat à SDI(DS) par bits. Supposons que dat=0x3f (0011 1111, quand j=2, 0x3f sera décalé vers la droite (<<) de 2 bits. 1111 1100 (0x3f << 2) & 1000 0000 (0x80) = 1000 0000, ce qui est vrai. À ce moment, 1 est écrit dans SDI. .. code-block:: js SRCLK.trigger(1,1); Générer une impulsion montante et déplacer les données DS vers le registre de décalage. ``trigger(pulseLen, level)`` * pulseLen - longueur de l'impulsion en microsecondes (1 - 100) * level - 0 ou 1 Envoyer une impulsion de déclenchement au GPIO. Le GPIO est réglé sur level pendant pulseLen microsecondes, puis réinitialisé à non level. .. code-block:: js RCLK.trigger(1,1); Générer une impulsion montante et déplacer les données du registre de décalage vers le registre de stockage. .. code-block:: js let index = -1; setInterval(() => { index = (index+1)%16; hc595_shift(segCode[index]); }, 1000); Enfin, utiliser la fonction ``hc595_shift()`` pour convertir les champs dans ``segCode`` et les afficher via le tube numérique. Image du Phénomène --------------------------- .. image:: img/image74.jpeg