ESP32-CAM 是安信可发布小尺寸的摄像头模组。该模块可以作为最小系统独立工作,尺寸仅为2740.54.5mm。 ESP32-CAM可广泛应用于各种物联网场合,适用于家庭智能设备、工业无线控制、无线监控、人脸识别以及其它物联网应用,是物联网应用的理想解决方案。 ESP32-CAM采用DIP封装,直接插上底板即可使用,实现产品的快速生产,为客户提供高可靠性的连接方式,方便应用于各种物联网硬件终端场合。
MicroPython 是运行在微控制器硬件之上的 Python 编译器,提供给用户一个交互式提示符(Read-Evaluate-Print-Loop, 以下简称 REPL)来立即执行所支持的命令。除了包括选定的核心 Python 库,MicroPython 还包括了给予编程者访问低层硬件的模块。
MicroPython 是澳大利亚程序员和物理学家 Damien George,在 2013 年一次众筹活动之后创建的。当初的众筹活动将 MicroPython 与基于 STM32 F4 的pyboard 开发板一起发行,因此 MicroPython 支持大量的基于 ARM 的体系结构,随后 MicroPython 已经可以运行于 Arduino、ESP8266、ESP32 与大多数的物联网硬件。在 2016 年,Python 软件基金会创建了 MicroPython 的 BBC Micro Bit 版本,作为其 BBC Micro Bit 合作伙伴贡献的一部分,授權條款 为 MIT 授權條款。
软件列表:
pip3 install esptool
图 1. 根据自己的操作系统下载适合的 Thonny 版本
完成上面软硬件准备后,先将 CH340 串口模块插到电脑上,1. 是使用 Type C 连到电脑;2. 使用 USB 连接 CH340 串口模块;3. ESP32-CAM 设定在下载模式,如下图所示。
图 2. 将 ESP32-CAM 连接到电脑
要确认电脑是否能够识别到这个模块,以 Mac 来说,可以在 /dev 中找到,在终端输入以下指令后就可以看到 /dev/cu.usbserial-14110
ls -l /dev/cu*
图 3. 电脑识别到 CH340 串口模块
打开 Thonny IDE,选择运行->配置解释器
图 4. 在 Thonny IDE 中选择运行->配置解释器
最后单击 Install or Update MicroPython
图 5. 配置解释器到 ESP32-CAM
安装并更新 MicroPython,指定端口(Port)跟烧录档固件(Firmware)
接著单击安装
图 6. 安装并更新 MicroPython
烧录完毕后就可以单击关闭,回到主画面,回弹出错误信息。主要是因为目前是下载模式并非调适模式,所以记得将ESP32-CAM的跳线帽移除。下图中 1. 移除后的跳线帽;2. 按下 reset 键重启 ESP32-CAM;3. Thonny 成功连接到 ESP32-CAM 中的 MicroPython,虽然会有错误信息,但这是 Thonny 所造成,可以不用理会,可以看出这个版本的固件信息如下:
图 7. Thonny 连接 ESP32 成功的主画面
本篇文章的目的是要用 MicroPython 控制 ESP32-CAM 的摄像头,运行一个实时视频,可以使用浏览器莱观看结果,架构设计如下图所示,先让 ESP32-CAM 跟电脑先连上同一个AP(子网络),接著在 ESP32-CAM 上运行一个Web服务器,是使用 microdot 这个包来简化架站的功能,接著打开web浏览器即可观看结果。
图 8. 视频网络服务器架构
在本机取得 microdot.py 原始档(百度云盘,提取码ccit),透过 Thonny 的画面打开,如下图所示。
图 9. Thonny 打开文件
图 10. Thonny 打开本地的 microdot.py 文件
接著将 microdot.py 存到 ESP32-CAM 上,单击上方工作列的 文件,选择 另存为… ,如下图所示。
图 11. Thonny 将本地文另存为其他文件
接著会弹出一个画面,选择存到哪一个设备,选择 MicroPython设备。
图 12. Thonny 选择存到 MicroPython设备
在 MicroPython设备 中单击右键,选择新建文件夹…,输入 lib。
图 13. Thonny 新建文件夹
进入 lib 文件夹,文件名输入 microdot.py后,单击 好的
图 14. 另存为 microdot.py
会出现上传画面。
图 15. 正在保存 microdot.py 到 MicroPython设备
在 Shell 中输入以下源代码运行,如果运行成功会出现 Starting … 等信息,如下图所示。
原始代码
from microdot import Microdot app = Microdot() @app.route('/') def index(request): return 'Hello, world Microdot!' app.run(debug=True)
图 16. 导入 microdot 包,架构 Web 服务器
输出结果为:
Starting sync server on 0.0.0.0:5000...
以下是实时视频代码 video_stream.py,代码说明如下:
from microdot import Microdot import time import camera from machine import reset import network def connect(): wlan = network.WLAN(network.STA_IF) wlan.active(True) if not wlan.isconnected(): print('connecting to network...') wlan.connect(SSID, PASSWORD) while not wlan.isconnected(): pass print('network config: ', wlan.ifconfig()) connect() app = Microdot() # wait for camera ready for i in range(5): cam = camera.init() print("Camera ready?: ", cam) if cam: print("Camera ready") break else: time.sleep(2) else: print('Timeout') reset() @app.route('/') def index(request): return ''' Microdot Video Streaming Microdot Video Streaming
''', 200, {'Content-Type': 'text/html'} @app.route('/video_feed') def video_feed(request): def stream(): yield b'--frame\r\n' while True: frame = camera.capture() yield b'Content-Type: image/jpeg\r\n\r\n' + frame + \ b'\r\n--frame\r\n' #time.sleep_ms(50) return stream(), 200, {'Content-Type': 'multipart/x-mixed-replace; boundary=frame'} if __name__ == '__main__': app.run(debug=True)
下图就是运行结果,左手边是浏览器的观看结果,右手边则是Thonny运行代码的画面。
图 17. 视频网络服务器结果画面
下一篇:Linux--进程信号