DHT22 Temperatura e Umidade em um display de 7 segmentos com Arduino RJT43
Este projeto demonstra como construir um sistema simples, porém eficaz, para exibir leituras de temperatura e umidade em um display de 7 segmentos usando um Arduino. Esta configuração é útil para várias aplicações em que o monitoramento das condições ambientais é crucial. O projeto combina o sensor de temperatura e umidade DHT22 com um display de 7 segmentos TM1637, fornecendo uma saída clara e de fácil leitura.


Ideias de Projeto:
- Monitoramento de um ambiente doméstico para conforto ideal.
- Monitoramento das condições em uma estufa ou terrário.
- Construindo uma estação meteorológica básica.
- Exibindo temperatura e umidade em um projeto de registro de dados.
Hardware/Componentes
Para construir este projeto, você precisará dos seguintes componentes:
- Arduino Uno (ou placa compatível)
- Sensor de Temperatura e Umidade DHT22
- Display de 7 segmentos TM1637
- Fios de conexão
- Protoboard (opcional, mas recomendada)
Guia de Fiação



A fiação é simples. Consulte o vídeo (em 01:51) para um guia visual. As conexões principais são:
- Visor TM1637:VCC para 5V, GND para GND, CLK para o pino 2 do Arduino, DIO para o pino 3 do Arduino (no vídeo em 02:00).
- Sensor DHT22:VCC para 5V, GND para GND, DATA para o pino 9 do Arduino (no vídeo em 02:20). Observe que o vídeo usa o pino 8 do Arduino para fornecer 5V ao sensor (no vídeo em 02:41).
%%FIAÇÃO%%
Explicação do código
O código Arduino utiliza duas bibliotecas: TM1637Display para o display de 7 segmentos e DHT para o sensor DHT22. Os parâmetros configuráveis do código estão principalmente localizados no início:
// Module connection pins (Digital Pins)
#define CLK 2
#define DIO 3
#define DHTPIN 9 // DHT22 data pin
#define DHTTYPE DHT22 // DHT sensor type
Estas linhas definem os pinos do Arduino conectados ao display e ao sensor DHT22. Pode ser necessário ajustá-los se você usar pinos diferentes. OgetTemp()A função (no vídeo em 07:03) é crucial. Ela permite que você recupere diferentes valores do sensor DHT22 passando uma string como argumento:
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) ...
}
Esta função simplifica a leitura de diferentes dados do sensor (Celsius, Fahrenheit, umidade, índice de calor). O loop principal usa esta função para obter os dados e exibí-los no display de 7 segmentos, arredondando valores de ponto flutuante para inteiros para fins de exibição (no vídeo em 07:14).
Projeto/Demonstração ao vivo
O vídeo (no vídeo aos 00:32) mostra uma demonstração ao vivo do projeto. O display de 7 segmentos mostra claramente a temperatura em Fahrenheit. O vídeo também demonstra como o código pode ser modificado para exibir valores em Celsius, Kelvin, umidade e índice de calor (no vídeo aos 08:21).
Capítulos
- [00:06] Introdução e Visão Geral do Projeto
- [00:53] Primeiros passos e visão geral dos componentes
- [01:51] Fiação do Display TM1637
- [02:20] Fiação do sensor DHT22
- [03:14] Explicação do código: Configuração do TM1637
- [04:00] Explicação do Código: Configuração do DHT22
- [05:54] Explicação do Código: Loop Principal e Função de Exibição
- [07:03] Explicação do código: função getTemp()
- [08:21] Demonstração e Diferentes Opções de Saída
/*
* 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
}
}
Recursos e referências
Ainda não há recursos.
Arquivos📁
Bibliotecas do Arduino (zip)
-
Módulo PCB DHT22 vermelho
DHT22-module-red.fzpz0.01 MB
Arquivo Fritzing
-
Sensor de Umidade e Temperatura DHT22
DHT22 Humidity and Temperature Sensor.fzpz0.01 MB -
Módulo PCB DHT22 vermelho
DHT22-module-red.fzpz0.01 MB -
Módulo DHT22 branco
DHT22-module-white.fzpz0.01 MB -
Módulo de sete segmentos TM1637
TM1637.fzpz0.01 MB -
Sensor de Umidade e Temperatura DHT11 (3 pinos)
DHT11 Humitidy and Temperature Sensor (3 pins).fzpz0.20 MB
Manual do Usuário
-
Manual do usuário do sensor de temperatura e umidade DHT22
robojax-DHT22_manual.pdf0.36 MB