DHT22 : température et humidité sur un afficheur 7 segments avec Arduino RJT43
Ce projet montre comment construire un système simple mais efficace pour afficher les relevés de température et d'humidité sur un afficheur à 7 segments en utilisant un Arduino. Cette configuration est utile pour diverses applications où la surveillance des conditions environnementales est cruciale. Le projet associe le capteur de température et d'humidité DHT22 à un afficheur 7 segments TM1637, offrant un affichage clair et facile à lire.


Idées de projet :
- Surveillance d'un environnement domestique pour un confort optimal.
- Suivi des conditions dans une serre ou un terrarium.
- Construire une station météorologique de base.
- Affichage de la température et de l'humidité dans un projet d'enregistrement de données.
Matériel/Composants
Pour réaliser ce projet, vous aurez besoin des composants suivants :
- Arduino Uno (ou carte compatible)
- Capteur de température et d'humidité DHT22
- Afficheur 7 segments TM1637
- Fils de connexion
- Plaque d'essai (optionnelle, mais recommandée)
Guide de câblage



Le câblage est simple. Reportez-vous à la vidéo (à 01:51) pour un guide visuel. Les connexions clés sont :
- Afficheur TM1637:VCC vers 5V, GND vers GND, CLK vers la broche 2 de l'Arduino, DIO vers la broche 3 de l'Arduino (dans la vidéo à 02:00).
- Capteur DHT22:VCC vers 5V, GND vers GND, DATA vers la broche 9 de l'Arduino (dans la vidéo à 02:20). Notez que la vidéo utilise la broche 8 de l'Arduino pour fournir 5V au capteur (dans la vidéo à 02:41).
%%CÂBLAGE%%
Explication du code
Le code Arduino utilise deux bibliothèques : TM1637Display pour l'afficheur 7 segments et DHT pour le capteur DHT22. Les paramètres configurables du code se trouvent principalement au début :
// Module connection pins (Digital Pins)
#define CLK 2
#define DIO 3
#define DHTPIN 9 // DHT22 data pin
#define DHTTYPE DHT22 // DHT sensor type
Ces lignes définissent les broches Arduino connectées à l'écran et au capteur DHT22. Vous devrez peut-être les ajuster si vous utilisez d'autres broches. LegetTemp()La fonction (dans la vidéo à 07:03) est cruciale. Elle vous permet de récupérer différentes valeurs du capteur DHT22 en passant un argument de type chaîne :
float getTemp(String req) {
// ... (Sensor reading code) ...
if(req =="c"){ return t; } // Celsius
else if(req =="f"){ return f; } // Fahrenheit
// ... (Other options for Kelvin, humidity, heat index) ...
}
Cette fonction simplifie la lecture de différentes données provenant du capteur (Celsius, Fahrenheit, humidité, indice de chaleur). La boucle principale utilise cette fonction pour récupérer les données et les afficher sur l'afficheur 7 segments, en arrondissant les valeurs à virgule flottante en nombres entiers pour l'affichage (dans la vidéo à 07:14).
Projet/démonstration en direct
La vidéo (à 00:32) montre une démonstration en direct du projet. L'afficheur à 7 segments affiche clairement la température en degrés Fahrenheit. La vidéo montre également comment le code peut être modifié pour afficher des valeurs en Celsius, Kelvin, l'humidité et l'indice de chaleur (à 08:21).
Chapitres
- [00:06] Introduction et aperçu du projet
- [00:53] Prise en main et aperçu des composants
- [01:51] Câblage de l'afficheur TM1637
- [02:20] Câblage du capteur DHT22
- [03:14] Explication du code : configuration du TM1637
- [04:00] Explication du code : Configuration du DHT22
- [05:54] Explication du code : boucle principale et fonction d'affichage
- [07:03] Explication du code : la fonction getTemp()
- [08:21] Démonstration et différentes options de sortie
/*
* Original code from TM1637 https://github.com/avishorp/TM1637
* Original code and library for DHT22 https://github.com/adafruit/DHT-sensor-library
* Modified for Robojax video on January 7, 2018
* by Ahmad Shamshiri, in Ajax, Ontario, Canada
* Watch the video for this code https://youtu.be/z_FvRm6Te78
* Other Arduino library and videos https://robojax.com
* Get this code and other Arduino codes from Robojax.com
Learn Arduino step by step in a structured course with all material, wiring diagrams, and libraries
all in one place.
If you found this tutorial helpful, please support me so I can continue creating
content like this.
or make a donation using PayPal http://robojax.com/L/?id=64
* * This code is "AS IS" without warranty or liability. Free to be used as long as you keep this note intact.*
* This code has been downloaded from Robojax.com
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <https://www.gnu.org/licenses/>.
*/
// ****** Start of TM1637 Display code
#include <Arduino.h>
#include <TM1637Display.h>
// Module connection pins (Digital Pins)
#define CLK 2
#define DIO 3
// The amount of time (in milliseconds) between tests
#define TEST_DELAY 1000
TM1637Display display(CLK, DIO);
// ****** end of TM1637 Display code
// Example testing sketch for various DHT humidity/temperature sensors
// Written by ladyada, public domain
// ****** Start of DHT code
#include "DHT.h"
#define DHTPIN 9 // what digital pin we're connected to
// Uncomment whatever type you're using!
//#define DHTTYPE DHT11 // DHT 11
#define DHTTYPE DHT22 // DHT 22 (AM2302), AM2321
//#define DHTTYPE DHT21 // DHT 21 (AM2301)
DHT dht(DHTPIN, DHTTYPE);
// ********** end of DHT22 code
void setup()
{
Serial.begin(9600);
Serial.println("DHT22 Robojax Test with Display");
pinMode(8,OUTPUT);
digitalWrite(8,HIGH);// gives 5v for DHT22
dht.begin();
}
void loop()
{
delay(TEST_DELAY);// wait
// **** TM1637 code start
display.setBrightness(0x0f);// set brightness
uint8_t data[] = { 0x0, 0x0, 0x0, 0x0 };// clear display values
display.setSegments(data);//clear display
// **** TM1637 code end
// Robojax.com test video
Serial.println(getTemp("h"));
int temp = round(getTemp("h"));
display.showNumberDec(temp, false, 3,1);
}// loop end
/*
* getTemp(String req)
* returns the temperature related parameters
* req is string request
* This code can display temperature in:
* getTemp("c") is used to get Celsius
* getTemp("f") is used to get Fahrenheit
* getTemp("k") is used for Kelvin
* getTemp("hif") is used to get Fahrenheit
* getTemp("hic") is used to get Celsius
* getTemp("h") is used to get humidity
* written by Ahmad Shamshiri for Robojax.com on January 7, 2018
* in Ajax, Ontario, Canada
*/
float getTemp(String req)
{
// Reading temperature or humidity takes about 250 milliseconds!
// Sensor readings may also be up to 2 seconds 'old' (it's a very slow sensor)
float h = dht.readHumidity();
// Read temperature as Celsius (the default)
float t = dht.readTemperature();
// Read temperature as Fahrenheit (isFahrenheit = true)
float f = dht.readTemperature(true);
// Compute heat index in Fahrenheit (the default)
float hif = dht.computeHeatIndex(f, h);
// Compute heat index in Celsius (isFahreheit = false)
float hic = dht.computeHeatIndex(t, h, false);
// Check if any reads failed and exit early (to try again).
if (isnan(h) || isnan(t) || isnan(f)) {
Serial.println("Failed to read from DHT sensor!");
return 0.0; //return 0.0 instead of nothing.
}
// Compute heat index in Kelvin
float k = t + 273.15;
if(req =="c"){
return t;//return Celsius
}else if(req =="f"){
return f;// return Fahrenheit
}else if(req =="h"){
return h;// return humidity
}else if(req =="hif"){
return hif;// return heat index in Fahrenheit
}else if(req =="hic"){
return hic;// return heat index in Celsius
}else if(req =="k"){
return k;// return temperature in Kelvin
}else{
return 0.000;// if no request found, return 0.000
}
}
Ressources et références
Aucune ressource pour le moment.
Fichiers📁
Bibliothèques Arduino (zip)
-
Module PCB DHT22 rouge
DHT22-module-red.fzpz0.01 MB
Fichier Fritzing
-
Capteur d'humidité et de température DHT22
DHT22 Humidity and Temperature Sensor.fzpz0.01 MB -
Module PCB DHT22 rouge
DHT22-module-red.fzpz0.01 MB -
Module DHT22 blanc
DHT22-module-white.fzpz0.01 MB -
Module à sept segments TM1637
TM1637.fzpz0.01 MB -
Capteur d'humidité et de température DHT11 (3 broches)
DHT11 Humitidy and Temperature Sensor (3 pins).fzpz0.20 MB
Manuel de l'Utilisateur
-
Manuel de l'utilisateur du capteur de température et d'humidité DHT22
robojax-DHT22_manual.pdf0.36 MB