在yolo的一个主界面中做一个摄像头检测的功能,該怎末做
#ui界面
from PyQt5 import QtCore, QtGui, QtWidgets
class Ui_MainWindow(object):
def setupUi(self, MainWindow):
MainWindow.setObjectName("MainWindow")
MainWindow.resize(698, 403)
self.centralwidget = QtWidgets.QWidget(MainWindow)
self.centralwidget.setObjectName("centralwidget")
self.input = QtWidgets.QLabel(self.centralwidget)
self.input.setGeometry(QtCore.QRect(10, 20, 331, 281))
self.input.setScaledContents(True)
self.input.setAlignment(QtCore.Qt.AlignCenter)
self.input.setObjectName("input")
self.output = QtWidgets.QLabel(self.centralwidget)
self.output.setGeometry(QtCore.QRect(360, 20, 331, 281))
self.output.setScaledContents(True)
self.output.setAlignment(QtCore.Qt.AlignCenter)
self.output.setObjectName("output")
self.line = QtWidgets.QFrame(self.centralwidget)
self.line.setGeometry(QtCore.QRect(340, 10, 16, 301))
self.line.setFrameShape(QtWidgets.QFrame.VLine)
self.line.setFrameShadow(QtWidgets.QFrame.Sunken)
self.line.setObjectName("line")
self.images = QtWidgets.QPushButton(self.centralwidget)
self.images.setEnabled(True)
self.images.setGeometry(QtCore.QRect(20, 340, 201, 41))
self.images.setObjectName("images")
self.videos = QtWidgets.QPushButton(self.centralwidget)
self.videos.setEnabled(True)
self.videos.setGeometry(QtCore.QRect(250, 340, 201, 41))
self.videos.setObjectName("videos")
self.camera = QtWidgets.QPushButton(self.centralwidget)
self.camera.setEnabled(True)
self.camera.setGeometry(QtCore.QRect(480, 340, 201, 41))
self.camera.setObjectName("camera")
MainWindow.setCentralWidget(self.centralwidget)
self.statusbar = QtWidgets.QStatusBar(MainWindow)
self.statusbar.setObjectName("statusbar")
MainWindow.setStatusBar(self.statusbar)
self.retranslateUi(MainWindow)
QtCore.QMetaObject.connectSlotsByName(MainWindow)
def retranslateUi(self, MainWindow):
_translate = QtCore.QCoreApplication.translate
MainWindow.setWindowTitle(_translate("MainWindow", "MainWindow"))
self.input.setText(_translate("MainWindow", "显示原始图片"))
self.output.setText(_translate("MainWindow", "检测结果"))
self.images.setText(_translate("MainWindow", "图片检测"))
self.videos.setText(_translate("MainWindow", "视频检测"))
self.camera.setText(_translate("MainWindow", "摄像头检测"))
import cv2
import sys
from PyQt5 import QtCore
from PyQt5.QtWidgets import QMainWindow,QApplication,QFileDialog
from PyQt5.QtGui import QPixmap, QImage
from PyQt5.QtCore import QTimer
from 交通头盔规范检测 import Ui_MainWindow
import torch
def convert2QImage(img):
height, width, channel = img.shape
return QImage(img, width, height, width * channel, QImage.Format_RGB888)
class MainWindow(QMainWindow, Ui_MainWindow):
def __init__(self):
super(MainWindow, self).__init__()
self.setupUi(self)
self.model = torch.hub.load("./", "custom", path="runs/train/exp9/weights/best.pt", source="local")
self.timer = QTimer()
self.timer.setInterval(100) # 设置间隔为 100 毫秒,即 0.1 秒
self.video = None
self.bind_slots()
def images_pred(self, file_path):
results = self.model(file_path)
image = results.render()[0]
return convert2QImage(image)
def open_image(self):
print("点击了检测图片!")
file_path = QFileDialog.getOpenFileName(None, "Open Image", r"E:\yolov5-master\VOCdevkit\images\train", filter="*.jpg;*.png;*.jpeg")
if file_path[0]:
file_path=file_path[0]
qimage=self.images_pred(file_path)
self.input.setPixmap(QPixmap(file_path))
self.output.setPixmap(QPixmap.fromImage(qimage))
def video_pred(self):
ret, frame = self.video.read()
if not ret:
self.timer.stop()
else:
frame = cv2.cvtColor(frame, cv2.COLOR_BGR2RGB)
self.input.setPixmap(QPixmap.fromImage(convert2QImage(frame)))
results = self.model(frame)
image = results.render()[0]
self.output.setPixmap(QPixmap.fromImage(convert2QImage(image)))
def open_video(self):
print("点击了检测视频!")
self.timer.stop()
file_path = QFileDialog.getOpenFileName(None, r"C:\Users\32147\Desktop\03.mp4", filter="*.mp4")
if file_path[0]:
file_path = file_path[0]
self.video = cv2.VideoCapture(file_path)
self.timer.start()
def bind_slots(self):
self.images.clicked.connect(self.open_image)
self.videos.clicked.connect(self.open_video)
self.timer.timeout.connect(self.video_pred)
if __name__=="__main__":
QtCore.QCoreApplication.setAttribute(QtCore.Qt.AA_EnableHighDpiScaling)
# 使用 QtCore.Qt.AA_EnableHighDpiScaling 常量设置了应用程序的属性,告诉 Qt 应用程序启用高DPI缩放。
app= QApplication(sys.argv)
window=MainWindow()
window.show()
app.exec()