118.Python——PyQt窗体上显示监控视频画面

liftword1周前 (04-22)技术文章8

在做计算机视觉项目时,经常需要打开和显示监控视频画面,对画面进行分析处理。使用OpenCV打开摄像头显示视频画面,视频可以参看:1.3 OpenCV打开本地摄像头并显示视频画面

本文主要实现在PyQt窗体上显示监控视频画面。视频可以参看:8.2 Python-PyQt:窗体上显示视频图像

一、使用Qt Designer创建窗体

窗体主要两个元素:一个 Label 用来显示图像,一个Push Button 用来打开视频头。

窗体自适应布局,保存窗体文件:yolodet.ui,XML格式保存的。

要在Python中使用这个窗体文件,还需要把yolodet.ui文件编译生成.py文件。在vscode中配置好PyQt后,打开ui文件的右键菜单,很方便把ui文件转换成py文件。

二、实现代码

import sys
import cv2
from PyQt5 import QtCore,QtGui,QtWidgets
from Ui_yolodet import Ui_MainWindow

class MainWindow(QtWidgets.QMainWindow,Ui_MainWindow):
    def __init__(self):
        super().__init__()
        self.setupUi(self)
        
        self.btnopen.clicked.connect(self.Open)
        
    def Open(self):
        cap=cv2.VideoCapture(0)
        while cap.isOpened():
            ret,frame=cap.read()
             #img=QtGui.QImage(frame.data,frame.shape[1],frame.shape[0],QtGui.QImage.Format_BGR888)    
            #重载修复图像显示变形问题      
            img = QtGui.QImage(frame.data, frame.shape[1], frame.shape[0], frame.shape[1] * 3,QtGui.QImage.Format_BGR888)
            
            #设置label高度和宽度
            self.lblimg.setFixedSize(frame.shape[1],frame.shape[0])
                        
            self.lblimg.setPixmap(QtGui.QPixmap.fromImage(img))
            self.lblimg.setScaledContents(True) #自适应大小
            
            QtWidgets.QApplication.processEvents()
        
if __name__ == '__main__':
    app=QtWidgets.QApplication(sys.argv)
    mywin=MainWindow()
    mywin.setObjectName("Yolo3 Detect")
    mywin.show()
    sys.exit(app.exec_())
    

说明:

1、正常情况,使用下面代码来生成QImage,可以显示正常图像,但有时会发现图像会扭曲变形。

img=QtGui.QImage(frame.data,frame.shape[1],frame.shape[0],QtGui.QImage.Format_BGR888)

解决办法:改成如下代码。原因:QImage每行是按照sizeof(int)对齐的,如果不明确指定最后一个参数,即行字节数,则图像会歪斜。增加第三个参数:frame.shape[1] * 3,

img = QtGui.QImage(frame.data, frame.shape[1], frame.shape[0], frame.shape[1] * 3,QtGui.QImage.Format_BGR888)

2、根据图像的大小来设定Label的大小,以防止视频画面变形

#设置label高度和宽度
self.lblimg.setFixedSize(frame.shape[1],frame.shape[0])

三、运行效果

相关文章

Qt for Python—Qt Designer 概览

前言本系列第三篇文章(Qt for Python学习笔记—应用程序初探 )、第四篇文章(Qt for Python学习笔记—应用程序再探 )中均是使用纯代码方式来开发 PySide6 GUI 应用程序...

PySide:基于 Qt 框架的 Python 高级 UI 库

PySide 是 Python 的官方 Qt 库绑定,由 Qt for Python 提供支持。它允许开发者使用 Python 编写基于 Qt 框架的图形用户界面(GUI)应用。作为一个功能强大的跨平...

使用PySide2做窗体,到底是怎么个事?看这个能不能搞懂

PySide2 是 Qt 框架的 Python 绑定,允许你使用 Python 创建功能强大的跨平台 GUI 应用程序。PySide2 的基本使用方法:安装 PySide2pip install Py...

Python Qt GUI设计:将UI文件转换Python文件三种妙招(基础篇—2)

在开始本文之前提醒各位朋友,Python记得安装PyQt5库文件,Python语言功能很强,但是Python自带的GUI开发库Tkinter功能很弱,难以开发出专业的GUI。好在Python语言的开放...

进入Python的世界02外篇-Pycharm配置Pyqt6

为什么这样配置,要开发带UI的python也只能这样了,安装过程如下:一 安装工具打开终端:pip install PyQt6 PyQt6-tools二 打开设置并汉化点击plugin,安装汉化插件,...