Оглавление:
Видео: Детектор движения с использованием облачной платформы Thingsai.io Iot: 6 шагов
2025 Автор: John Day | [email protected]. Последнее изменение: 2025-01-13 06:58
В этом руководстве я расскажу об обнаружении движения с помощью датчика PIR и Esp32 вместе с облачной платформой IOT Thingai.io.
Шаг 1: Компоненты
АППАРАТНЫЕ КОМПОНЕНТЫ;
1. Совет по развитию esp32
2. датчик PIR
3. Проволочные перемычки
ПРОГРАММНОЕ ОБЕСПЕЧЕНИЕ:
1. Arduino IDE
2. Аккаунт Thingsai.io
Шаг 2: ПОДКЛЮЧЕНИЯ
Подключения довольно простые.
PIR PINS ------------ ESP32 PINS
VCC ------------------- 3V3 на esp32
GND ------------------ GND на esp32
ВЫХОД ------------------- D22 на esp32
Шаг 3: КОДИРОВКА
Вставьте этот код в свою Arduino IDE с некоторыми обновлениями, ваш датчик движения выдаст результат безупречно.
#включают
#включают
#включают
int count = 0, я, м, j, k;
int t, t1, t2, t3;
int pin = 22;
////////////////////////////////////// ВСЕ ЗАЯВЛЕНИЯ для ОБЛАКА ////// ////////////////////////
const char * host = "api.thingsai.io"; // ИЛИ host = devapi2.thethingscloud.com
const char * post_url = "/ devices / deviceData"; // ИЛИ / api / v2 / thingscloud2 / _table / data_ac
const char * time_server = "baas.thethingscloud.com"; // это для преобразования метки времени
const int httpPort = 80;
const int httpsPort = 443;
const char * server = "api.thingsai.io"; // URL сервера
временная метка [10];
WiFiMulti WiFiMulti;
// Используйте класс WiFiClient для создания TCP-соединений
Клиент WiFiClient;
/////////////////////////////////////// Функция РАСЧЕТ ВРЕМЕННОЙ АППАРАТУРЫ //////// ///////////////////////////////
int GiveMeTimestamp ()
{
беззнаковый длинный таймаут = millis ();
// Клиент WiFiClient;
пока (client.available () == 0)
{
если (millis () - таймаут> 50000)
{
client.stop ();
возврат 0;
}
}
пока (client.available ())
{
Строка line = client.readStringUntil ('\ r'); // indexOf () - функция для поиска чего-либо, возвращает -1, если не найдено
int pos = line.indexOf ("\" отметка времени / ""); // ищем "\" отметку времени / "" от начала полученного ответа и копируем все данные после этого, это будет ваша отметка времени
если (pos> = 0)
{
int j = 0;
для (j = 0; j <10; j ++)
{
отметка времени [j] = строка [pos + 12 + j];
}
}
}
}
////////////////////////////////////////////////////////////////////////////////////////////////////////
установка void ()
{
Serial.begin (115200);
задержка (10);
pinMode (контакт, ВХОД);
// Начнем с подключения к сети Wi-Fi
WiFiMulti.addAP ("wifi_name", "Wifi_password");
Serial.println ();
Serial.println ();
Serial.print («Ждите WiFi…»);
while (WiFiMulti.run ()! = WL_CONNECTED) {
Serial.print (".");
задержка (500);
}
Serial.println ("");
Serial.println («WiFi подключен»);
Serial.println ("IP-адрес:");
Serial.println (WiFi.localIP ());
задержка (500);
}
пустой цикл ()
{
int analogValue = analogRead (вывод);
{
/////////////////////////////////////// ОТПРАВИТЬ ЗАПРОС И ПОЛУЧИТЕ ОТВЕТ //// ///////////////////
{
bool isDetected = digitalRead (контакт);
if (isDetected) {
Serial.println («Обнаружено присутствие»);
}
задержка (500);
}
Serial.print («подключение к»);
Serial.println (хост); // определенный потенциал роста: - host = devapi2.thethingscloud.com или 139.59.26.117
///////////////////////////////////// КОД TIMESTAMP КОД ИНФОРМАЦИЯ ////////// ///////////////
Serial.println ("получить метку времени / n");
если (! client.connect (сервер_времени, {
возвращение; // * - * - * - * - * - * - * - * - * - *
}
client.println ("GET / api / timestamp HTTP / 1.1"); // Что делает эта часть, я не понял
client.println ("Хост: baas.thethingscloud.com");
client.println ("Контроль кеширования: без кеширования");
client.println ("Почтальон-токен: ea3c18c6-09ba-d049-ccf3-369a22a284b8");
client.println ();
GiveMeTimestamp (); // он вызовет функцию, которая получит ответ с отметкой времени от сервера
Serial.println ("временная метка получена");
Serial.println (отметка времени);
Serial.println («внутри ThingsCloudPost»);
Строка PostValue = "{" device_id / ": 61121695839, \" slave_id / ": 2";
PostValue = PostValue + ", \" dts / ":" + отметка времени;
PostValue = PostValue + ", \" данные / ": {" PIR / ":" + pin + "}" + "}";
Serial.println (PostValue);
/ * создаем экземпляр WiFiClientSecure * /
Клиент WiFiClientSecure;
Serial.println («Подключиться к серверу через порт 443»);
if (! client.connect (сервер, 443)) {
Serial.println («Ошибка подключения!»);
} еще {
Serial.println («Подключено к серверу!»);
/ * создаем HTTP-запрос * /
client.println ("POST / devices / deviceData HTTP / 1.1");
client.println ("Хост: api.thingsai.io");
//client.println("Connection: close ");
client.println ("Content-Type: application / json");
client.println ("управление кешем: без кеша");
client.println ("Авторизация: предъявитель eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9. IjVhMzBkZDFkN2QwYjNhNGQzODkwYzQ4OSI.kaY6OMj5cYlWNq6SajPNT)"
client.print ("Длина содержимого:");
client.println (PostValue.length ());
client.println ();
client.println (PostValue);
////////////////////////////////// Публикация данных в облако завершена, и теперь мы получаем облако формы ответа. сервер //////////////////
Serial.print («Жду ответа»);
while (! client.available ()) {
задержка (50); //
Serial.print (".");
}
/ * если данные доступны, то получить и распечатать в Терминал * /
while (client.available ()) {
char c = client.read ();
Serial.write (c);
}
/ * если сервер отключился, останавливаем клиента * /
if (! client.connected ()) {
Serial.println ();
Serial.println («Сервер отключен»); javascript:;
client.stop ();
}
}
Serial.println ("////////////////////// КОНЕЦ ///////////////////// ");
задержка (3000);
}
}
Шаг 4: ВЫВОД
Это гистограмма значений, считываемых с датчика в облачной платформе thingsai, io,
Шаг 5: График
Это графическое представление значений датчика. Из приведенного выше графика мы можем проанализировать применение датчика. Спасибо