Note

Bonjour, bienvenue dans la communauté Facebook des passionnés SunFounder Raspberry Pi, Arduino et ESP32 ! Plongez plus profondément dans l’univers du Raspberry Pi, de l’Arduino et de l’ESP32 avec d’autres passionnés.

Pourquoi nous rejoindre ?

  • Support d’experts : Résolvez vos problèmes après-vente et vos défis techniques avec l’aide de notre communauté et de notre équipe.

  • Apprendre & partager : Échangez des astuces et 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 derniers produits.

  • Promotions festives et concours : Participez à des tirages au sort et à des promotions spéciales.

👉 Prêt à explorer et créer avec nous ? Cliquez sur [Ici] et rejoignez-nous dès aujourd’hui !

2.2.1 Photo-résistance (MCP3008)

Note

../_images/mcp3008_and_adc0834.jpg

Selon la version de votre kit, identifiez si vous disposez du ADC0834 ou du MCP3008 et suivez la section correspondante.

Introduction

La photo-résistance est un composant couramment utilisé pour mesurer l’intensité lumineuse ambiante. Elle aide le contrôleur à distinguer le jour de la nuit et à réaliser des fonctions de contrôle de la lumière, comme une lampe de nuit. Ce projet est très similaire à celui du potentiomètre, sauf qu’ici la variation de tension est utilisée pour détecter la lumière.

Composants nécessaires

Dans ce projet, nous avons besoin des composants suivants.

../_images/list2_2.2.1_photoresistor.png

Principe

Une photo-résistance (ou cellule photoélectrique) est une résistance variable commandée par la lumière. La résistance d’une photo-résistance diminue lorsque l’intensité lumineuse incidente augmente ; autrement dit, elle présente une photoconductivité. Elle peut être utilisée dans des circuits détecteurs sensibles à la lumière ainsi que dans des circuits de commutation activés par la lumière ou l’obscurité.

../_images/image196.png

Schéma de câblage

Nom T-Board

Physique

WiringPi

BCM

SPICE0

pin24

10

8

SPIMOSI

pin19

12

10

SPIMISO

pin21

13

9

SPISCLK

pin23

14

11

GPIO22

pin15

3

22

../_images/schematic_2.2.1_photoresistor_mcp3008.png

Procédure expérimentale

Étape 1 : Monter le circuit.

../_images/july24_2.2.1_photoresistor_mcp3008.png

Étape 2 : Aller dans le dossier du code.

cd ~/davinci-kit-for-raspberry-pi/c/2.2.1-2/

Étape 3 : Compiler le code.

gcc 2.2.1_Photoresistor.c -o photoresistor -lwiringPi -lm

Étape 4 : Exécuter le fichier compilé.

./photoresistor

Lorsque le code est en cours d’exécution, la luminosité de la LED varie en fonction de l’intensité lumineuse détectée par la photo-résistance.

Note

Si le programme ne fonctionne pas après l’exécution, ou s’il affiche le message d’erreur : « wiringPi.h: No such file or directory », veuillez vous référer à Installer et vérifier WiringPi.

Code

#include <wiringPi.h>
#include <wiringPiSPI.h>
#include <stdio.h>
#include <softPwm.h>

#define SPI_CHANNEL 0       // Utiliser le canal SPI 0 (CE0)
#define SPI_SPEED   1000000 // Vitesse SPI 1 MHz
#define LedPin      3       // GPIO3 (WiringPi) pour le PWM de la LED

// Lecture d'une valeur ADC depuis le MCP3008, canal 0~7
int readMCP3008(int channel) {
    if (channel < 0 || channel > 7) return -1;

    unsigned char buffer[3];
    buffer[0] = 1;                          // Bit de démarrage
    buffer[1] = (8 + channel) << 4;         // SGL/DIF = 1, D2-D0 = canal
    buffer[2] = 0;

    wiringPiSPIDataRW(SPI_CHANNEL, buffer, 3);

    // Combiner le résultat
    int result = ((buffer[1] & 3) << 8) | buffer[2];
    return result;
}

int main(void) {
    if (wiringPiSetup() == -1) {
        printf("Initialisation wiringPi échouée !\n");
        return 1;
    }

    if (wiringPiSPISetup(SPI_CHANNEL, SPI_SPEED) == -1) {
        printf("Initialisation SPI échouée !\n");
        return 1;
    }

    softPwmCreate(LedPin, 0, 100); // Initialiser le PWM logiciel

    while (1) {
        int analogVal = readMCP3008(0); // Lecture sur CH0
        printf("Valeur ADC : %d\n", analogVal);

        // Mise à l’échelle de la valeur ADC 10 bits (0–1023) vers la plage PWM (0–100)
        int pwmVal = analogVal * 100 / 1023;
        softPwmWrite(LedPin, pwmVal);

        delay(100);
    }

    return 0;
}

Explication du code

Le code ici est identique à celui de la section 2.1.4 Potentiomètre. Si vous avez d’autres questions, reportez-vous aux explications détaillées de 2.1.4 Potentiomètre (MCP3008).