.. 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.2.1_py_pi5:
1.2.1 Buzzer Actif
======================
Introduction
---------------
Dans ce projet, nous apprendrons comment faire sonner un buzzer actif avec un transistor NPN.
Composants Nécessaires
--------------------------
Pour ce projet, nous avons besoin des composants suivants.
.. image:: ../python_pi5/img/1.2.1_active_buzzer_list.png
Il est certainement pratique d'acheter un kit complet, voici le lien :
.. list-table::
:widths: 20 20 20
:header-rows: 1
* - Nom
- ÉLÉMENTS 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 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_resistor`
- |link_resistor_buy|
* - :ref:`cpn_buzzer`
- \-
* - :ref:`cpn_transistor`
- |link_transistor_buy|
Schéma de Montage
--------------------
Dans cette expérience, on utilise un buzzer actif, un transistor NPN et une résistance de 1 kΩ. La résistance est placée entre la broche GPIO et la base du transistor afin de limiter le courant de base et de protéger le transistor. Lorsque la broche GPIO17 du Raspberry Pi fournit un niveau haut (3,3 V), le transistor entre en saturation, ce qui permet au courant de traverser le buzzer, produisant ainsi un son. Lorsque le GPIO17 fournit un niveau bas (0 V), le transistor est coupé et le buzzer reste silencieux.
============ ======== ======== ===
Nom T-Board Physique wiringPi BCM
GPIO17 Pin 11 0 17
============ ======== ======== ===
.. image:: ../python_pi5/img/1.2.1_active_buzzer_schematic.png
Procédures Expérimentales
--------------------------------
**Étape 1 :** Construisez le circuit. (Le buzzer actif a une étiquette blanche sur la surface et un dos noir.)
.. image:: ../python_pi5/img/1.2.1_ActiveBuzzer_circuit.png
**Étape 2 :** Ouvrez le fichier de code.
.. raw:: html
.. code-block::
cd ~/raphael-kit/python-pi5
**Étape 3 :** Exécutez.
.. raw:: html
.. code-block::
sudo python3 1.2.1_ActiveBuzzer_zero.py
Le code s'exécute et le buzzer émet un bip.
.. warning::
Si vous recevez le message d'erreur ``RuntimeError: Cannot determine SOC peripheral base address``, veuillez consulter :ref:`faq_soc`
**Code**
.. note::
Vous pouvez **Modifier/Réinitialiser/Copier/Exécuter/Arrêter** le code ci-dessous. Mais avant cela, vous devez aller au chemin source du code comme ``raphael-kit/python-pi5``. Après avoir modifié le code, vous pouvez l'exécuter directement pour voir l'effet.
.. raw:: html
.. code-block:: python
#!/usr/bin/env python3
from gpiozero import Buzzer
from time import sleep
# Initialize a Buzzer object on GPIO pin 17
buzzer = Buzzer(17)
try:
while True:
# Turn on the buzzer
print('Buzzer On')
buzzer.on()
sleep(0.1) # Keep the buzzer on for 0.1 seconds
# Turn off the buzzer
print('Buzzer Off')
buzzer.off()
sleep(0.1) # Keep the buzzer off for 0.1 seconds
except KeyboardInterrupt:
# Handle KeyboardInterrupt (Ctrl+C) for clean script termination
pass
**Explication du Code**
#. Ces instructions importent la classe ``Buzzer`` de la bibliothèque ``gpiozero`` et la fonction ``sleep`` du module ``time``.
.. code-block:: python
#!/usr/bin/env python3
from gpiozero import Buzzer
from time import sleep
#. Cette ligne crée un objet ``Buzzer`` connecté au GPIO pin 17 sur le Raspberry Pi.
.. code-block:: python
# Initialize a Buzzer object on GPIO pin 17
buzzer = Buzzer(17)
#. Dans une boucle infinie (``while True``), le buzzer est allumé et éteint toutes les 0,1 secondes. Les instructions ``print`` fournissent une sortie console pour chaque action.
.. code-block:: python
try:
while True:
# Turn on the buzzer
print('Buzzer On')
buzzer.on()
sleep(0.1) # Keep the buzzer on for 0.1 seconds
# Turn off the buzzer
print('Buzzer Off')
buzzer.off()
sleep(0.1) # Keep the buzzer off for 0.1 seconds
#. Ce segment assure que le programme peut être terminé en toute sécurité en utilisant une interruption clavier (Ctrl+C) sans générer d'erreur.
.. code-block:: python
except KeyboardInterrupt:
# Handle KeyboardInterrupt (Ctrl+C) for clean script termination
pass