Índice:

Medição de temperatura usando a plataforma Esp32 e Thingsio.ai: 6 etapas
Medição de temperatura usando a plataforma Esp32 e Thingsio.ai: 6 etapas

Vídeo: Medição de temperatura usando a plataforma Esp32 e Thingsio.ai: 6 etapas

Vídeo: Medição de temperatura usando a plataforma Esp32 e Thingsio.ai: 6 etapas
Vídeo: Automação com ESP32: Como Ler Temperatura e Umidade Com Seu Celular (Passo a Passo) 2024, Julho
Anonim
Medição de temperatura usando a plataforma Esp32 e Thingsio.ai
Medição de temperatura usando a plataforma Esp32 e Thingsio.ai

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:

COMPONENTES
COMPONENTES

Hardware:

Placa de desenvolvimento 1.esp32

Programas:

1. Arduino IDE

2. Thingsio.ai

Etapa 2: REPRESENTAÇÃO DO DIAGRAMA DE BLOCO DE Esp32

DIAGRAMA DE BLOCO REPRESENTAÇÃO DE Esp32
DIAGRAMA DE BLOCO REPRESENTAÇÃO 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:

SAÍDA
SAÍDA

Aqui está a saída dos valores de temperatura lidos do sensor.

Etapa 5: GRÁFICOS:

GRÁFICOS
GRÁFICOS
GRÁFICOS
GRÁFICOS

A representação gráfica dos valores lidos do sensor de temperatura a bordo.

Recomendado: