#include <SPI.h>
#include <SD.h>

#define SD_CS_PIN 5
#define BUTTON_PIN 2
#define LED_PIN 12

bool sdInitialized = false;
bool buttonPressed = false;
unsigned long startTime = 0;
unsigned long elapsedTime = 0;

void setup() {
  pinMode(BUTTON_PIN, INPUT_PULLUP); // Configura o pino do botão como entrada com pull-up interno
  pinMode(LED_PIN, OUTPUT);
  digitalWrite(LED_PIN, LOW); // Inicia o LED desligado
  Serial.begin(115200);

  // Inicializa o cartão SD
  if (SD.begin(SD_CS_PIN)) {
    Serial.println("Cartão SD inicializado com sucesso.");
    sdInitialized = true;
  } else {
    Serial.println("Falha ao inicializar o cartão SD.");
    sdInitialized = false;
  }
}

void loop() {
  File dataFile = SD.open("data.txt", FILE_WRITE);
  if (digitalRead(BUTTON_PIN) == LOW) {
    if (!buttonPressed) {
      buttonPressed = true;
      startTime = micros();
      digitalWrite(LED_PIN, HIGH);
    }
  } else {
    if (buttonPressed && sdInitialized) {
      elapsedTime = micros() - startTime;
      Serial.print("Time: ");
      Serial.println(elapsedTime);
      dataFile.print("Tempo decorrido: ");
      dataFile.println(elapsedTime);
      dataFile.println("Dados gravados...");
      if (elapsedTime >= 1000000) {
        buttonPressed = false;
        digitalWrite(LED_PIN, LOW);
        dataFile.close();
      }
    }
  }
}
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
sd1:CD
sd1:DO
sd1:GND
sd1:SCK
sd1:VCC
sd1:DI
sd1:CS
led1:A
led1:C
r1:1
r1:2
btn1:1.l
btn1:2.l
btn1:1.r
btn1:2.r