使用ESP32-CAM构建人脸ID控制的数字门锁系统

2022-12-05  

  安全是当今每个人最关心的问题,无论是数据安全还是自己家的安全。随着技术的进步和物联网的日益普及,如今数字门锁已变得非常普遍。数字锁不需要任何物理钥匙,但它使用RFID、指纹、Face ID、pin、密码等来控制门锁。过去,我们使用这些不同的技术开发了许多数字门锁应用程序。在本教程中,我们使用 ESP32-CAM 构建了一个人脸 ID 控制的数字门锁系统。


  所需组件

  ESP32 凸轮

  FTDI 董事会

  继电器模块

  电磁锁

  跳线


  电磁锁

  电磁锁在电子机械锁定机构上工作。这种类型的锁有一个带有倾斜切口的嵌条和一个良好的安装支架。通电时,直流电会产生磁场,将塞子移入内部并使门保持在解锁位置。弹头将保持其位置,直到断电。当电源断开时,蛞蝓移动到外面并锁上门。它在锁定状态下不使用任何电源。要驱动电磁锁,您需要一个可以提供 12V @ 500mA 的电源。

poYBAGLwv5eAE4XGAAOTaTTNS7c616.png

  我们之前使用电磁锁来构建基于Arduino 的 RFID 门锁。

  电路原理图

  ESP32-CAM人脸识别门锁系统电路图如下:

pYYBAGLwv5OATlK7AAFz2ylDO0c459.png

  上面的电路与 FTDI 板、继电器模块和电磁锁相结合。FTDI 板用于将代码刷入 ESP32-CAM,因为它没有 USB 连接器,而继电器模块用于打开或关闭电磁锁。FTDI 板和 Relay 模块的 VCC 和 GND 引脚连接到 ESP32-CAM 的 Vcc 和 GND 引脚。FTDI 板的 TX 和 RX 连接到 ESP32 的 RX 和 TX,继电器模块的 IN 引脚连接到 ESP32-CAM 的 IO4。

pYYBAGLwv5CAWRj_AABHh-0p9rg971.png

  注意:在上传代码之前,将 IO0 接地。IO0 决定 ESP32 是否处于闪烁模式。当 GPIO 0 连接到 GND 时,ESP32 处于闪烁模式。


  根据电路图连接硬件后,它应该如下所示:

poYBAGLwv4yAMLktAAdIuoXqUP4765.png

  在 Arduino IDE 上安装 ESP32 Board

  这里使用 Arduino IDE 对 ESP32-CAM 进行编程。为此,首先,在 Arduino IDE 上安装 ESP32 插件。

  要在您的 Arduino IDE 中安装 ESP32 板,请转到File》 Preferences。

poYBAGLwv4iAIePmAAHV2KOXt7M808.png

  现在复制下面的链接并将其粘贴到“AddiTIonal Board Manager URLs”字段中,如下图所示。然后,单击“确定”按钮:

  https://dl.espressif.com/dl/package_esp32_index.json

pYYBAGLwv4SAUagBAAQAEQ2v4XA146.png

  现在转到工具》董事会》董事会经理

poYBAGLwv4CAHMQbAAS-kP_L1aE769.png

  在 Board Manager 中,搜索 ESP32 并安装“ESP32 by Espressif Systems”。

pYYBAGLwv32AZtRYAAD-yD7B164883.png

代码说明

我们在上一篇文章中解释了使用 ESP32 进行人脸识别;在这里,我们将修改相同的代码来控制电磁门锁。完整的代码分为四个部分。一个是摄像头和继电器模块的主代码,ESP32 根据人脸识别锁定或解锁门,另外三个代码是网页、摄像头索引和摄像头引脚。本页末尾给出了完整的代码。在这里,我们将解释代码的一些重要部分。

通过包含所有库文件来启动程序。

 

#include “esp_camera.h”
#include#include “camera_pins.h”

 

在下一行中,取消注释您与 ESP32 一起使用的摄像头模块。在代码中,定义了五种不同的相机模型。在这种情况下,我们使用的是 AI-THINKER 模型。

 

//#define CAMERA_MODEL_WROVER_KIT
//#define CAMERA_MODEL_ESP_EYE
//#define CAMERA_MODEL_M5STACK_PSRAM//#define CAMERA_MODEL_M5STACK_WIDE
#define CAMERA_MODEL_AI_THINKER

 

之后,将您的网络凭据插入以下变量:

 

const char* ssid = "Wi-Fi 名称";
const char* password = "Wi-Fi 密码";

 

然后定义连接继电器模块的引脚。在定义的时间间隔内解锁后,我们将使用millis()函数锁定门,这里是 5 秒。

 

#定义继电器4
长 prevMillis = 0;
整数间隔 = 5000;

 

在setup()函数中,以 115200 的波特率初始化串行监视器以进行调试。然后在接下来的几行中,定义继电器模块的引脚模式,并将继电器初始设置为低位。

 

无效设置(){
  序列号.开始(115200);
  pinMode(继电器,输出);
  数字写入(继电器,低);

 

在loop()函数中,检查人脸是否与注册的人脸匹配。如果是,则解锁门 5 秒,5 秒后再次锁门。

 

无效循环(){    if (matchFace == true && activeRelay == false){
      主动继电器=真;
      数字写入(继电器,高);
      上一页Millis = millis();
    }
    if(activeRelay == true && millis()- prevMillis > 间隔){
      主动继电器 = 假;
      匹配面=假;
      数字写入(继电器,低);
    }

 

  测试ESP32-CAM 人脸识别门锁系统

  最后上传代码,将 FDTI 板连接到您的笔记本电脑,然后选择“ESP32 Wrover Module”作为您的板。此外,更改其他设置,如下图所示:

poYBAGLwv3aAFzrAAAKZCjBtTTU270.png

  在上传代码之前不要忘记将 IO0 引脚连接到 GND,并按下 ESP32 重置按钮,然后单击上传按钮。

  注意:如果您在上传代码时遇到错误,请检查 IO0 是否连接到 GND,并且您在工具菜单中选择了正确的设置。

  上传代码后,移除 IO0 和 GND 引脚。然后打开串口监视器并将波特率更改为115200。然后,按下ESP32重置按钮,它将打印ESP IP地址和端口号。在串行监视器上。

poYBAGLwv3KAaQTBAAH5znfach4443.png

  现在导航到浏览器并输入从串行监视器复制的 ESP IP 地址以访问摄像机流。它将带您到流媒体页面。要开始视频流,请单击页面底部的“开始流”按钮。

poYBAGLwv2iAPCneAAIGNTZ9jPU047.png

  要使用 ESP32-CAM 识别人脸,首先,我们必须注册人脸。为此,请从设置中打开人脸识别和检测功能,然后单击“注册人脸”按钮。需要多次尝试才能保住面子。保存人脸后,它将人脸检测为主体 0,其中零是人脸编号。

pYYBAGLwv2OAECGPAAFdgZyxnCo291.png

  注册人脸后,如果视频中识别到人脸,ESP32 会将继电器模块设为高电平以解锁门。

pYYBAGLwv2CAGMZIAAOhdIzn7cs897.png

#include “esp_camera.h”
#include
//
// 警告!!!确保您选择了 ESP32 Wrover 模块,
// 或另一个启用了 PSRAM 的板
//
// 选择相机型号
//#define CAMERA_MODEL_WROVER_KIT
//#define CAMERA_MODEL_ESP_EYE
//#define CAMERA_MODEL_M5STACK_PSRAM
//#define CAMERA_MODEL_M5STACK_WIDE
#define CAMERA_MODEL_AI_THINKER
#include “camera_pins.h”
const char* ssid = "银河-M20";
const char* 密码 = "ac312124";
#define LED_BUILTIN 4
#定义继电器4
#定义蜂鸣器2
布尔匹配面 = 假;
boolean acTIveRelay = false;
长 prevMillis = 0;
整数间隔 = 5000;
无效 startCameraServer();
无效设置(){
序列号.开始(115200);
Serial.setDebugOutput(true);
序列号.println();
pinMode(继电器,输出);
pinMode(蜂鸣器,输出);
pinMode(LED_BUILTIN,输出);
数字写入(LED_BUILTIN,低);
数字写入(继电器,低);
数字写入(蜂鸣器,低);
camera_config_t 配置;
config.ledc_channel = LEDC_CHANNEL_0;
config.ledc_timer = LEDC_TIMER_0;
config.pin_d0 = Y2_GPIO_NUM;
config.pin_d1 = Y3_GPIO_NUM;
config.pin_d2 = Y4_GPIO_NUM;
config.pin_d3 = Y5_GPIO_NUM;
config.pin_d4 = Y6_GPIO_NUM;
config.pin_d5 = Y7_GPIO_NUM;
config.pin_d6 = Y8_GPIO_NUM;
config.pin_d7 = Y9_GPIO_NUM;
config.pin_xclk = XCLK_GPIO_NUM;
config.pin_pclk = PCLK_GPIO_NUM;
config.pin_vsync = VSYNC_GPIO_NUM;
config.pin_href = HREF_GPIO_NUM;
config.pin_sscb_sda = SIOD_GPIO_NUM;
config.pin_sscb_scl = SIOC_GPIO_NUM;
config.pin_pwdn = PWDN_GPIO_NUM;
config.pin_reset = RESET_GPIO_NUM;
config.xclk_freq_hz = 20000000;
config.pixel_format = PIXFORMAT_JPEG;
//用高规格初始化以预分配更大的缓冲区
如果(psramFound()){
config.frame_size = FRAMESIZE_UXGA;
config.jpeg_quality = 10;
config.fb_count = 2;
} 别的 {
config.frame_size = FRAMESIZE_SVGA;
config.jpeg_quality = 12;
config.fb_count = 1;
}
#如果定义(CAMERA_MODEL_ESP_EYE)
pinMode(13,INPUT_PULLUP);
pinMode(14, INPUT_PULLUP);
#万一
// 相机初始化
esp_err_t err = esp_camera_init(&config);
如果(错误!= ESP_OK){
Serial.printf("相机初始化失败,错误 0x%x", err);
返回;
}
sensor_t * s = esp_camera_sensor_get();
//初始传感器垂直翻转,颜色有点饱和
if (s->id.PID == OV3660_PID) {
s->set_vflip(s, 1);//翻转回来
s->set_brightness(s, 1);//稍微提高亮度
s->set_saturation(s, -2);//降低饱和度
}
//降低帧大小以获得更高的初始帧速率
s->set_framesize(s, FRAMESIZE_QVGA);
#如果定义(CAMERA_MODEL_M5STACK_WIDE)
s->set_vflip(s, 1);
s->set_hmirror(s, 1);
#万一
WiFi.begin(ssid, 密码);
而(WiFi.status()!= WL_CONNECTED){
延迟(500);
Serial.print(".");
}
序列号.println("");
Serial.println("WiFi 连接");
startCameraServer();
Serial.print("相机准备好了!使用'http://");
Serial.print(WiFi.localIP());
Serial.println("'要连接");
}
无效循环(){
if (matchFace == true && activeRelay == false){
主动继电器=真;
数字写入(继电器,高);
digitalWrite(蜂鸣器,高);
延迟(800);
digitalWrite(蜂鸣器,低);
上一页Millis = millis();
}
if(activeRelay == true && millis()- prevMillis > 间隔){
主动继电器 = 假;
匹配面=假;
数字写入(继电器,低);
}
}


文章来源于:电子工程世界    原文链接
本站所有转载文章系出于传递更多信息之目的,且明确注明来源,不希望被转载的媒体或个人可与我们联系,我们将立即进行删除处理。