Marco de fotos OSD con reconocimiento facial: 11 pasos (con imágenes)
Marco de fotos OSD con reconocimiento facial: 11 pasos (con imágenes)
Anonim
Marco de fotos OSD con reconocimiento facial
Marco de fotos OSD con reconocimiento facial
Marco de fotos OSD con reconocimiento facial
Marco de fotos OSD con reconocimiento facial
Marco de fotos OSD con reconocimiento facial
Marco de fotos OSD con reconocimiento facial
Marco de fotos OSD con reconocimiento facial
Marco de fotos OSD con reconocimiento facial

Este Instructables muestra cómo hacer un marco de fotos con visualización en pantalla (OSD) sensible a la cara.

El OSD puede mostrar la hora, el clima u otra información de Internet que desee.

Paso 1: ¿Por qué marco de fotos OSD?

¿Por qué marco de fotos OSD?
¿Por qué marco de fotos OSD?
¿Por qué marco de fotos OSD?
¿Por qué marco de fotos OSD?

Tengo 2 proyectos de reloj de fotos en Instructables antes:

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

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

Ambos recuperan una foto con bellezas y un tablero de tiempo de Internet cada minuto y se muestran en la pantalla LCD.

Mostrar bellezas es bueno, pero todas son extrañas para mí. ¿Qué tal usar fotos favoritas personales y agregar la hora actual y más información instantánea?

Este proyecto está explorando cómo hacerlo.

Paso 2: ¿Por qué Face Aware?

¿Por qué Face Aware?
¿Por qué Face Aware?
¿Por qué Face Aware?
¿Por qué Face Aware?
¿Por qué Face Aware?
¿Por qué Face Aware?
¿Por qué Face Aware?
¿Por qué Face Aware?

Primero veamos cómo agregar OSD de información instantánea a una foto:

  1. Seleccionar al azar una foto de una carpeta específica
  2. Recuperar tiempo
  3. Recupere información instantánea de Internet
  4. Dibujar tiempo e información instantánea en la foto.

El paso 1-3 es sencillo; El paso 4 también parece simple, pero determinar dónde dibujar el texto no es tan fácil.

Si el tamaño del texto es demasiado pequeño, es difícil leerlo a una distancia razonable; Si el tamaño del texto es demasiado grande, lo más probable es que cubra los objetos de la foto. Especialmente si se trata de una foto de retrato, no se prefiere el texto que cubra las caras.

Dado que la posición de los rostros para cada foto no es la misma, para evitar los rostros cubiertos por OSD, primero necesitamos un proceso de detección de rostros. Entonces podemos encontrar un área sin rostro para dibujar el texto.

Paso 3: Diseño de 2 niveles

Diseño de 2 niveles
Diseño de 2 niveles

El proceso de detección de rostros requiere algo de potencia de procesamiento, por el contrario, el marco de fotos puede ser muy liviano. Así que lo dividí en 2 niveles:

Servidor

El motor de fotos con reconocimiento facial es un servidor de aplicaciones Node.js. Para cada solicitud HTTP, hará lo siguiente:

  1. Seleccione una foto de la carpeta de fotos al azar
  2. Detección de rostro
  3. determinar el área sin rostro o con el mínimo de caras
  4. Mientras tanto, recupere información meteorológica u otra información instantánea útil de Internet cada cierto período.
  5. Dibuja tiempo e información instantánea en la foto.
  6. Devuelve la foto con OSD en formato JPEG como respuesta

Cliente

El cliente puede ser un navegador web, un applet o un dispositivo IoT.

P.ej. un desarrollador ESP32 con una pantalla LCD de 2-4 pulgadas es muy adecuado para colocarlo en el escritorio como un pequeño marco de fotos.

Paso 4: Configurar el servidor de fotos Opción 1: Imagen de Docker

Configuración del servidor de fotografías, opción 1: imagen de Docker
Configuración del servidor de fotografías, opción 1: imagen de Docker
Configuración del servidor de fotografías, opción 1: imagen de Docker
Configuración del servidor de fotografías, opción 1: imagen de Docker

Para mayor comodidad, he compilado previamente una imagen de Docker para el servidor de aplicaciones Node.js OSD de fotos con reconocimiento facial.

En caso de que aún no haya configurado Docker, siga la guía de introducción de Docker:

www.docker.com/get-started

Luego ejecute el siguiente comando: (reemplace / ruta / a / foto por su propia ruta de fotos)

docker run -p 8080: 8080 -v / ruta / a / foto: / app / photo moononournation / face-awareness-photo-osd: 1.0.1

Pruébelo navegando a https:// localhost: 8080 /

Puede encontrar que la hora de visualización no está en su zona horaria:

docker run -p 8080: 8080 -e TZ = Asia / Hong_Kong -v / ruta / a / foto: / app / photo moononournation / face-awareness-photo-osd: 1.0.1

Si vive en Hong Kong como yo, puede agregar información meteorológica de Hong Kong:

Docker run -p 8080: 8080 -e TZ = Asia / Hong_Kong -e OSD = HK_Weather -v / ruta / a / foto: / app / photo moononournation / face-awareness-photo-osd: 1.0.1

Si desea desarrollar su propia información 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 / ruta / a / foto: / app / foto -v ~ / git / face-awareness-photo-osd / app.js: /app/app.js moononournation / face-awareness-photo-osd: 1.0. 1

Modifique la función update_osd () en app.js para personalizar su propia información OSD. Después del desarrollo, simplemente elimine el entorno DEBUG = Y del comando docker.

Paso 5: Configurar Photo Server Opción 2: Construir a partir de la fuente

Si está familiarizado con Node.js, puede crear el servidor de aplicaciones desde la fuente.

Obtén la fuente:

clon de git

Instalar paquetes:

cd cara-consciente-foto-osd

npm install

Cree una carpeta de fotos y copie sus propias fotos en la carpeta.

Ejecute el servidor de aplicaciones:

nodo app.js

Paso 6: Opción de cliente 1: navegador web

Opción de cliente 1: navegador web
Opción de cliente 1: navegador web

Simplemente navegue a https:// localhost: 8080 /

La página está programada para cargar automáticamente una imagen de tamaño de página ajustada cada minuto.

PD Si navega desde otra máquina que no está ejecutando el servidor de aplicaciones, recuerde cambiar localhost por el nombre de host o la dirección IP del servidor de aplicaciones.

Paso 7: Opción de cliente 2: ESP32 + LCD

Opción de cliente 2: ESP32 + LCD
Opción de cliente 2: ESP32 + LCD
Opción de cliente 2: ESP32 + LCD
Opción de cliente 2: ESP32 + LCD
Opción de cliente 2: ESP32 + LCD
Opción de cliente 2: ESP32 + LCD
Opción de cliente 2: ESP32 + LCD
Opción de cliente 2: ESP32 + LCD

Un cliente de marcos de fotos puede ser tan simple como una placa de desarrollo ESP32 y una pantalla LCD.

Aquí está el hardware necesario:

Tablero de desarrollo ESP32

Cualquier placa de desarrollo ESP32 debería estar bien, esta vez estoy usando una placa llamada MH-ET LIVE.

Pantalla LCD

Cualquier LCD compatible con Arduino_GFX, puede encontrar una pantalla compatible actualmente en el archivo Léame de GitHub:

github.com/moononournation/Arduino_GFX

Cable pasa corriente

Algunos cables de puente, dependen de la placa de desarrollo y la disposición de los pines LCD. En la mayoría de los casos, son suficientes 6-9 cables de puente hembra a hembra.

Soporte para LCD

Algunos soportes ayudan a que la pantalla LCD se mantenga recta, esta vez estoy usando un soporte para tarjetas.

Paso 8: Ensamblaje de ESP32 + LCD

Ensamblaje de LCD ESP32 +
Ensamblaje de LCD ESP32 +
Ensamblaje de LCD ESP32 +
Ensamblaje de LCD ESP32 +
Ensamblaje de LCD ESP32 +
Ensamblaje de LCD ESP32 +

Se prefiere el ESP32 con cabezal de clavija en la parte superior. Si el encabezado del pin está en la parte inferior, simplemente coloque la placa boca abajo;>

Conecte ESP32 y LCD con cables de puente, luego colóquelo en el soporte.

Aquí está el resumen de conexión de muestra:

ESP32 -> LCD

Vcc -> Vcc GND -> GND GPIO 5 -> CS GPIO 27 -> DC (si está disponible) GPIO 33 -> RST GPIO 18 -> SCK GPIO 19 -> MISO (opcional) GPIO 22 -> LED (si está disponible) GPIO 23 -> MOSI / SDA

Paso 9: Software ESP32 + LCD

Software ESP32 + LCD
Software ESP32 + LCD

IDE de Arduino

Descargue e instale Arduino IDE si aún no lo ha hecho:

www.arduino.cc/en/main/software

Soporte ESP32

Siga las instrucciones de instalación para agregar compatibilidad con ESP32 si aún no lo ha hecho:

github.com/espressif/arduino-esp32

Biblioteca Arduino_GFX

Descargue las últimas bibliotecas Arduino_GFX: (presione "Clonar o Descargar" -> "Descargar ZIP")

github.com/moononournation/Arduino_GFX

Importar bibliotecas en Arduino IDE. (Menú "Sketch" de Arduino IDE -> "Incluir biblioteca" -> "Agregar biblioteca. ZIP" -> seleccione el archivo ZIP descargado)

Compilar y cargar

  1. Abra el IDE de Arduino
  2. Abra el código de muestra ESP32PhotoFrame ("Archivo" -> "Ejemplo" -> "Biblioteca GFX para Arduino" -> "WiFiPhotoFrame")
  3. Ingrese la configuración de su AP WiFi en SSID_NAME y SSID_PASSWORD
  4. Reemplace el nombre de host o IP y el puerto de su servidor en HTTP_HOST y
  5. Presione el botón "Cargar" de Arduino IDE
  6. Si encuentra que la orientación no es correcta, cambie el valor de "rotación" (0-3) en el nuevo código de clase

Paso 10: ¡Disfruta de la foto

¡Disfruta de la foto!
¡Disfruta de la foto!

¡Es hora de poner el marco de fotos de IoT en su escritorio y disfrutar!

Paso 11: ¿Qué sigue?

  • Agrega tu propia información instantánea
  • Ajuste el tamaño de la foto de origen para una mejor precisión en la detección de rostros
  • Tarea automática para poner las últimas fotos en la carpeta de fotos del servidor
  • Toma más fotos;>