ESP32-CAM WIFI摄像头遥控车
本帖最后由 云天 于 2022-1-30 15:47 编辑想法很简单,用手机控制视频小车,硬件使用ESP32-CAM,手机程序制作软件使用App Inventor2。
【ESP322-CAM简介】
ESP322-CAM是安信可最新推出一款开发板模组,只需要一个ESP32模组和摄像头即可组成一个摄像头系统,ESP32-CAM是一款低成本物联网解决方案的开发板,基于ESP32模块开发的最小系统物联网产品,具有小体积,可板载摄像头的优势,适合快速原型搭建,DIY项目开发,物联网入门学习等。该产品集成了Wi-Fi,支持图片WiFI上传。
【引脚】
下图显示了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
【烧录程序】
我们使用Arduino IDE对ESP32-CAM板进行编程。因此,您需要安装Arduino IDE以及ESP32插件。
1、Arduino IDE配置
Arduino IDE 中,转到文件>首选项
如下图所示,在“Additional Board Manager URLs”字段中输入https://dl.espressif.com/dl/package_esp32_index.json 。然后,单击“确定”按钮:
转到工具>板>板管理器...,搜索“ESP32”并按下“ ESP32 by Espressif Systems ”的安装按钮:
2、CameraWebServer示例代码
在Arduino IDE中,转到文件 > 示例 > ESP32 > 相机,然后打开CameraWebServer示例。应加载以下代码。在上载代码之前,您需要在以下变量中插入网络凭据:const char* ssid = "********";
const char* password = "********";然后,确保选择正确的相机模块。在这种情况下,我们使用AI-THINKER模型。所以,注释掉所有其他模型,AI-THINKER模型取消注释:// Select camera model
//#define CAMERA_MODEL_WROVER_KIT // Has PSRAM
//#define CAMERA_MODEL_ESP_EYE // Has PSRAM
//#define CAMERA_MODEL_M5STACK_PSRAM // Has PSRAM
//#define CAMERA_MODEL_M5STACK_V2_PSRAM // M5Camera version B Has PSRAM
//#define CAMERA_MODEL_M5STACK_WIDE // Has PSRAM
//#define CAMERA_MODEL_M5STACK_ESP32CAM // No PSRAM
#define CAMERA_MODEL_AI_THINKER // Has PSRAM
//#define CAMERA_MODEL_TTGO_T_JOURNAL // No PSRAM定义电机控制引脚,发现GPIO12不能被占用,与FLASH信号有冲突。所以在下载程序时将12引脚拔下,当传好程序,重启后再插上。/* Defining motor and servo pins */
extern int DRV_A = 12;
extern int DRV_B = 13;
extern int DIR_A = 14;
extern int DIR_B = 15;当下载程序时,如不拔下12引脚连接线,会出现如下错误。void setup()中,进行引脚初始化 pinMode(DRV_A, OUTPUT);
pinMode(DRV_B, OUTPUT);
pinMode(DIR_A, OUTPUT);
pinMode(DIR_B, OUTPUT);在文件app_httpd.cpp中,初始引脚/* Initializing pins */
extern int DRV_A;
extern int DRV_B;
extern int DIR_A;
extern int DIR_B;在static esp_err_t cmd_handler(httpd_req_t *req)中,接收由手机APP发过来的http请求:/control?var=motor&val=对应数字(1为前进,2为后退,3为向左,4为向左,5为停止)if(!strcmp(variable, "motor")){
if(val==1)
{
Serial.println("Forward Left");
digitalWrite(DRV_A, HIGH);
digitalWrite(DRV_B, LOW);
digitalWrite(DIR_A, HIGH);
digitalWrite(DIR_B, LOW);
//digitalWrite(ledPin, HIGH);
httpd_resp_set_type(req, "text/html");
return httpd_resp_send(req, "OK", 2);
}else if(val==2){
Serial.println("Back");
digitalWrite(DRV_A, LOW);
digitalWrite(DRV_B, HIGH);
digitalWrite(DIR_A, LOW);
digitalWrite(DIR_B, HIGH);
httpd_resp_set_type(req, "text/html");
return httpd_resp_send(req, "OK", 2);
}
else if(val==3){
Serial.println("Left");
digitalWrite(DRV_A, LOW);
digitalWrite(DRV_B,LOW);
digitalWrite(DIR_A, HIGH);
digitalWrite(DIR_B, LOW);
httpd_resp_set_type(req, "text/html");
return httpd_resp_send(req, "OK", 2);
}
else if(val==4){
Serial.println("Right");
digitalWrite(DRV_A, HIGH);
digitalWrite(DRV_B,LOW);
digitalWrite(DIR_A, LOW);
digitalWrite(DIR_B, LOW);
httpd_resp_set_type(req, "text/html");
return httpd_resp_send(req, "OK", 2);
}
else if(val==5){
Serial.println("Stop");
digitalWrite(DRV_A, LOW);
digitalWrite(DRV_B, LOW);
digitalWrite(DIR_A, LOW);
digitalWrite(DIR_B, LOW);
httpd_resp_set_type(req, "text/html");
return httpd_resp_send(req, "OK", 2);
}
}
现在,代码已准备好(原例)(修改)【ESP32-CAM上传代码】使用USB to Serial 转串口。在烧录的时候要注意,要将开发板中的GPIO0连接到GND,烧录完毕后去掉连接。其他的RX,TX连接就不多说了。
您还应该按下板载重置按钮以在闪烁模式下重新启动ESP32。
保证模块输入电源至少5V 2A,否则图片会有几率出现水纹。
【获取IP地址】
上传代码后,断开GPIO 0与GND的连接。以波特率115200打开串行监视器。按ESP32-CAM板载复位按钮。ESP32 IP地址应打印在串行监视器中。【访问视频流服务器】现在,可以在本地网络上访问您的相机流媒体服务器。打开浏览器并键入ESP32-CAM IP地址。按Start Streaming按钮开始视频流。看到视频,说明Esp32配置成功。
【手机APP编写程序】
使用App Inventor2编写手机程序。1、界面设计
2、逻辑设计
视频流地址:http://IP:81/stream
修改视频帧清晰地址:http://IP/control?var=quality&val=滑动条值
修改视频帧大小地址:http://IP/control?var=framesize&val=下拉框选中项索引
电机控制指令地址:http://IP/control?var=motor&val=数字
【硬件组装】
1、小车底盘
2、电机驱动
3、电源使用两节锂电池供电,利用变压模块提供两个5V接口。
制作USB供电线
4、ESP32 CAM
5、组装成品车
【演示视频】
https://www.bilibili.com/video/BV1hS4y1y7dK?share_source=copy_web
您好,在DF创客社区看到您关于ESP32-CAM摄像头遥控车的项目,我也在做这个项目,但是手机端一直显示Header fields are too long for server to interpret,在网上查阅了很久都说是因为ARDUINO ide编译的原因,您遇到过这个问题吗? 手机用edge浏览器可以直接访问,但百度浏览器不行。用appinventor的web浏览器也不行。求助各位大佬…… 海燕peter 发表于 2022-5-18 09:10
您好,在DF创客社区看到您关于ESP32-CAM摄像头遥控车的项目,我也在做这个项目,但是手机端一直显示Header...
我换了一个手机,问题解决! 海燕peter 发表于 2022-5-18 09:10
您好,在DF创客社区看到您关于ESP32-CAM摄像头遥控车的项目,我也在做这个项目,但是手机端一直显示Header...
谁有 APP inventor 的地址,给一下喂,感谢各位大佬了,, 谁有 APP inventor 的地址,给一下喂,感谢各位大佬了,,
lv7MF1HbRBHm 发表于 2022-6-19 16:07
谁有 APP inventor 的地址,给一下喂,感谢各位大佬了,,
https://app.wxbit.com/
http://app.gzjkw.net/
页:
[1]