ESP32-CAM 使用 MicroPython 完成视频网络服务器 (Web Video Stream)

Yehchitsai 2024-07-02 17:03:04 阅读 61

ESP32-CAM 使用 MicroPython 完成视频网络服务器 (Web Video Stream)

目录

ESP32-CAM 使用 MicroPython 完成视频网络服务器 (Web Video Stream)开发环境准备软硬件集成架构说明手动安装 microdot实时视频代码

参考资料

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 授權條款。

软件列表:

MicroPython for ESP32-CAM 烧录档(提取码 ccit),也可到 github 上去下载。esptool.py,一个针对乐鑫科技Espressif所开发出来的晶片提供烧录开机软件的开源软件,以 Python 为基础,可以用于乐鑫 ESP8285, ESP8266, ESP32, ESP32-S 等系列芯片和 ROM Bootloader (即:一级 bootloader )通讯。

pip3 install esptool

Thonny(提取码 ccit) ,Python IDE,可进行 Python 或是 MicroPython 程式设计,也可以直接将程式码烧录到 ESP32-CAM。

到 Thonny 的官网 https://thonny.org/,根据自己的操作系统下载适合的版本

在这里插入图片描述

图 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 中选择运行->配置解释器

解释器: MicroPython(ESP32)端口: /dev/cu.usbserial-14110

最后单击 Install or Update MicroPython

在这里插入图片描述

图 5. 配置解释器到 ESP32-CAM

安装并更新 MicroPython,指定端口(Port)跟烧录档固件(Firmware)

端口(Port): /dev/cu.usbserial-14110固件(Firmware): esp32-cam-micropython-20221203.bin烧录模式(Flash mode): From image file (keep)勾选先删除后安装*(Erase flash before installing)*

接著单击安装

在这里插入图片描述

图 6. 安装并更新 MicroPython

烧录完毕后就可以单击关闭,回到主画面,回弹出错误信息。主要是因为目前是下载模式并非调适模式,所以记得将ESP32-CAM的跳线帽移除。下图中 1. 移除后的跳线帽;2. 按下 reset 键重启 ESP32-CAM;3. Thonny 成功连接到 ESP32-CAM 中的 MicroPython,虽然会有错误信息,但这是 Thonny 所造成,可以不用理会,可以看出这个版本的固件信息如下:

开发语言: v1.19.1编译日期: 2022-12-03硬件: ESP32 CAMERA w/SSL

在这里插入图片描述

图 7. Thonny 连接 ESP32 成功的主画面

架构说明

本篇文章的目的是要用 MicroPython 控制 ESP32-CAM 的摄像头,运行一个实时视频,可以使用浏览器莱观看结果,架构设计如下图所示,先让 ESP32-CAM 跟电脑先连上同一个AP(子网络),接著在 ESP32-CAM 上运行一个Web服务器,是使用 microdot 这个包来简化架站的功能,接著打开web浏览器即可观看结果。

在这里插入图片描述

图 8. 视频网络服务器架构

手动安装 microdot

在本机取得 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,代码说明如下:

1-5:导入需要的模块,只有 microdot 需要额外安装,其他的都是内建模块。7-15:连线到AP的函数定义,12行务必修改为自己的 SSID 跟 PASSWORD。17:连线到 Wi-Fi AP18:建立 Microdot 网站服务器21-31:激活摄像头(camera)。33-44:定义网站根目录(/)网页46-57:定义视频流的路径(‘/video_feed’)与操作,这里就是整个视频流的主要代码61:激活网站服务器

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 '''<!doctype html>

<html>

<head>

<title>Microdot Video Streaming</title>

</head>

<body>

<h1>Microdot Video Streaming</h1>

<img src="/video_feed" width="30%">

</body>

</html>''', 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. 视频网络服务器结果画面

参考资料

esptool.py,https://github.com/espressif/esptoolThonny, https://thonny.org/esp32-cam-micropython-2022, https://github.com/shariltumin/esp32-cam-micropython-2022microdot, https://github.com/miguelgrinberg/microdotMicrodot, https://microdot.readthedocs.io/en/latest/index.html



声明

本文内容仅代表作者观点,或转载于其他网站,本站不以此文作为商业用途
如有涉及侵权,请联系本站进行删除
转载本站原创文章,请注明来源及作者。