Nota

Ciao, benvenuto nella Community SunFounder Raspberry Pi & Arduino & ESP32 Enthusiasts su Facebook! Approfondisci Raspberry Pi, Arduino ed ESP32 con altri appassionati.

Perché unirsi?

  • Supporto esperto: Risolvi problemi post-vendita e sfide tecniche con l’aiuto della community e del nostro team.

  • Impara e condividi: Scambia consigli e tutorial per migliorare le tue competenze.

  • Anteprime esclusive: Accedi in anteprima ai nuovi annunci di prodotti e alle anteprime speciali.

  • Sconti speciali: Godi di sconti esclusivi sui nostri prodotti più recenti.

  • Promozioni e giveaway festivi: Partecipa a concorsi e promozioni durante le festività.

👉 Pronto a esplorare e creare con noi? Clicca [Qui] e unisciti oggi stesso!

2.2.1 Fotoresistenza (MCP3008)

Nota

../_images/mcp3008_and_adc0834.jpg

A seconda della versione del kit, identifica se hai ADC0834 o MCP3008 e procedi con la sezione corrispondente.

Introduzione

La fotoresistenza è un componente comunemente usato per rilevare l’intensità della luce ambientale. Aiuta il controllore a distinguere tra giorno e notte e a realizzare funzioni di controllo della luce, come una lampada notturna. Questo progetto è molto simile a quello con il potenziometro: potresti pensare che funzioni modificando la tensione per rilevare la luce.

Componenti richiesti

In questo progetto sono necessari i seguenti componenti.

../_images/list2_2.2.1_photoresistor.png

Principio

Una fotoresistenza o fotocellula è una resistenza variabile controllata dalla luce. La resistenza di una fotoresistenza diminuisce all’aumentare dell’intensità della luce incidente; in altre parole, mostra fotoconduttività. Una fotoresistenza può essere applicata in circuiti rilevatori sensibili alla luce, e in circuiti di commutazione attivati dalla luce o dall’oscurità.

../_images/image196.png

Schema elettrico

Nome T-Board

physical

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

Procedura sperimentale

Passo 1: Montare il circuito.

../_images/july24_2.2.1_photoresistor_mcp3008.png

Passo 2: Accedere alla cartella del codice.

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

Passo 3: Compilare il codice.

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

Passo 4: Eseguire il file compilato.

./photoresistor

Quando il codice è in esecuzione, la luminosità del LED varierà in base all’intensità della luce rilevata dalla fotoresistenza.

Nota

Se non funziona dopo l’esecuzione, o compare l’errore: "wiringPi.h: No such file or directory", fare riferimento a Installazione e verifica di WiringPi.

Codice

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

#define SPI_CHANNEL 0      // Usa canale SPI 0 (CE0)
#define SPI_SPEED   1000000 // Velocità SPI 1 MHz
#define LedPin      3       // GPIO3 (WiringPi) per PWM LED

// Legge il valore ADC da MCP3008, canali 0~7
int readMCP3008(int channel) {
    if (channel < 0 || channel > 7) return -1;

    unsigned char buffer[3];
    buffer[0] = 1;                          // Bit di avvio
    buffer[1] = (8 + channel) << 4;         // SGL/DIF = 1, D2-D0 = canale
    buffer[2] = 0;

    wiringPiSPIDataRW(SPI_CHANNEL, buffer, 3);

    // Combina il risultato
    int result = ((buffer[1] & 3) << 8) | buffer[2];
    return result;
}

int main(void) {
    if (wiringPiSetup() == -1) {
        printf("Inizializzazione wiringPi fallita!\n");
        return 1;
    }

    if (wiringPiSPISetup(SPI_CHANNEL, SPI_SPEED) == -1) {
        printf("Inizializzazione SPI fallita!\n");
        return 1;
    }

    softPwmCreate(LedPin, 0, 100); // Inizializza PWM software

    while (1) {
        int analogVal = readMCP3008(0); // Legge da CH0
        printf("Valore ADC: %d\n", analogVal);

        // Scala il valore ADC a 10 bit (0–1023) al range PWM (0–100)
        int pwmVal = analogVal * 100 / 1023;
        softPwmWrite(LedPin, pwmVal);

        delay(100);
    }

    return 0;
}

Spiegazione del codice

Il codice qui è lo stesso di quello della sezione 2.1.4 Potenziometro. Se hai altre domande, consulta la spiegazione del codice in 2.1.4 Potenziometro (MCP3008) per maggiori dettagli.