Оглавление:

Фоторамка OSD с функцией распознавания лиц: 11 шагов (с изображениями)
Фоторамка OSD с функцией распознавания лиц: 11 шагов (с изображениями)

Видео: Фоторамка OSD с функцией распознавания лиц: 11 шагов (с изображениями)

Видео: Фоторамка OSD с функцией распознавания лиц: 11 шагов (с изображениями)
Видео: ASECAM АНТИВАНДАЛЬНАЯ КАМЕРА 5-ЗУМ С ОПРЕДЕЛЕНИЕМ И СЛЕЖЕНИЕМ ЗА ЛЮДЬМИ 2024, Ноябрь
Anonim
Фоторамка OSD с функцией распознавания лиц
Фоторамка OSD с функцией распознавания лиц
Фоторамка OSD с функцией распознавания лиц
Фоторамка OSD с функцией распознавания лиц
Фоторамка OSD с функцией распознавания лиц
Фоторамка OSD с функцией распознавания лиц
Фоторамка OSD с функцией распознавания лиц
Фоторамка OSD с функцией распознавания лиц

В этом руководстве показано, как создать фоторамку с экранным меню (OSD) с функцией распознавания лиц.

Экранное меню может отображать время, погоду или другую информацию из Интернета, которую вы хотите.

Шаг 1. Почему фоторамка OSD?

Почему фоторамка OSD?
Почему фоторамка OSD?
Почему фоторамка OSD?
Почему фоторамка OSD?

Раньше у меня было 2 проекта фото-часов в Instructables:

www.instructables.com/id/ESP32-Photo-Clock…

www.instructables.com/id/Arduino-BiJin-ToK…

Оба получают фотографию с красотками и табло времени из Интернета каждую минуту и отображают на ЖК-дисплее.

Показывать красоток - это хорошо, но все они мне чужие. Как насчет использования личных любимых фотографий и добавления к ним текущего времени и дополнительной мгновенной информации?

Этот проект изучает, как это сделать.

Шаг 2. Почему Face Aware?

Почему Face Aware?
Почему Face Aware?
Почему Face Aware?
Почему Face Aware?
Почему Face Aware?
Почему Face Aware?
Почему Face Aware?
Почему Face Aware?

Давайте сначала проверим, как добавить экранное меню с мгновенной информацией к фотографии:

  1. Случайный выбор фотографии из определенной папки
  2. Получить время
  3. Получать мгновенную информацию из Интернета
  4. время прорисовки и мгновенная информация на фото

Шаг 1-3 прямолинейный; Шаг 4 тоже выглядит просто, но определить, где нарисовать текст, не так-то просто.

Если размер текста слишком мал, его будет трудно читать с разумного расстояния; Если размер текста слишком большой, он, скорее всего, закроет фотообъекты. Особенно, если это портретная фотография, текст, закрывающий лица, не является предпочтительным.

Поскольку положение лиц для каждой фотографии не одинаково, чтобы избежать скрытых лиц OSD, нам сначала нужен процесс обнаружения лиц. Затем мы можем найти область без лица для рисования текста.

Шаг 3: двухуровневый дизайн

2-х уровневый дизайн
2-х уровневый дизайн

Процесс обнаружения лица требует некоторой вычислительной мощности, фоторамка, напротив, может быть очень легкой. Поэтому я разделил его на 2 уровня:

Сервер

Фотодвижок с распознаванием лиц - это сервер приложений Node.js. Для каждого HTTP-запроса он будет:

  1. Выбрать фотографию из папки с фотографиями случайным образом
  2. Распознавание лиц
  3. определить область без лица или с наименьшим количеством лиц
  4. В то же время получайте информацию о погоде или другую полезную мгновенную информацию из Интернета каждый определенный период.
  5. Время рисования и мгновенная информация на фото
  6. Вернуть фотографию с экранным меню в формате JPEG в качестве ответа

Клиент

Клиент может быть веб-браузером, апплетом или устройством IoT.

Например. ESP32 dev boasrd с 2-4 дюймовым ЖК-дисплеем очень подходит для размещения на рабочем столе в качестве крошечной фоторамки.

Шаг 4. Настройте сервер фотографий. Вариант 1: образ Docker

Настройка сервера фотографий, вариант 1: образ Docker
Настройка сервера фотографий, вариант 1: образ Docker
Настройка сервера фотографий, вариант 1: образ Docker
Настройка сервера фотографий, вариант 1: образ Docker

Для удобства я предварительно создал образ Docker для сервера приложений OSD Node.js с распознаванием лиц.

Если вы еще не настроили Docker, следуйте руководству по началу работы с Docker:

www.docker.com/get-started

Затем выполните следующую команду: (замените / путь / к / фото на свой собственный путь к фотографии)

docker run -p 8080: 8080 -v / путь / к / фото: / приложение / фото moononournation / лицо-осведомленность-фото-osd: 1.0.1

Проверьте это, перейдя по адресу https:// localhost: 8080 /

Вы можете обнаружить, что время отображается не в вашем часовом поясе:

docker run -p 8080: 8080 -e TZ = Asia / Hong_Kong -v / path / to / photo: / app / photo moononournation / face-known-photo-osd: 1.0.1

Если вы, как и я, живете в Гонконге, вы можете добавить информацию о погоде в Гонконге:

docker run -p 8080: 8080 -e TZ = Asia / Hong_Kong -e OSD = HK_Weather -v / path / to / photo: / app / photo moononournation / face-known-photo-osd: 1.0.1

Если вы хотите разработать свою собственную информацию OSD:

mkdir -p ~ / git

cd ~ / git git clone https://github.com/moononournation/face-aware-photo-osd.git docker run -it -p 8080: 8080 -e TZ = Asia / Hong_Kong -e OSD = HK_Weather -e DEBUG = Y -v / путь / к / фото: / app / photo -v ~ / git / face-known-photo-osd / app.js: /app/app.js moononournation / face-known-photo-osd: 1.0. 1

Измените функцию update_osd () в app.js, чтобы настроить вашу собственную информацию OSD. После разработки просто удалите среду DEBUG = Y из команды docker.

Шаг 5. Настройте сервер фотографий. Вариант 2: сборка из исходного кода

Если вы знакомы с Node.js, вы можете создать сервер приложений из исходного кода.

Получите источник:

git clone

Установить пакеты:

компакт-диск с распознаванием лица-фото-OSD

npm install

Создайте папку с фотографиями и скопируйте в нее свои фотографии.

Запускаем сервер приложений:

узел app.js

Шаг 6. Клиентский вариант 1. Веб-браузер

Вариант клиента 1: веб-браузер
Вариант клиента 1: веб-браузер

Просто откройте https:// localhost: 8080 /

Страница скрипта автоматически загружает изображение подходящего размера страницы каждую минуту.

P. S. Если вы просматриваете страницы с другого компьютера, на котором не запущен сервер приложений, не забудьте изменить localhost на имя хоста или IP-адрес сервера приложений.

Шаг 7: Вариант клиента 2: ESP32 + LCD

Вариант клиента 2: ESP32 + LCD
Вариант клиента 2: ESP32 + LCD
Вариант клиента 2: ESP32 + LCD
Вариант клиента 2: ESP32 + LCD
Вариант клиента 2: ESP32 + LCD
Вариант клиента 2: ESP32 + LCD
Вариант клиента 2: ESP32 + LCD
Вариант клиента 2: ESP32 + LCD

Клиент фоторамки может быть таким же простым, как плата разработчика ESP32 и ЖК-дисплей.

Вот необходимое оборудование:

Совет разработчиков ESP32

Любая плата разработчика ESP32 должна быть в порядке, на этот раз я использую плату под названием MH-ET LIVE.

ЖК дисплей

Любой ЖК-дисплей с поддержкой Arduino_GFX, вы можете найти поддерживаемый в настоящее время дисплей в файле readme на GitHub:

github.com/moononournation/Arduino_GFX

Перемычка

Некоторые перемычки зависят от платы разработчика и расположения выводов ЖК-дисплея. В большинстве случаев достаточно 6-9 перемычек между гнездом и гнездом.

ЖК-подставка

Некоторая поддержка помогает ЖК-дисплею стоять прямо, на этот раз я использую подставку для карт.

Шаг 8: сборка ЖК-дисплея ESP32 +

ESP32 + ЖК-дисплей
ESP32 + ЖК-дисплей
ESP32 + ЖК-дисплей
ESP32 + ЖК-дисплей
ESP32 + ЖК-дисплей
ESP32 + ЖК-дисплей

ESP32 с контактным разъемом на верхней стороне является предпочтительным. Если штифт на нижней стороне, просто переверните доску;>

Соедините ESP32 и ЖК-дисплей с помощью перемычек, затем установите его на подставку.

Вот пример сводки по подключению:

ESP32 -> ЖК-дисплей

Vcc -> Vcc GND -> GND GPIO 5 -> CS GPIO 27 -> DC (если есть) GPIO 33 -> RST GPIO 18 -> SCK GPIO 19 -> MISO (опционально) GPIO 22 -> LED (если есть) GPIO 23 -> MOSI / SDA

Шаг 9: программное обеспечение ESP32 + LCD

Программное обеспечение ESP32 + LCD
Программное обеспечение ESP32 + LCD

IDE Arduino

Загрузите и установите Arduino IDE, если вы еще этого не сделали:

www.arduino.cc/en/main/software

Поддержка ESP32

Следуйте инструкциям по установке, чтобы добавить поддержку ESP32, если вы еще этого не сделали:

github.com/espressif/arduino-esp32

Библиотека Arduino_GFX

Загрузите последние библиотеки Arduino_GFX: (нажмите «Клонировать или загрузить» -> «Загрузить ZIP»)

github.com/moononournation/Arduino_GFX

Импортируйте библиотеки в Arduino IDE. (Меню «Скетч» в Arduino IDE -> «Включить библиотеку» -> «Добавить библиотеку. ZIP» -> выбрать загруженный ZIP-файл)

Скомпилировать и загрузить

  1. Откройте Arduino IDE
  2. Откройте образец кода ESP32PhotoFrame («Файл» -> «Пример» -> «Библиотека GFX для Arduino» -> «WiFiPhotoFrame»).
  3. Заполните настройки точки доступа WiFi в SSID_NAME и SSID_PASSWORD
  4. Замените имя хоста или IP-адрес вашего сервера и порт в HTTP_HOST и
  5. Нажмите кнопку "Загрузить" в Arduino IDE.
  6. Если вы обнаружите, что ориентация неправильная, измените значение «поворота» (0–3) в новом коде класса.

Шаг 10: Наслаждайтесь фото

Наслаждайтесь фото!
Наслаждайтесь фото!

Пришло время поставить фоторамку IoT на рабочий стол и наслаждаться!

Шаг 11: Что дальше?

  • Добавьте свою собственную мгновенную информацию
  • Точная настройка размера исходной фотографии для повышения точности распознавания лиц
  • Автоматическая задача поместить последние фотографии в папку с фотографиями на сервере
  • Сделайте больше фотографий;>

Рекомендуемые: