//Teste de interfaceamento entre Wokwi e Blynk: digital

//Após configuração de template no BLynk, copiar o código dado e colar abaixo
#define BLYNK_TEMPLATE_ID "TMPL2aoRBo23G"
#define BLYNK_TEMPLATE_NAME "Automação residencial"
#define BLYNK_AUTH_TOKEN "4yozsOJi5CQxY_DlUoYFKJTud0D-k4Dp"

//Redireciona os prints da serial com informações do Blynk
//Após montar o projeto, transformar em comentário para economizar memória
#define BLYNK_PRINT Serial

//Libera o uso de WiFi. Permite a definição de usuário específico. Biblioteca de comunicação com Blynk.
#include <WiFi.h>
#include <WiFiClient.h>
#include <BlynkSimpleEsp32.h>
#include <DHT.h>

//Autentica a conexão direcionando para o login do Blynk
char auth[] = BLYNK_AUTH_TOKEN;

//Credenciais de conexão para rede WiFi. SSID = nome da rede, Pass = senha da rede
//Senha nomeada como "" para redes abertas.
char ssid[] = "Wokwi-GUEST";
char pass[] = "";

DHT dht(14, DHT22);

//Tempo do timer definido pelo Blynk para o delay do loop. NÃO UTILIZAR A FUNÇÃO DELAY NO LOOP.
BlynkTimer timer;

//Definição dos pinos ligados aos botões
#define button1_pin 26

//Definição dos pinos ligados aos relés
#define relay1_pin 13

//Variáveis que marca o estado do relé, incializada em 0
int relay1_state = 0;

//Definição dos pinos virtuais, atrelados as variáveis do Blynk
#define button1_vpin     V1

//Define o LED do Blynk como variável V5
WidgetLED led1(V2);

//Esta função é chamada cada vez que o dispositivo é conectado ao Blynk.Cloud
//Atualiza com o último estado armazenado no servidor
BLYNK_CONNECTED() {
  Blynk.syncVirtual(button1_vpin);
}

//Essa função é chamada toda vez que os pinos virtuais mudam
//Ou seja, ao apertar no app o botão, atualiza o circuito
BLYNK_WRITE(button1_vpin) { //Se alguém tiver mexido no botão virtual 1, roda o comando
  relay1_state = param.asInt(); //Estado do relé 1 será igualado ao valor do parâmetro lido, ou seja, botão V1
  digitalWrite(relay1_pin, relay1_state); //passa para o pino do relé 1 o valor do estado
}

//Configuração do sistema
void setup()
{
  Serial.begin(115200);

  //Botões de entrada configurado como PULL UP
  pinMode(button1_pin, INPUT_PULLUP);
 
 //Configurando os relés como saída
  pinMode(relay1_pin, OUTPUT);

  /*Teste de relés, dura o tempo da inicialização
  digitalWrite(relay1_pin, HIGH);
  */

  dht.begin();
  delay(2000);

  Blynk.begin(auth, ssid, pass); //Inicializa e loga no blynk
  // You can also specify server:
  //Blynk.begin(auth, ssid, pass, "blynk.cloud", 80);
  //Blynk.begin(auth, ssid, pass, IPAddress(192,168,1,100), 8080);
  //--------------------------------------------------------------------
  //Blynk.virtualWrite(button1_vpin, relay1_state);
  //--------------------------------------------------------------------
}

//Programa Principal
void loop()
{
  //Blynk.run é a principal rotina, responsável por manter a conexão e atualizar os dados
  //Atenção: não pode usar função delay com o Blynk.run()
  Blynk.run();
  timer.run();//Utiliza o temporizador definido pelo Blynk
  //A partir daqui, você pode colocar seu código ou subrotinas.
  
  ler_botoes();
  atualiza_ledv();
  lerdht();
}

//Rotina que lê os botões físicos
void ler_botoes(){
  if(digitalRead(button1_pin) == LOW){
    delay(200);
    control_relay(1);
    Blynk.virtualWrite(button1_vpin, relay1_state); //update button state
  }
}

//Rotina que atualiza os relés a partir dos botões físicos
void control_relay(int relay){
  if(relay == 1){
    relay1_state = !relay1_state;
    digitalWrite(relay1_pin, relay1_state);
    delay(50);
  }
}

void atualiza_ledv(){
  if(relay1_state==1) led1.on();
  else led1.off();
  Serial.print("\nRelay1 State = ");
  Serial.println(relay1_state);
}

void lerdht(){
  float temp = dht.readTemperature();
  float umid = dht.readHumidity();
  Serial.print("Temperatura: ");
  Serial.print(temp);
  Serial.print("\tUmidade: ");
  Serial.print(umid);
  Blynk.virtualWrite(V3, umid);
  Blynk.virtualWrite(V4, temp);
  delay(1000);
}
$abcdeabcde151015202530fghijfghij
esp:VIN
esp:GND.2
esp:D13
esp:D12
esp:D14
esp:D27
esp:D26
esp:D25
esp:D33
esp:D32
esp:D35
esp:D34
esp:VN
esp:VP
esp:EN
esp:3V3
esp:GND.1
esp:D15
esp:D2
esp:D4
esp:RX2
esp:TX2
esp:D5
esp:D18
esp:D19
esp:D21
esp:RX0
esp:TX0
esp:D22
esp:D23
NOCOMNCVCCGNDINLED1PWRRelay Module
relay1:VCC
relay1:GND
relay1:IN
relay1:NC
relay1:COM
relay1:NO
btn1:1.l
btn1:2.l
btn1:1.r
btn1:2.r
vcc1:VCC
led1:A
led1:C
vcc2:VCC
gnd1:GND
dht1:VCC
dht1:SDA
dht1:NC
dht1:GND
r1:1
r1:2