pyqt 创建系统托盘

简介: pyqt 创建系统托盘

demo

import sys
from PyQt5.QtGui import QIcon
from PyQt5.QtWidgets import (QApplication, QDialog, QMessageBox, QPushButton,
                             QLabel, QCheckBox, QComboBox, QLineEdit, QSpinBox,
                             QMenu, QAction, QGridLayout, QHBoxLayout, QVBoxLayout,
                             QTextEdit,QGroupBox, QStyle, QSystemTrayIcon)
# import resource_rc
class SystemTrayDemo(QDialog):
    def __init__(self):
        super(SystemTrayDemo, self).__init__()
        # 设置窗口标题
        self.setWindowTitle('实战PyQt5: 演示应用最小化到托盘')
        #设置窗口尺寸
        self.resize(400, 300)
        self.sysIcon = QIcon(R"F:\work\免杀-小工具\loader\pdf-reader\pdf.png")
        self.setWindowIcon(self.sysIcon)
        self.initUi()
    def initUi(self):
        self.createMessageGroupBox()
        self.createTrayIcon()
        mainLayout = QVBoxLayout()
        mainLayout.addWidget(self.grpMessageBox)
        self.setLayout(mainLayout)
        #让托盘图标显示在系统托盘上
        self.trayIcon.show()
    #创建托盘图标
    def createTrayIcon(self):
        aRestore = QAction('恢复(&R)', self, triggered = self.showNormal)
        aQuit = QAction('退出(&Q)', self, triggered = QApplication.instance().quit)
        menu = QMenu(self)
        menu.addAction(aRestore)
        menu.addAction(aQuit)
        self.trayIcon = QSystemTrayIcon(self)
        self.trayIcon.setIcon(self.sysIcon)
        self.trayIcon.setContextMenu(menu)
        self.trayIcon.messageClicked.connect(self.messageClicked)
        self.trayIcon.activated.connect(self.iconActivated)
    #气球信息控制部分
    def createMessageGroupBox(self):
        self.grpMessageBox = QGroupBox('气球消息')
        #==== 消息类型控制部分 ====#
        typeLabel = QLabel('消息类型:')
        self.cmbType = QComboBox()
        self.cmbType.addItem('无类型', QSystemTrayIcon.NoIcon)
        self.cmbType.addItem(self.style().standardIcon(QStyle.SP_MessageBoxInformation), 
                             '信息', QSystemTrayIcon.Information)
        self.cmbType.addItem(self.style().standardIcon(QStyle.SP_MessageBoxWarning),
                             '警告', QSystemTrayIcon.Warning)
        self.cmbType.addItem(self.style().standardIcon(QStyle.SP_MessageBoxCritical),
                             '错误', QSystemTrayIcon.Critical)
        self.cmbType.setCurrentIndex(1)
        #==== 消息显示持续时间部分 ====#
        durationLabel = QLabel('持续时间:')
        self.durationSpinBox = QSpinBox()
        self.durationSpinBox.setRange(5, 60)    #时间范围
        self.durationSpinBox.setSuffix(' s')    #后缀,秒
        self.durationSpinBox.setValue(15)       # 缺省时间 15秒
        #spinbox 右边的警告提示信息
        durationWarningLabel = QLabel('(一些系统可能会忽略消息显示的持续时间控制)')
        durationWarningLabel.setIndent(10)
        #==== 消息标题栏控制 ====#
        titleLabel = QLabel('标题:')
        self.titleEdit = QLineEdit('不能连接到网络')
        #==== 消息编辑栏 ====#
        bodyLabel = QLabel('消息:')
        self.bodyEdit = QTextEdit()
        self.bodyEdit.setPlainText('不要问我, 老实说吧,我也不知道原因。'
                                   '\n请点击气球图标获得更多信息')
        #==== 显示消息按钮 ====#
        showMessageButton = QPushButton('显示消息')
        showMessageButton.setDefault(True)
        showMessageButton.clicked.connect(self.showMessage)
        #==== 将上述部件加入到一个网格布局中
        msgLayout = QGridLayout()
        msgLayout.addWidget(typeLabel, 0, 0)     #0行0列
        msgLayout.addWidget(self.cmbType, 0, 1, 1, 2)    #0行1列, 占1行2列
        msgLayout.addWidget(durationLabel, 1, 0)    #1行0列
        msgLayout.addWidget(self.durationSpinBox, 1, 1)     #1行1列
        msgLayout.addWidget(durationWarningLabel, 1, 2, 1, 3)  #1行2列, 占1行3列
        msgLayout.addWidget(titleLabel, 2, 0)     #2行0列
        msgLayout.addWidget(self.titleEdit, 2, 1, 1, 4)  #2行1列, 占1行4列
        msgLayout.addWidget(bodyLabel, 3, 0)     #3行0列
        msgLayout.addWidget(self.bodyEdit, 3, 1, 2, 4)  #3行1列, 占2行4列
        msgLayout.addWidget(showMessageButton, 5, 4) #5行4列
        msgLayout.setColumnStretch(3, 1)
        msgLayout.setRowStretch(4, 1)
        self.grpMessageBox.setLayout(msgLayout)
    #显示气球信息   
    def showMessage(self):
        #根据消息类型获取图标
        icon = QSystemTrayIcon.MessageIcon(self.cmbType.itemData(self.cmbType.currentIndex()))
        self.trayIcon.showMessage(self.titleEdit.text(),         #标题
                                  self.bodyEdit.toPlainText(),   #信息
                                  icon,                          #图标
                                  self.durationSpinBox.value() * 1000) #信息显示持续时间
    #关闭事件处理, 不关闭,只是隐藏,真正的关闭操作在托盘图标菜单里
    def closeEvent(self, event):
        if self.trayIcon.isVisible():
            QMessageBox.information(self, '系统托盘', 
                                    '程序将继续在系统托盘中运行,要终止本程序,\n'
                                    '请在系统托盘入口的上下文菜单中选择"退出"')
            self.hide()
            event.ignore()
    def messageClicked(self):
        QMessageBox.information(None, '系统托盘',
                                '对不起,我已经尽力了。'
                                '也许你应该试着问一个人?')
    def iconActivated(self, reason):
        if reason in (QSystemTrayIcon.DoubleClick, QSystemTrayIcon.MiddleClick):
            self.showMessage()
if __name__ == '__main__':
    app = QApplication(sys.argv)
    #如果系统不支持最小化到托盘
    if not QSystemTrayIcon.isSystemTrayAvailable():
        QMessageBox.critical(None, '系统托盘', '本系统不支持托盘功能')
        sys.exit(1)
    QApplication.setQuitOnLastWindowClosed(False)
    window = SystemTrayDemo()
    window.show()
    sys.exit(app.exec())
目录
相关文章
|
8天前
|
机器学习/深度学习 数据采集 供应链
使用Python实现智能食品安全追溯系统的深度学习模型
使用Python实现智能食品安全追溯系统的深度学习模型
30 4
|
2月前
|
机器学习/深度学习 传感器 存储
使用 Python 实现智能地震预警系统
使用 Python 实现智能地震预警系统
122 61
|
23天前
|
弹性计算 数据管理 数据库
从零开始构建员工管理系统:Python与SQLite3的完美结合
本文介绍如何使用Python和Tkinter构建一个图形界面的员工管理系统(EMS)。系统包括数据库设计、核心功能实现和图形用户界面创建。主要功能有查询、添加、删除员工信息及统计员工数量。通过本文,你将学会如何结合SQLite数据库进行数据管理,并使用Tkinter创建友好的用户界面。
从零开始构建员工管理系统:Python与SQLite3的完美结合
|
16天前
|
机器学习/深度学习 人工智能 算法
基于Python深度学习的【垃圾识别系统】实现~TensorFlow+人工智能+算法网络
垃圾识别分类系统。本系统采用Python作为主要编程语言,通过收集了5种常见的垃圾数据集('塑料', '玻璃', '纸张', '纸板', '金属'),然后基于TensorFlow搭建卷积神经网络算法模型,通过对图像数据集进行多轮迭代训练,最后得到一个识别精度较高的模型文件。然后使用Django搭建Web网页端可视化操作界面,实现用户在网页端上传一张垃圾图片识别其名称。
61 0
基于Python深度学习的【垃圾识别系统】实现~TensorFlow+人工智能+算法网络
|
16天前
|
机器学习/深度学习 人工智能 算法
基于深度学习的【蔬菜识别】系统实现~Python+人工智能+TensorFlow+算法模型
蔬菜识别系统,本系统使用Python作为主要编程语言,通过收集了8种常见的蔬菜图像数据集('土豆', '大白菜', '大葱', '莲藕', '菠菜', '西红柿', '韭菜', '黄瓜'),然后基于TensorFlow搭建卷积神经网络算法模型,通过多轮迭代训练最后得到一个识别精度较高的模型文件。在使用Django开发web网页端操作界面,实现用户上传一张蔬菜图片识别其名称。
59 0
基于深度学习的【蔬菜识别】系统实现~Python+人工智能+TensorFlow+算法模型
|
27天前
|
机器学习/深度学习 数据采集 存储
使用Python实现智能农业灌溉系统的深度学习模型
使用Python实现智能农业灌溉系统的深度学习模型
131 6
|
28天前
|
数据可视化 开发者 Python
Python GUI开发:Tkinter与PyQt的实战应用与对比分析
【10月更文挑战第26天】本文介绍了Python中两种常用的GUI工具包——Tkinter和PyQt。Tkinter内置于Python标准库,适合初学者快速上手,提供基本的GUI组件和方法。PyQt基于Qt库,功能强大且灵活,适用于创建复杂的GUI应用程序。通过实战示例和对比分析,帮助开发者选择合适的工具包以满足项目需求。
85 7
|
1月前
|
机器学习/深度学习 数据采集 算法框架/工具
使用Python实现智能生态系统监测与保护的深度学习模型
使用Python实现智能生态系统监测与保护的深度学习模型
86 4
|
2月前
|
机器学习/深度学习 API 计算机视觉
基于Python_opencv人脸录入、识别系统(应用dlib机器学习库)(下)
基于Python_opencv人脸录入、识别系统(应用dlib机器学习库)(下)
28 2
|
2月前
|
机器学习/深度学习 存储 算法
基于Python_opencv人脸录入、识别系统(应用dlib机器学习库)(上)
基于Python_opencv人脸录入、识别系统(应用dlib机器学习库)(上)
35 1