使用node-red+opencv+mqtt实现相机图像云端查看

一、本机环境

jetson nano ubuntu20.04

python 3.12

复制代码
pip install opencv-python paho-mqtt

安装并启动mqtt broker

复制代码
# 安装 Mosquitto
sudo apt update
sudo apt install mosquitto mosquitto-clients -y

# 启动并设置开机自启
sudo systemctl enable mosquitto
sudo systemctl start mosquitto

# 验证是否运行
sudo systemctl status mosquitto

二、制作方法

mqtt broker启动成功后,执行这个python脚本

复制代码
# script.py
import cv2
import paho.mqtt.client as mqtt
import base64
import time

# MQTT 配置
MQTT_BROKER = "localhost"
MQTT_PORT = 1883
MQTT_TOPIC = "camera/image"

# 打开摄像头
cap = cv2.VideoCapture(0)
if not cap.isOpened():
    print("无法打开摄像头")
    exit()

# 指定 callback_api_version
client = mqtt.Client(callback_api_version=mqtt.CallbackAPIVersion.VERSION2)

# 连接 MQTT
try:
    client.connect(MQTT_BROKER, MQTT_PORT, 60)
    client.loop_start()  # 启动后台线程处理网络通信
except Exception as e:
    print(f"MQTT 连接失败: {e}")
    exit()

print("摄像头启动,开始发布图像...")

try:
    while True:
        ret, frame = cap.read()
        if not ret:
            print("摄像头读取失败")
            break

        # 缩放图像(减小带宽)
        frame = cv2.resize(frame, (640, 480))

        # 编码为 JPEG
        _, buffer = cv2.imencode('.jpg', frame, [cv2.IMWRITE_JPEG_QUALITY, 80])
        
        # 转为 Base64 字符串
        jpg_as_text = base64.b64encode(buffer).decode('utf-8')

        # 发布到 MQTT
        result = client.publish(MQTT_TOPIC, jpg_as_text, qos=0)
        
        # 可选:检查是否发布成功
        # if result.rc != mqtt.MQTT_ERR_SUCCESS:
        #     print("发布失败")

        time.sleep(0.1)  # 控制帧率(约10fps)

except KeyboardInterrupt:
    print("\n停止发布")

finally:
    cap.release()
    client.loop_stop()  # 停止后台线程
    client.disconnect()

在node-red端则需要两个节点,一个是mqtt_in 和 ui_template节点,mqtt_in节点需要配置与python端一致的话题和端口

ui_template 则需要输入以下代码:

复制代码
<div style="text-align: center;">
  <img ng-src="data:image/jpeg;base64,{{msg.payload}}" 
       style="max-width: 100%; height: auto; border: 1px solid #ccc; border-radius: 8px;"
       alt="Camera Stream">
  <p style="font-size: 12px; color: #666;">Last update: {{ $flow.lastUpdate }}</p>
</div>

<script>
// 更新时间戳
(function(scope) {
    scope.$watch('msg', function(msg) {
        if (msg) {
            scope.$flow.lastUpdate = new Date().toLocaleTimeString();
        }
    });
})(scope);
</script>

部署后,mqtt_in连接上服务器就对了

然后输入 127.0.0.1:1880/ui 进入ui界面,即可查看相机图像,也可通过远程ip访问查看

可以调整python端控制帧率的time.sleep函数,达到实时传输

相关推荐
IT_陈寒1 天前
React 18新特性全解析:这5个隐藏API让你的性能飙升200%!
前端·人工智能·后端
IT_陈寒2 天前
React性能优化:这5个被90%开发者忽略的Hooks用法,让你的应用快3倍
前端·人工智能·后端
飞哥数智坊2 天前
从能用到好看:CodeBuddy+uniapp小程序生成实录(续篇)
人工智能·ai编程
CareyWYR2 天前
每周AI论文速递(250915-250919)
人工智能
倔强青铜三2 天前
苦练Python第48天:类的私有变量“防身术”,把秘密藏进类里!
人工智能·python·面试
倔强青铜三2 天前
苦练Python第47天:一文吃透继承与多继承,MRO教你不再踩坑
人工智能·python·面试
倔强青铜三2 天前
为什么Python程序员必须学习Pydantic?从数据验证到API开发的革命性工具
人工智能·python·面试
Codebee2 天前
魔改 OneCode-RAD 实现 LLM 编程:打造自然语言驱动的低代码助手
前端·人工智能·前端框架
IT_陈寒2 天前
SpringBoot 3.2新特性实战:这5个隐藏技巧让你的启动速度提升50%
前端·人工智能·后端
后端小肥肠2 天前
卷出新高度!字节Seedream 4.0模型真实体验:它真的解决了AI绘画的核心痛点?
人工智能·aigc