.. note::
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 [|link_sf_facebook|] e unisciti oggi stesso!
.. _2.2.1_c_pi5_mcp3008:
2.2.1 Fotoresistenza (MCP3008)
==============================
.. note::
.. image:: ../img/mcp3008_and_adc0834.jpg
:width: 25%
:align: left
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.
.. image:: ../img/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à.
.. image:: ../img/image196.png
:width: 200
:align: center
Schema elettrico
----------------
.. list-table::
:widths: 30 30 30 30
:header-rows: 1
* - 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
.. image:: ../img/schematic_2.2.1_photoresistor_mcp3008.png
Procedura sperimentale
----------------------
**Passo 1:** Montare il circuito.
.. image:: ../img/july24_2.2.1_photoresistor_mcp3008.png
**Passo 2:** Accedere alla cartella del codice.
.. raw:: html
.. code-block::
cd ~/davinci-kit-for-raspberry-pi/c/2.2.1-2/
**Passo 3:** Compilare il codice.
.. raw:: html
.. code-block::
gcc 2.2.1_Photoresistor.c -o photoresistor -lwiringPi -lm
**Passo 4:** Eseguire il file compilato.
.. raw:: html
.. code-block::
./photoresistor
Quando il codice è in esecuzione, la luminosità del LED varierà in base all’intensità della luce rilevata dalla fotoresistenza.
.. note::
Se non funziona dopo l’esecuzione, o compare l’errore: \"wiringPi.h: No such file or directory\", fare riferimento a :ref:`install_wiringpi_pi5`.
**Codice**
.. code-block:: c
#include
#include
#include
#include
#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 :ref:`2.1.4_c_pi5_mcp3008` per maggiori dettagli.