Python+PyQt5自制监控小工具
作者:Sir 时间:2023-09-14 10:52:31
本篇文章通过使用python实现对计算机摄像头的调用从而实现摄像监控的功能。
利用opencv的图像处理功能可以轻松对计算机摄像头的调用实现实时图像的采集效果。
最终将图片进行保存后生成监控的历史视频记录。
pip install PyQt5
pip install python-opencv
若是没有安装相关的模块,可以选择上述pip的方式进行安装。
接下来我们将需要的python模块导入到代码块中。
# It's just an alias for the cv2 module.
import cv2 as cv_
# It's importing all the classes from the QtGui module.
from PyQt5.QtGui import *
# It's importing all the classes from the QtCore module.
from PyQt5.QtCore import *
# It's importing all the classes from the QtWidgets module.
from PyQt5.QtWidgets import *
# It's importing the sys module.
import sys
# It's importing the os module.
import os
# It's importing the time module.
import time
# It's importing the traceback module.
import traceback
创建名称为CameraUI的python类,开发监控工具相关的页面组件及布局。
将控件按钮等对应的槽函数也放到该类中。
class CameraUI(QWidget):
def __init__(self):
super(CameraUI, self).__init__()
self.init_ui()
def init_ui(self):
self.setWindowTitle('本地监控工具 公众号:Python 集中营')
self.setWindowIcon(QIcon('ico.png'))
self.resize(600, 400)
self.label_view = QLabel()
self.image_path = QLineEdit()
self.image_path.setReadOnly(True)
self.image_path.setPlaceholderText('视频流图片保存地址')
self.image_path_btn = QPushButton()
self.image_path_btn.setText('打开')
self.image_path_btn.clicked.connect(self.image_path_btn_clk)
self.video_path = QLineEdit()
self.video_path.setReadOnly(True)
self.video_path.setPlaceholderText('监控视频保存地址')
self.video_path_btn = QPushButton()
self.video_path_btn.setText('打开')
self.video_path_btn.clicked.connect(self.video_path_btn_clk)
self.start_listen_btn = QPushButton()
self.start_listen_btn.setText('开启监控')
self.start_listen_btn.clicked.connect(self.start_listen_btn_clk)
self.brower = QTextBrowser()
self.brower.setReadOnly(True)
self.brower.setFont(QFont('宋体', 8))
self.brower.setPlaceholderText('日志处理过程区域...')
self.brower.ensureCursorVisible()
hbox = QHBoxLayout()
vbox_left = QVBoxLayout()
vbox_right = QVBoxLayout()
vbox_left.addWidget(self.label_view)
vbox_right_grid1 = QGridLayout()
vbox_right_grid1.addWidget(self.image_path, 0, 0, 1, 2)
vbox_right_grid1.addWidget(self.image_path_btn, 0, 2, 1, 1)
vbox_right_grid1.addWidget(self.video_path, 1, 0, 1, 2)
vbox_right_grid1.addWidget(self.video_path_btn, 1, 2, 1, 1)
vbox_right_grid2 = QGridLayout()
vbox_right_grid2.addWidget(self.brower, 0, 0, 1, 3)
vbox_right_grid2.addWidget(self.start_listen_btn, 1, 0, 1, 3)
vbox_right.addLayout(vbox_right_grid1)
vbox_right.addLayout(vbox_right_grid2)
hbox.addLayout(vbox_left)
hbox.addLayout(vbox_right)
self.listen_thread = ListenWorkThread(self)
self.listen_thread.message.connect(self.show_message)
self.listen_thread.finished.connect(lambda: self.start_listen_btn.setEnabled(True))
self.setLayout(hbox)
def show_message(self, text):
cursor = self.brower.textCursor()
cursor.movePosition(QTextCursor.End)
self.brower.append(text)
self.brower.setTextCursor(cursor)
self.brower.ensureCursorVisible()
def image_path_btn_clk(self):
dir = QFileDialog.getExistingDirectory(self, "选择文件夹", os.getcwd())
self.image_path.setText(dir)
def video_path_btn_clk(self):
dir = QFileDialog.getExistingDirectory(self, "选择文件夹", os.getcwd())
self.video_path.setText(dir)
def start_listen_btn_clk(self):
self.listen_thread.start()
开发一个ListenWorkThread类并且继承自QThread的子线程。
将该线程作为业务类实现调用本地摄像头完成监控的效果。
class ListenWorkThread(QThread):
message = pyqtSignal(str)
finished = pyqtSignal(bool)
def __init__(self, parent=None):
super(ListenWorkThread, self).__init__(parent)
self.parent = parent
self.working = True
def __del__(self):
self.working = False
def run(self):
try:
image_path = self.parent.image_path.text()
video_path = self.parent.video_path.text()
if image_path.strip() == '' or video_path.strip() == '':
self.message.emit('相关路径设置不能为空,请检查设置!')
return
self.cap = cv_.VideoCapture(0)
self.cap.set(3, 300)
self.cap.set(4, 400)
if self.cap.isOpened():
self.message.emit('摄像头已成功打开!')
n = 0
self.message.emit('正在进行视频 监控中....')
start_time = time.clock()
while True:
ret, img = self.cap.read()
if os.path.exists(os.path.join(image_path, str(n) + '.jpg')):
os.remove(os.path.join(image_path, str(n) + '.jpg'))
self.save_image(img, str(n), image_path)
time.sleep(0.1)
pixmap_ = QPixmap(os.path.join(image_path, str(n) + '.jpg'))
self.parent.label_view.setPixmap(pixmap_)
n = n + 1
self.finished.emit(True)
except Exception as e:
traceback.print_exc()
self.message.emit('程序运行错误,请检查参数是否设置正确!')
self.finished.emit(True)
def save_image(self, image=None, file_name=None, image_path=None):
if image is not None:
cv_.imwrite(os.path.join(image_path, file_name + '.jpg'), image)
以上整个业务子线程的逻辑就开发完成了,然后使用python模块的main函数调用。
将整个程序的运行加入到主体循环当中。
if __name__ == '__main__':
app = QApplication(sys.argv)
main = CameraUI()
main.show()
sys.exit(app.exec_())
来源:https://mp.weixin.qq.com/s/v9wvqLCyM-kLPBS6-W7kCw
标签:Python,PyQt5,监控
0
投稿
猜你喜欢
perl的格式化输出及chomp的重要性分析
2022-03-22 11:03:00
解决MySQL安装重装时出现could not start the service mysql error:0问题的方法
2024-01-23 01:17:00
python 爬虫基本使用——统计杭电oj题目正确率并排序
2021-11-25 17:16:35
可以随便改别人的网页的代码
2008-03-25 12:54:00
小程序scroll-view组件实现滚动的示例代码
2024-05-11 09:31:42
python3.8+django2+celery5.2.7环境准备(python测试开发django)
2022-08-19 06:17:14
利用python实现可视化大屏
2023-08-17 17:29:17
推荐19个很有用的 JavaScript 库
2011-05-14 16:33:00
Python图像处理库PIL的ImageEnhance模块使用介绍
2023-05-14 17:29:51
在微信小程序中获取用户位置的详细过程
2024-04-29 13:43:02
详解MySQL 8.0 之不可见索引
2024-01-22 17:41:46
python3格式化字符串 f-string的高级用法(推荐)
2023-04-13 00:56:55
详解Python中range()与xrange()的区别
2021-09-06 12:32:14
Go语言基础结构体用法及示例详解
2024-04-25 15:11:34
Google开源的Python格式化工具YAPF的安装和使用教程
2023-02-02 12:32:16
详解Hadoop 运行环境搭建过程
2022-08-25 13:50:58
Vue中qs插件的使用详解
2023-07-02 17:07:06
ASP存储过程开发应用详解第1/2页
2011-04-07 11:16:00
MySQL中的count(*) 和 count(1) 区别性能对比分析
2024-01-24 03:12:51
SQL SERVER EXPRESS 常见问题及解决办法
2008-09-13 19:07:00