Files
Blinds_XIAO/src/main.cpp

68 lines
1.5 KiB
C++
Raw Normal View History

2025-11-28 18:26:32 -06:00
#include <driver/gptimer.h>
#include "pwm.h"
#include "defines.h"
#include "nvs_flash.h"
#include "NimBLEDevice.h"
#include "WiFi.hpp"
#include "setup.hpp"
2025-12-23 17:21:44 -06:00
#include "socketIO.hpp"
#include "encoder.hpp"
2025-11-28 18:26:32 -06:00
void mainApp() {
2025-12-23 17:21:44 -06:00
printf("Hello ");
esp_err_t ret = nvs_flash_init(); // change to secure init logic soon!!
2025-11-28 18:26:32 -06:00
// 2. If NVS is full or corrupt (common after flashing new code), erase and retry
if (ret == ESP_ERR_NVS_NO_FREE_PAGES || ret == ESP_ERR_NVS_NEW_VERSION_FOUND) {
ESP_ERROR_CHECK(nvs_flash_erase());
ret = nvs_flash_init();
2025-11-28 18:26:32 -06:00
}
ESP_ERROR_CHECK(ret);
bmWiFi.init();
2025-12-28 15:31:20 -06:00
// Create and initialize encoder
Encoder encoder(ENCODER_PIN_A, ENCODER_PIN_B);
encoder.init();
2025-11-28 18:26:32 -06:00
setupLoop();
2025-12-23 17:21:44 -06:00
statusResolved = false;
// Main loop
2025-11-28 18:26:32 -06:00
while (1) {
if (statusResolved) {
if (!connected) {
printf("Disconnected! Beginning setup loop.\n");
stopSocketIO();
setupLoop();
}
else printf("Reconnected!\n");
statusResolved = false;
}
// Your main application logic here
2025-12-23 17:28:32 -06:00
vTaskDelay(pdMS_TO_TICKS(1000));
printf("loop\n");
2025-11-28 18:26:32 -06:00
}
}
void encoderTest() {
2025-12-28 15:31:20 -06:00
// Create encoder instance
Encoder encoder(ENCODER_PIN_A, ENCODER_PIN_B);
encoder.init();
2025-12-28 15:31:20 -06:00
int32_t prevCount = encoder.getCount();
while (1) {
2025-12-28 15:31:20 -06:00
int32_t currentCount = encoder.getCount();
if (currentCount != prevCount) {
prevCount = currentCount;
printf("Encoder Pos: %d\n", prevCount);
}
vTaskDelay(pdMS_TO_TICKS(100));
}
}
extern "C" void app_main() {
// mainApp();
encoderTest();
2025-11-28 18:26:32 -06:00
}