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 [Ici] et rejoignez-nous aujourd’hui !

4.1.1 Appareil photo

Introduction

Ici, nous allons fabriquer un appareil photo avec un déclencheur. Lorsque vous appuyez sur le bouton, l’appareil photo prend une photo pendant que la LED clignote.

Composants nécessaires

Dans ce projet, nous avons besoin des composants suivants.

../_images/3.1.15camera_list.png

Il est certainement pratique d’acheter un kit complet, voici le lien :

Nom

ÉLÉMENTS DANS CE KIT

LIEN

Kit Raphael

337

Raphael Kit

Vous pouvez également les acheter séparément aux liens ci-dessous.

INTRODUCTION DES COMPOSANTS

LIEN D’ACHAT

Carte d’extension GPIO

ACHETER

Plaque d’expérimentation (Breadboard)

ACHETER

Fils de Liaison

ACHETER

Résistance

ACHETER

LED

ACHETER

Bouton

ACHETER

Module de Caméra

ACHETER

Schéma de câblage

Nom T-Board

physique

wiringPi

BCM

GPIO17

Pin 11

0

17

GPIO18

Pin 12

1

18

../_images/4.1.1_camera_schematic.png

Procédures expérimentales

Étape 1 : Construire le circuit.

../_images/4.1.1_camera_circuit.png

Étape 2 : Pour connecter le module caméra et compléter la configuration, veuillez vous référer à : Module de Caméra.

Étape 3 : Accédez au bureau de la Raspberry Pi. Vous aurez peut-être besoin d’un écran pour une meilleure expérience, référez-vous à : Connect your Raspberry Pi. Ou accédez au bureau de la Raspberry Pi à distance, pour un tutoriel détaillé, veuillez vous référer à : Bureau à distance.

Étape 4 : Ouvrez un terminal et accédez au dossier du code.

cd ~/raphael-kit/python/

Étape 5 : Exécutez le code.

sudo python3 4.1.1_Camera.py

Après l’exécution du code, appuyez sur le bouton, la Raspberry Pi fera clignoter la LED et prendra une photo. La photo sera nommée my_photo.jpg et stockée dans le répertoire ~.

Note

Vous pouvez également ouvrir 4.1.1_Camera.py dans le chemin ~/raphael-kit/python/ avec un IDE Python, cliquer sur le bouton Run pour exécuter et sur le bouton Stop pour arrêter le code.

Si vous souhaitez télécharger la photo sur votre PC, veuillez vous référer à : Logiciel FileZilla.

Code

Note

Vous pouvez Modifier/Réinitialiser/Copier/Exécuter/Arrêter le code ci-dessous. Mais avant cela, vous devez vous rendre dans le chemin du code source comme raphael-kit/python. Après avoir modifié le code, vous pouvez l’exécuter directement pour voir l’effet.

#!/usr/bin/env python3
import time
import os
import RPi.GPIO as GPIO
from picamera2 import Picamera2, Preview

# ----------------------------
# GPIO SETUP
# ----------------------------

BUTTON_PIN = 18  # The push button is connected to GPIO18
LED_PIN = 17     # The LED is connected to GPIO17

GPIO.setmode(GPIO.BCM)  # Use BCM GPIO numbering

# The button uses a 10K pull-up resistor externally.
# When released → HIGH, when pressed → LOW.
GPIO.setup(BUTTON_PIN, GPIO.IN, pull_up_down=GPIO.PUD_UP)

# LED is an output (HIGH → ON, LOW → OFF)
GPIO.setup(LED_PIN, GPIO.OUT)
GPIO.output(LED_PIN, GPIO.LOW)  # Ensure LED is OFF at startup

# ----------------------------
# USER DIRECTORY SETUP
# ----------------------------

# Get the current logged-in username
user = os.getlogin()

# Build the path to the user's home directory (ex: /home/pi)
user_home = os.path.expanduser(f"~{user}")

# ----------------------------
# CAMERA SETUP
# ----------------------------

# Create a Picamera2 object
camera = Picamera2()

# Create a preview configuration:
# main → the main camera stream
# size → resolution 800x600
# format → display format used by the preview window
preview_config = camera.create_preview_configuration(
    main={"size": (800, 600), "format": "XRGB8888"}
)

# Apply the configuration to the camera
camera.configure(preview_config)

# Start the preview window using QTGL (GPU-accelerated)
camera.start_preview(Preview.QTGL)

# Start the camera hardware
camera.start()

print("Ready! Press the button to take a photo...")

# ----------------------------
# MAIN LOOP
# ----------------------------
try:
    while True:
        # Check if button is pressed (LOW means pressed)
        if GPIO.input(BUTTON_PIN) == GPIO.LOW:
            print("Button pressed! Taking photo...")

            # Flash LED 3 times to warn before taking the photo
            for _ in range(3):
                GPIO.output(LED_PIN, GPIO.HIGH)
                time.sleep(0.1)
                GPIO.output(LED_PIN, GPIO.LOW)
                time.sleep(0.1)

            # Build a unique filename using current date and time
            # Example: /home/pi/my_photo_20251201_143522.jpg
            timestamp = time.strftime("%Y%m%d_%H%M%S")
            filename = os.path.join(user_home, f"my_photo_{timestamp}.jpg")

            # Capture the image
            camera.capture_file(filename)

            print(f"Photo saved to: {filename}")

            # Turn LED ON briefly to confirm capture
            GPIO.output(LED_PIN, GPIO.HIGH)
            time.sleep(0.5)
            GPIO.output(LED_PIN, GPIO.LOW)

            # Debounce delay to prevent repeated triggers
            time.sleep(0.3)

        # Small delay to reduce CPU usage
        time.sleep(0.01)

# ----------------------------
# CLEAN EXIT WHEN CTRL+C IS PRESSED
# ----------------------------
except KeyboardInterrupt:
    print("\nCtrl+C received, exiting...")

# ----------------------------
# CLEANUP SECTION
# ----------------------------
finally:
    # Safely try to stop the camera preview
    try:
        camera.stop_preview()
    except:
        pass  # Ignore errors if preview wasn't running

    # Safely close the camera device
    try:
        camera.close()
    except:
        pass

    # Reset GPIO pins to a safe state
    GPIO.cleanup()

    print("Program exited cleanly.")

Explication du code

  1. Vérifie si le bouton connecté à BUTTON_PIN est pressé.

    if GPIO.input(BUTTON_PIN) == GPIO.LOW:
    

    Comme le bouton utilise une résistance de tirage vers le haut (pull-up), son état par défaut est HIGH. Lorsque le bouton est pressé, le signal devient LOW et déclenche le processus de capture d’image.

  2. Fait clignoter la LED trois fois comme retour visuel avant de prendre une photo.

    for _ in range(3):
        GPIO.output(LED_PIN, GPIO.HIGH)
        time.sleep(0.1)
        GPIO.output(LED_PIN, GPIO.LOW)
        time.sleep(0.1)
    

    Cela indique que le Raspberry Pi se prépare à capturer une image.

  3. Génère un nom de fichier unique à l’aide d’un horodatage et capture une photo.

    timestamp = time.strftime("%Y%m%d_%H%M%S")
    filename = os.path.join(user_home, f"my_photo_{timestamp}.jpg")
    camera.capture_file(filename)
    

    L’horodatage garantit que chaque photo capturée possède un nom différent. L’image est ensuite enregistrée dans le répertoire personnel de l’utilisateur.

  4. Allume la LED pendant 0,5 seconde pour confirmer qu’une photo a été prise.

    GPIO.output(LED_PIN, GPIO.HIGH)
    time.sleep(0.5)
    GPIO.output(LED_PIN, GPIO.LOW)
    

    Cette brève illumination signale que la capture a réussi.

  5. Ajoute un court délai pour éviter plusieurs déclenchements lors d’un seul appui sur le bouton.

    time.sleep(0.3)
    

    Ce délai d’antirebond assure un fonctionnement fiable du bouton.

Photo du Phénomène

../_images/4.1.1camera.JPG