Оглавление:
- Шаг 1: Компоненты
- Шаг 2: ПОДКЛЮЧЕНИЯ
- Шаг 3: КОДИРОВКА
- Шаг 4: ВЫВОД
- Шаг 5: График
- Шаг 6: Вот видео с объяснением Breif
Видео: Детектор движения с использованием облачной платформы Thingsai.io Iot: 6 шагов
2024 Автор: John Day | [email protected]. Последнее изменение: 2024-01-30 11:51
В этом руководстве я расскажу об обнаружении движения с помощью датчика 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: График
Это графическое представление значений датчика. Из приведенного выше графика мы можем проанализировать применение датчика. Спасибо
Рекомендуемые:
Система автоматического железнодорожного переезда с использованием встроенной платформы на базе Arduino: 9 шагов
Автоматическая система железнодорожных переездов с использованием встроенной платформы на базе Arduino: до Рождества всего неделя! Все заняты празднованием и получением подарков, которые, кстати, становится все труднее получить из-за бесконечных возможностей вокруг нас. Как насчет классического подарка и добавления нотки рукоделия к
Умная аркадная игра в баскетбол с подсчетом очков с использованием встроенной платформы Evive - Arduino: 13 шагов
Умная аркадная игра «Баскетбол» с подсчетом очков с использованием встроенной платформы Evive - Arduino: из всех существующих игр самыми интересными являются аркады. Итак, мы подумали, а почему бы не сделать его самим дома! И вот мы - самая увлекательная игра, в которую вы когда-либо играли, сделанную своими руками, - аркадную баскетбольную игру DIY! Мало того
Детектор движения с использованием NodeMCU: 5 шагов
Детектор движения с использованием NodeMCU: в этом проекте, просто используя датчик движения, вы можете обнаружить присутствие любого человека или животного. А с помощью платформы под названием thingsio вы можете отслеживать дату и время, когда было обнаружено присутствие
Настольный пинбол-автомат с использованием встроенной платформы Evive - Arduino: 18 шагов (с изображениями)
Настольный пинбол-автомат с использованием встроенной платформы Evive - Arduino: еще один уик-энд, еще одна захватывающая игра! И на этот раз это не что иное, как всеми любимая аркада - пинбол! Этот проект покажет вам, как легко сделать свой собственный автомат для игры в пинбол в домашних условиях. Все, что вам нужно, это компоненты от Evive
Измерение температуры с использованием платформы Esp32 и Thingsio.ai: 6 шагов
Измерение температуры с использованием платформы Esp32 и Thingsio.ai: в этом руководстве я расскажу об измерении температуры в окружающей среде с помощью встроенного датчика температуры, присутствующего в плате разработки esp32. esp32 имеет множество встроенных датчиков, таких как датчик Холла, используемый в качестве датчика приближения, касания