Índice:
2025 Autor: John Day | [email protected]. Última modificação: 2025-01-13 06:58
Neste tutorial, irei explicar sobre como medir a temperatura nas redondezas usando o sensor de temperatura embutido presente na placa de desenvolvimento esp32. O esp32 tem muitos sensores embutidos, como o sensor hall usado como sensor de proximidade, sensor de toque e sensor de temperatura. Neste tutorial vamos discutir sobre o sensor de temperatura.
Etapa 1: COMPONENTES:
Hardware:
Placa de desenvolvimento 1.esp32
Programas:
1. Arduino IDE
2. Thingsio.ai
Etapa 2: REPRESENTAÇÃO DO DIAGRAMA DE BLOCO DE Esp32
Etapa 3: CODIFICAÇÃO:
#incluir
#incluir
#incluir
#incluir
#incluir
#ifdef _cplusplus
extern "C" {
#fim se
uint8_t temprature_sens_read ();
// uint8_t g_phyFuns;
#ifdef _cplusplus
}
#fim se
contagem interna = 0, i, m, j, k;
int t, t1, t2, t3;
int outputpin = A0; // ds18b20
////////////////////////////////////////////// TODAS AS DECLARAÇÕES
para CLOUD ////////////////////////////////
const char * host = "api.thingsai.io"; // OR host =
devapi2.thethingscloud.com
const char * post_url = "/ devices / deviceData"; //
OU / api / v2 / thingscloud2 / _table / data_ac
const char * time_server =
"baas.thethingscloud.com"; // isso é para converter o carimbo de data / hora
const int httpPort = 80;
const int httpsPort = 443;
const char * server =
"api.thingsai.io"; // URL do servidor
carimbo de data / hora char [10];
WiFiMulti WiFiMulti;
// Use a classe WiFiClient para criar conexões TCP
Cliente WiFiClient;
///////////////////////////////////////////// TIMESTAMP
CÁLCULO função /////////////////////////////////////////
int GiveMeTimestamp ()
{
longo sem sinal
tempo limite = milis ();
// cliente WiFiClient;
enquanto
(cliente.disponível () == 0)
{
if (milis () -
tempo limite> 50000)
{
client.stop ();
return 0;
}
}
enquanto (cliente.disponível ())
{
String line =
client.readStringUntil ('\ r'); // indexOf () é uma função para pesquisar smthng, ele retorna -1 se não for encontrado
int pos =
line.indexOf ("\" timestamp / ""); // procure por "\" carimbo de data / hora / "" do início da resposta obtida e copie todos os dados depois disso, será seu carimbo de data / hora
if (pos> =
0)
{
int j = 0;para (j = 0; j <10; j ++)
{carimbo de data / hora [j] = linha [pos + 12 + j];
}
}
}
}
////////////////////////////////////////////////////////////////////////////////////////////////////////
void setup ()
{Serial.begin (115200);
atraso (10);
tzset ();
// Começamos por
conectando-se a uma rede WiFiWiFiMulti.addAP ("dlink_DWR-113", "madhukar66");
Serial.println ();
Serial.println ();Serial.print ("Aguarde WiFi…");while (WiFiMulti.run ()! = WL_CONNECTED) {Serial.print (".");
atraso (500);
}Serial.println ("");Serial.println ("WiFi conectado");Serial.println ("endereço IP:");Serial.println (WiFi.localIP ());
atraso (500);
}
uint8_t temp_farenheit;
float temp_celsius;
char strftime_buf [64];
time_t now = 0;
struct tm timeinfo;
char buf [256];
void loop ()
{
// int analogValue =
analogRead (outputpin);
{
/////////////////////////////////////////// ENVIE A CONSULTA E
RECEBA A RESPOSTA /////////////////////////
//
t1 = (analogValue / 1024,0) * 5000;
//
Serial.print ("temp:");
// Serial.println (t1);
/
/ t2 = (t1 / 10);
//
Serial.print ("celc:");
//
Serial.println (t2);
/
/ t3 = ((t2 *
9)/5 + 32);
//
Serial.print ("fhrn:");
//
Serial.println (t3); //pausa;localtime_r (& now, & timeinfo);strftime (strftime_buf, sizeof (strftime_buf), "% c", & timeinfo);sprintf (buf, "início da varredura% 02d:% 02d:% 02d", timeinfo.tm_hour, timeinfo.tm_min, timeinfo.tm_sec);
Serial.print
(buf);
temp_farenheit =
temprature_sens_read ();
temp_celsius = (temp_farenheit - 32) / 1.8;Serial.print ("Temp onBoard");Serial.print (temp_farenheit);Serial.print ("° F");Serial.print (temp_celsius);Serial.println ("° C");
atraso (1000);
agora ++;
Serial.print ( conectando
para );Serial.println (host); // upside definido: - host = devapi2.thethingscloud.com ou 139.59.26.117
///////////////////////////////////////// TIMESTAMP CODE SNIPPET
/////////////////////////
Serial.println ("dentro de obter carimbo de data / hora / n");
E se
(! client.connect (time_server, {
Retorna;
//*-*-*-*-*-*-*-*-*-*
}client.println ("GET / api / timestamp HTTP / 1.1"); // O que esta parte está fazendo, eu não entendiclient.println ("Host: baas.thethingscloud.com");client.println ("Cache-Control: no-cache");client.println ("Postman-Token: ea3c18c6-09ba-d049-ccf3-369a22a284b8");
client.println ();
GiveMeTimestamp (); // vai chamar o
função que obterá a resposta do carimbo de data / hora do servidor
Serial.println ("timestamp recebido");
Serial.println (carimbo de data / hora);Serial.println ("dentro de ThingsCloudPost");
String PostValue =
"{" device_id / ": 61121695920, \" slave_id / ": 2";
PostValue =
PostValue + ", \" dts / ":" + carimbo de data / hora;
PostValue =
PostValue + ", \" data / ": {" TEMP / ":" + temp_farenheit + "}" + "}";Serial.println (PostValue);
/ * cria uma instância de WiFiClientSecure * /
Cliente WiFiClientSecure;Serial.println ("Conectar ao servidor pela porta 443");
E se
(! client.connect (server, 443)) {Serial.println ("Falha na conexão!");
} outro {Serial.println ("Conectado ao servidor!");
/ * criar
solicitar */client.println ("POST / devices / deviceData HTTP / 1.1");client.println ("Host: api.thingsai.io");//client.println("Connection: close ");client.println ("Content-Type: application / json");client.println ("cache-control: no-cache");client.println ("Autorização: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9. IjVhMzBkZDFkN2QwYjNhNGQzODkwYzQ4OSI.kaYW6OMj5cYlWNqC2Ptd);client.print ("Content-Length:");client.println (PostValue.length ());client.println ();client.println (PostValue);
////////////////////////////////////// POSTANDO os dados no
a nuvem está pronta e agora obtenha o formulário de resposta cloud server //////////////////
Serial.print ( Aguardando
para resposta );
enquanto
(! client.available ()) {
atraso (50);
//Serial.print (".");
}
/ * se os dados forem
disponível, em seguida, receba e imprima no Terminal * /
enquanto
(cliente.disponível ()) {
char c =
client.read ();Serial.write (c);
}
/ * se o
servidor desconectado, pare o cliente * /
E se
(! client.connected ()) {Serial.println ();Serial.println ("Servidor desconectado");
client.stop ();
}
}
Serial.println ( ////////////////////// FIM
///////////////////// );
atraso (3000);
}
}
Etapa 4: SAÍDA:
Aqui está a saída dos valores de temperatura lidos do sensor.
Etapa 5: GRÁFICOS:
A representação gráfica dos valores lidos do sensor de temperatura a bordo.