项目(二) esp32-cam 网页图像人脸
https://randomnerdtutorials.com/esp32-cam-video-streaming-face-recognition-arduino-ide/



ESP32-CAM Pinout
下图显示了ESP32-CAM引脚排列(AI-Thinker模块)。
有三个GND引脚和两个引脚用于电源:3.3V或5V。
GPIO 1和GPIO 3是串行引脚。您需要这些引脚才能将代码上传到您的电路板。此外,GPIO 0也起着重要作用,因为它确定ESP32是否处于闪烁模式。当GPIO 0连接到GND时,ESP32处于闪烁模式。
以下引脚内部连接到microSD卡读卡器:
- GPIO 14:CLK
- GPIO 15:CMD
- GPIO 2:数据0
- GPIO 4:数据1(也连接到板载LED)
- GPIO 12:数据2
- GPIO 13:数据3
视频流服务器
按照以下步骤使用您可以在本地网络上访问的ESP32-CAM构建视频流式Web服务器。
1.安装ESP32插件
在本例中,我们使用Arduino IDE对ESP32-CAM板进行编程。因此,您需要安装Arduino IDE以及ESP32插件。如果您还没有安装ESP32插件,请按照下一个教程之一进行操作:
2. CameraWebServer示例代码
在Arduino IDE中,转到文件 > 示例 > ESP32 > 相机,然后打开CameraWebServer示例。

应加载以下代码。

如果在Arduino IDE中找不到代码,可以从我们的GitHub存储库下载。下载后,解压缩该文件夹,然后打开CameraWebServer.ino文件。
在上载代码之前,您需要在以下变量中插入网络凭据:
const char* ssid = "REPLACE_WITH_YOUR_SSID";
const char* password = "REPLACE_WITH_YOUR_PASSWORD";
然后,确保选择正确的相机模块。在这种情况下,我们使用AI-THINKER模型。

所以,评论所有其他模型并取消注释:
#define CAMERA_MODEL_AI_THINKER
现在,代码已准备好上传到您的ESP32
ESP32-CAM上传代码
使用FTDI编程器将ESP32-CAM板连接到计算机。按照下一个原理图:

重要提示: GPIO 0需要连接到GND,以便您能够上传代码。
要上传代码,请执行以下步骤:
- 转到工具 > 板,然后选择ESP32 Wrover模块
- 转到工具 > 端口,然后选择ESP32连接的COM端口
- 在工具 > 分区方案中,选择“ 巨大的APP(3MB无OTA) ”
- 按下ESP32-CAM板载RESET按钮
- 然后,单击上传按钮以上载代码。

重要提示:如果无法上传代码,请仔细检查GPIO 0是否已连接到GND,并在“ 工具”菜单中选择了正确的设置。您还应该按下板载重置按钮以在闪烁模式下重新启动ESP32。
获取IP地址
上传代码后,断开GPIO 0与GND的连接。
以波特率115200打开串行监视器。按ESP32-CAM板载复位按钮。
ESP32 IP地址应打印在串行监视器中。

访问视频流服务器
现在,您可以在本地网络上访问您的相机流媒体服务器。打开浏览器并键入ESP32-CAM IP地址。按Start Streaming按钮开始视频流。

您还可以通过单击“ 获取静止”按钮来拍摄照片。不幸的是,此示例不保存照片,但您可以修改它以使用板载microSD卡存储拍摄的照片。
您还可以使用多种相机设置来调整图像设置。
最后,您可以进行人脸识别和检测。

首先,您需要注册一张新面孔。它将多次尝试挽救面部。在注册新用户之后,它应该稍后检测到面部(主题0)。

就是这样。现在,您可以使用图库中的示例启动并运行带有面部检测和识别功能的视频流式Web服务器。
故障排除
如果您遇到以下任何错误,请阅读我们的 ESP32-CAM故障排除指南:修复了最常见的问题
- 无法连接到ESP32:超时等待数据包标头
- Camera init失败,错误0x20001或类似
- 掉电探测器或古鲁冥想错误
- 草图太大错误 - 选择了错误的分区方案
- COMX的主板不可用 - 未选择COM端口
- Psram错误:未安装GPIO isr服务
- 弱Wi-Fi信号
- Arduino IDE串行监视器中没有IP地址
- 无法打开Web服务器
- 图像滞后/显示大量延迟
包起来
ESP32-CAM提供了一种廉价的方式来构建更先进的家庭自动化项目,包括视频,拍照和人脸识别。
在本教程中,我们测试了CameraWebServer示例以测试摄像头功能。现在,我们的想法是修改示例或编写一个全新的代码来构建其他项目。例如,在检测到动作时拍照并将其保存到microSD卡,在家庭自动化平台(如Node-RED或Home Assistant)中集成视频流等等。
我们希望您发现本教程很有用。如果你还没有ESP32-CAM,你可以在这里抓住它。
如果您喜欢这个项目,您可能也喜欢其他有关相机的项目:
- ESP32-CAM视频流Web服务器(与Home Assistant和Node-RED配合使用)
- 基于CCTV Raspberry Pi的系统,使用MotionEyeOS进行存储
- 使用Raspberry Pi相机的视频流
- 使用Raspberry Pi相机的节点RED(拍照)
项目(二) esp32-cam 网页图像人脸的更多相关文章
- Vue小项目二手书商城:(二)axios前后端数据交互
实现内容: 写路由接口(express) axios取数据 一.写接口 1.我们要在前端取到后端的数据(之前写的data.json)可以用vue-resourse或者用axios,在vue2之后官方就 ...
- Eclipse+Maven创建webapp项目<二> (转)
Eclipse+Maven创建webapp项目<二> 1.开启eclipse,右键new——>other,如下图找到maven project 2.选择maven project,显 ...
- Vue小项目二手书商城:(四)详情页和购物车(emit、prop、computed)
实现效果: 点击对应商品,对应的商品详情页出现,详情页里面还有“Add to cart”按钮和“×”退出按钮. 点击“Add to cart”可以将商品加入购物车,每件商品只能添加一次,如果把购物车的 ...
- Vue小项目二手书商城:(三)前端渲染数据
实现内容: axios取到的数据在前端使用(父子组件各自应该怎么使用) 一.简单使用(在哪取在哪用) 1.在App.vue中script中加上data(data专属于当前组件,父子组件传参通过prop ...
- Vue小项目二手书商城:(一)准备工作、组件和路由
本项目基于vue2.5.2,与低版本部分不同之处会在(五)参考资料中提出 完整程序:https://github.com/M-M-Monica/bukesi 实现内容: 资源准备(mock数据) 组件 ...
- Eclipse+Maven创建webapp项目<二>
Eclipse+Maven创建webapp项目<二> 1.开启eclipse,右键new——>other,如下图找到maven project 2.选择maven project,显 ...
- [python-opencv]图像二值化【图像阈值】
图像二值化[图像阈值]简介: 如果灰度图像的像素值大于阈值,则为其分配一个值(可以是白色255),否则为其分配另一个值(可以是黑色0) 图像二值化就是将灰度图像上的像素值设置为0或255,也就是将整个 ...
- crm 系统项目(二) admin 后台操作表格
crm 系统项目(二) admin 后台操作表格 1. app下创建 templates 运行的时候 先找全局的templates——> 按照app的注册顺序找templates中的文件 2. ...
- 旋转图像 给定一个 n × n 的二维矩阵表示一个图像。
给定一个 n × n 的二维矩阵表示一个图像. 将图像顺时针旋转 90 度. 说明: 你必须在原地旋转图像,这意味着你需要直接修改输入的二维矩阵.请不要使用另一个矩阵来旋转图像. 示例 : 给定 ma ...
随机推荐
- 《即时消息技术剖析与实战》学习笔记1——IM系统的架构
一.IM的应用场景 聊天.直播.在线客服.物联网等所有需要实时互动.高实时性的场景,都需要应用到 IM 技术.
- Docker 运行 MySQL,使用 docker-compose
目录结构 . │ .env │ docker-compose.yml │ └─mysql ├─config │ my.cnf │ └─data mysql 目录下的 data 为数据目录,mysql ...
- .NET Core MD5加密 32位和16位
public class MD5Help { //此代码示例通过创建哈希字符串适用于任何 MD5 哈希函数 (在任何平台) 上创建 32 个字符的十六进制格式哈希字符串官网案例改编 /// <s ...
- C# 使用SuperSocket
一.需求场景 (1)使用SuperSocket进行网络通信 二.所需软件 (1)SocketTool 三.实现步骤 (1)使用Nuget管理器安装SuperSocket.Engine 该插件已经包 ...
- Java之路---Day19(set接口)
set接口 java.util.Set 接口和 java.util.List 接口一样,同样继承自 Collection 接口,它与 Collection 接口中的方 法基本一致,但是set接口中元素 ...
- 【转载】Jupyter Notebook 常用快捷键
原文:http://blog.csdn.net/lawme/article/details/51034543 Jupyter Notebook 有两种键盘输入模式.编辑模式,允许你往单元中键入代码或文 ...
- jQuery---bootstrap的下载使用,栅格(12个格子),轮播图,矢量图字体图标,进度条,选项卡,标签,表达校验
jQuery---bootstrap的下载使用,栅格(12个格子),轮播图,矢量图字体图标,进度条,选项卡,标签,表达校验 一丶bootstrap的使用 下载资源文件: bootstrap官网 导入 ...
- CSS3 2D 变换
CSS2D transform 表示2D变换,目前获得了各主流浏览器的支持,是CSS3中具有颠覆性的特征之一,可以实现元素的位移.旋转.倾斜.缩放,甚至支持矩阵方式,可以取代大量之前只能靠Flash才 ...
- Ajax跨域问题及解决方案 asp.net core 系列之允许跨越访问(Enable Cross-Origin Requests:CORS) c#中的Cache缓存技术 C#中的Cookie C#串口扫描枪的简单实现 c#Socket服务器与客户端的开发(2)
Ajax跨域问题及解决方案 目录 复现Ajax跨域问题 Ajax跨域介绍 Ajax跨域解决方案 一. 在服务端添加响应头Access-Control-Allow-Origin 二. 使用JSONP ...
- MySQL Table--独立表空间
数据库表空间 独立表空间 在MySQL 5.6 中引入独立表空间的概念,启用独立表空间后,每个表将生成独立的文件来进行存储. 创建表时可以指定表存放的文件路径 ##首选需要确保innodb_file_ ...
