使用QT的QML实时显示海康威视网络摄像头的视频数据

需求背景:

开发的监控软件中有个监控页面需要实时显示网络摄像头的数据,整个监控软件是基于QT的QML语言开发的。在QML中播放视频使用MediaPlayer组件就可以,但网上看到的一些都是播放录制好的视频文件,对于实时播放摄像头数据介绍的比较少。

开发环境:

Debian11.3

Qt 5.15

海康威视网络摄像机视频流地址

若要从网络摄像头实时获取数据,需要知道摄像头的视频流地址,仅此而已。这里需要获取rtsp协议的地址,它是一种实时数据流传输协议。地址如下:

格式:

rtsp://用户名:密码@ip地址:554/Streaming/Channels/101
样例:

取第1个通道的主码流预览

rtsp://admin:123456789@10.10.6.100:554/Streaming/Channels/101

取第1个通道的子码流预览

rtsp://admin:123456789@10.10.6.100:554/Streaming/Channels/102

取第12个通道的主码流预览

rtsp://admin:123456789@10.10.6.100:554/Streaming/Channels/1201

QML代码实现

bash 复制代码
import QtQuick 2.12
import QtQuick.Controls 2.5
import QtMultimedia 5.0

Rectangle {
    x: 10
    y:10
    width: 1200
    height: 800
    color: "white"
    
    MediaPlayer {
        id: player
        autoPlay: true
        //source: "file:///home/test/test_camera.mp4" //播放本地视频文件
        source: "rtsp://admin:123456789@10.10.6.100:554/Streaming/Channels/101" //播放摄像头实时数据
        onError: {
            console.log(errorString)
        }
    }
    
    VideoOutput {
        anchors.fill: parent
        source: player
    }
}

啰嗦一句

从上面的QML代码看,播放网络实时视频流实际和播放本地的视频文件一样,都是把URL赋值给source属性。差异只是不同的数据源需要填写正确的视频流地址。

相关推荐
Hello 0 14 小时前
视频号直播视频录制
python·音视频·流媒体·直播视频录制
J***Q2926 小时前
后端服务网格安全,mTLS加密通信
网络·安全
菜鸟-017 小时前
上位机---QT
开发语言·qt
864记忆8 小时前
Qt 对 JSON和XML文件的操作详解
xml·qt·json
Bug制造者_Guo8 小时前
QML BorderImage的使用
qt
wa的一声哭了9 小时前
WeBASE管理平台部署-WeBASE-Web
linux·前端·网络·arm开发·spring boot·架构·区块链
YJlio9 小时前
进程和诊断工具学习笔记(8.19):Hyper-V 来宾调试与符号配置 —— 在虚拟化场景下用 LiveKd 抓现场
网络·笔记·学习
青果网络_xz9 小时前
全球代理IP是什么?它和普通代理有什么区别?
网络·网络协议·tcp/ip
枫叶丹410 小时前
【Qt开发】Qt窗口(二) -> QToolBar工具栏
开发语言·数据库·c++·qt
ACP广源盛1392462567310 小时前
GSV2201S(1201S)@ACP#支持嵌入式 MCU 的 DisplayPort 1.4 到 HDMI 2.0 转换器
单片机·嵌入式硬件·电脑·音视频