【K210-ESP8266】开发板上传图像数据到服务器并实时显示

本文章主要记录基于 【K210-ESP8266】 图传和显示的过程,结合人脸识别,实现嵌入式边缘设备的无线通讯和AI推流,是系列文章,欢迎学习交流。
关于上位机的开发过程,请参考以下博文:
【K210+ESP8266图传上位机开发】TCP server + JPEG图像解析上位机开发

1. K210 - esp8266 图传

1.1 系统架构

  • K210 开发板的 OV2340摄像头采集图像
  • K210 开发板串口接 乐鑫科技的 ESP8266 模块,使用其 WIFI 功能
  • ESP8266 连接wifi后通过连接上位机TCP服务器,并将K210采集的图像数据通过透传的方式传输至 TCP server
  • 上位机 TCP server 将图像数据解析并还原显示

在这里插入图片描述

1.2 图像格式解析

一帧图像,格式 RGB56516位数据,每个像素占用2字节

320*240 分辨率 = 76800 像素

数据量 = 像素 * 2 字节 = 76800 * 2 = 153600字节 = 150 kb

img = sensor.snapshot() 
#返回值:{"w":320, "h":240, "type"="rgb565", "size":153600} 一帧图像字节数 153600
img_bytes = img.to_bytes() #转化为 字节
print(len(img_bytes))      #字节长度为 153600

# 图像压缩
img = sensor.snapshot()
lcd.display(img) 
img = img.compress(quality=60)    # 对原始图像压缩  压缩的 quality 越大 对原始图像的破坏率越大
img_bytes = img.to_bytes()    #转化为 字节
print(len(img_bytes))         #   #输出 6900 多  对原图进行压缩后,字节数变少,
#lcd.display(img)   #注意,压缩后再显示,会报错  格式不支持

1.3 图像发送方式解析

发送时,单次发送2048个字节,用block的形式,先发送2048的整数倍,再发送剩余字节数:

 img = sensor.snapshot()
        lcd.display(img)
        img = img.compress(quality=50)  # 对原始图像压缩  quality 越小 对原始图像的破坏率越大
        img_bytes = img.to_bytes() #转化为 字节
        print("send len: 压缩后的字节数 ", len(img_bytes))
        try:
            block = int(len(img_bytes)/2048)  #单次传2048个字节
            #print("发送的block数 ", block)
            for i in range(block):  # 先发送2048 的整数倍
                send_len = sock.send(img_bytes[i*2048:(i+1)*2048])  #返回发送的字节数
                #time.sleep_ms(500)
            send_len2 = sock.send(img_bytes[block*2048:]) #然后发啊送剩余不到2048个字节
            #print("send len2: ", send_len2)

            #time.sleep_ms(500)
            if send_len == 0:
                raise Exception("send fail")
        except OSError as e:
            if e.args[0] == 128:
                print("connection closed")

1.4 ESP8266 配置AT指令:

一般来说,ESP8266 模块默认的波特率是115200,AT指令全部以\r\n结尾;发送AT命令后,返回OK即认为设置成功

AP 模式:本身作为热点让别人连接: AT+CWMODE=2。配置热点信息: AT+CWSAP="Eureka1024","123456789",1,3 ---- 热点名为 Eureka1024,密码为 123456789,使用通道 1,加密方式为 WPA2_PSK。

station 模式: 用来连接热点,加入外部网络。AT+CWMODE=1连接到指定路由器:AT+CWJAP_DEF="PiWiFi","12345678" 。//wifi名wifi密码

# 透传模式:开启透传模式后只需要在第一次发送数据时使用 AT+CIPSEND 指令来告诉 ESP8266 开始透传发送,随后我们直接发送想要的数据即可,不需要在每次发送数据之前都要指定发送数据的长度
# 开启:使用 AT+CIPMODE=1 指令开启透传模式,
# 结束:1、发送 +++ 这三个字符,值得注意的是该命令没有换行符,不然后失败。 2、接着发送 AT+CIPMODE=0 命令即可退出透传模式,即回到正常的模式。
#ESP8266是通过AT指令进行配置的,因此要保证ESP8266已经烧录了AT固件库,一般网上买的ESP8266模块默认会烧录AT固件库,如若没有,可以自行进行烧录
AT+RESTORE                                                      #恢复出厂设置
AT+CWMODE=1                                                  #设置ESP8266工作模式为STA
AT+RST                                                            #复位
AT+CWJAP="路由器账号","密码"                                      #连接路由器
AT+CIPMODE=1                                                  #设置透传模式
AT+CIPSTART="TCP","192.168.6.117",8266                         #连接TCP服务器(上位机)
AT+CIPSEND                                                       #开启透传,传送数据的长度

1.5 ESP8266 透传图像数据

1.5.1 TcpServer 测试结果:

#上图中可以看出,OV2640采集到的图像数据,最终经过ESP8266发送到了上位机,并成功显示出来,只是受限于串口速率,大概3秒才会传输完一帧数据,在实际使用时,也可以发现,上位机数据缓冲容器时常都是空的,数据生产线程受限于串口速率,导致数据的生产远远小于数据的消耗,表现出来就是几秒才会刷新一帧数据。
图像帧数: 157
fps: 0.1968504
send len: 压缩后的字节数  6283
图像帧数: 158
fps: 0.1975114
send len: 压缩后的字节数  6285
图像帧数: 159
fps: 0.1968117
send len: 压缩后的字节数  6265
图像帧数: 160
fps: 0.1976675
send len: 压缩后的字节数  6232
图像帧数: 161
fps: 0.1969279
send len: 压缩后的字节数  6190
图像帧数: 162
fps: 0.1970055
send len: 压缩后的字节数  6205
图像帧数: 163
fps: 0.1970055
send len: 压缩后的字节数  6193

1.6 TCP 服务器+图像数据解析上位机

1.6.1 上位机:

在这里插入图片描述

上位机使用说明:
上位机下载:C#上位机 网络调试软件 可实时显示JPEG图像
https://download.csdn.net/download/qq_39217004/86946865

ESP8266在接受到K210开发板通过串口传输的图像数据之后,会将其发送给上位机,那么ESP8266和上位机之间是如何通讯的呢?是通过TCP/IP协议。本软件使用C#语言,基于TCP/IP协议,写了一个简单的上位机服务,该服务接受ESP8266的连接,并将其发送过来的数据编码为图像进行显示。由于软件写的很简单,因此很多功能并没有进行扩充实现,如其只支持一个设备的图传,后续可以进行升级改进。感谢各位的下载使用

使用说明:配置好您的本机IP和port口,port口在 0-65536任选一个即可,下位机和上位机的连接配置要一致,配置好趴之后可以实现连接使用

若有问题欢迎大家留言交流,祝大家工作学习顺利

修改不同的IP地址后,测试:
在这里插入图片描述

下位机:请留言交流





关于上位机的开发过程,请参考以下博文:
【K210+ESP8266图传上位机开发】TCP server + JPEG图像解析上位机开发

  • 38
    点赞
  • 272
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 35
    评论
目前基于图像处理使用市场上监控摄像头二次开发的案例很多,包括海康威视萤石开源摄像头;还有使用自带FIFO的OV7725或者OV7670摄像头模块结合stm32进行图传;还有OPENMV+OV7725的图像处理方案;还有一种使用MIPS架构的路由器芯片例如RT5350加免驱MPJG摄像头方案。每一种方案价格都要达到50块以上,因为除了购买摄像头之外还有购买单片机,成本降不下来。 好消息的是,乐鑫科技推出的ESP32芯片能满足图传的需求,某宝基于该芯片出售的ESP32-cam摄像头模块能满足图传的需求,最低价格26块能买到手,性价比相当高,ESP32的运行速度和wifi速度都比ESP8266高。26块集成了ESP32最小系统板和OV2640摄像头和板载蓝牙wifi天线,买了也不亏,一个好点的USB摄像头都不只这个价格了!为啥很少人使用呢?原因是入门比较麻烦。要是使用乐鑫idf去搭建开发图传,很麻烦,很难成功。 国内某个测评网有详细简介:https://post.smzdm.com/p/amm03d0d/ 模块的原理图如下: 模块的全家福如下: 该模块在某宝很多家店铺有售,至于代工厂估计有很多家,但是根据原理图就那么多IO口,资料都是通用的。 经过我自己个人努力,半年时间内掌握了ESP32图传技术,采用的是Arduino开发环境开发,很多情况下使用库函数来快速实现图传的功能。搭建开发环境也花了不少时间,后面根据一个教程搭建成功了。 搭建视频链接:https://pan.baidu.com/s/1_xYw-Mg3LPb5vqMuVgiD2A 提取码:qdl2 搭建软件及素材:链接:https://pan.baidu.com/s/1eIES_hDWNgr5lZD4akP9Jw 提取码:zrwu 最后是我根据搭建环境自带的图传源码修改裁剪后的图传源码(在最后免费下载),该源码是我将三四个源码文件裁剪修改合成一个源码文件,实现了图传功能,代码精简利于阅读和学习,先进行配置和运行的说明: (1)整个工程就是一个9kb的源码,名字叫websocket.ino文件,然后修改热点的名称和密码: (2)找一个CH340的USB转TTL电平的模块,某宝几块钱有卖的,按照下图接上模块: 右边的模块就是USB转TTL模块,主要是用来下载程序和串口调试,左边接ESP32模块,右边接电脑。 个人建议给cam模块供电压5V在第一张原理图左下角的端口供电,免得电源不足,不要接错了! UoR就是RX端 UOT是TX端 这两个端跟CH340的RX、TX交叉连接,如图示 将IO0端口与GND连接上之后就可以马上下载程序了: (3)用Arduino下载程序:(如果下载过程中出现失败,可以尝试按下模块的RST按键) (4)创建一个热点,名称和密码都与(1)的步骤相同,让ESP32的wifi能连上,我就用笔记本电脑创建了一个热点,然后打开串口Arduino监视器或者打开一个串口调试助手,打开电脑与CH340链接的串口,拔掉cam模块中IO0与GND链接的线(第三张图灰色的线,不断开就不能启动程序只能不断下载),再按下一次cam模块的RST按钮松开,如下图: 从图上看出,RST按下时,第一次程序运行不对,第二次运行正确了,打印出IP地址。右下角显示有设备连上热点。多试试几次就能成功的! (5)打开谷歌浏览器,输入网址串口打印的网址:172.25.139.2(个人具体IP看打印为准)就可以看到摄像头采集的视频流,相当流畅,如下图所示:(其他浏览器可能失败) 由于摄像前面的保护膜没有撕掉,所以有点模糊,视频还是很流畅的。 总结:该项目演示了用ESP32作为一个STA模式连上路由器或者笔记本热点,在同一个局域网环境下用浏览器登录ESP32的IP地址就可以收看ESP32摄像头采集下来的图像信息。后期会陆续发布根据此源码升级成视频监控小车、视频监控智能控制摄像头、视频监控系统和手机客户端图传、stm单片机图传接收、机器人视觉人脸签到系统、远程MQTT图传手机app接收、局域网javaweb显示图传、等等项目,敬请期待。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 35
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

积跬步、至千里

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值