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())
相关文章
基于Python深度学习的【害虫识别】系统~卷积神经网络+TensorFlow+图像识别+人工智能
害虫识别系统,本系统使用Python作为主要开发语言,基于TensorFlow搭建卷积神经网络算法,并收集了12种常见的害虫种类数据集【"蚂蚁(ants)", "蜜蜂(bees)", "甲虫(beetle)", "毛虫(catterpillar)", "蚯蚓(earthworms)", "蜚蠊(earwig)", "蚱蜢(grasshopper)", "飞蛾(moth)", "鼻涕虫(slug)", "蜗牛(snail)", "黄蜂(wasp)", "象鼻虫(weevil)"】 再使用通过搭建的算法模型对数据集进行训练得到一个识别精度较高的模型,然后保存为为本地h5格式文件。最后使用Djan
46 1
基于Python深度学习的【害虫识别】系统~卷积神经网络+TensorFlow+图像识别+人工智能
解锁文档管理系统高效检索奥秘:Python 哈希表算法探究
在数字化时代,文档管理系统犹如知识宝库,支撑各行各业高效运转。哈希表作为核心数据结构,通过哈希函数将数据映射为固定长度的哈希值,实现快速查找与定位。本文聚焦哈希表在文档管理中的应用,以Python代码示例展示其高效检索特性,并探讨哈希冲突解决策略,助力构建智能化文档管理系统。
基于Python深度学习的【蘑菇识别】系统~卷积神经网络+TensorFlow+图像识别+人工智能
蘑菇识别系统,本系统使用Python作为主要开发语言,基于TensorFlow搭建卷积神经网络算法,并收集了9种常见的蘑菇种类数据集【"香菇(Agaricus)", "毒鹅膏菌(Amanita)", "牛肝菌(Boletus)", "网状菌(Cortinarius)", "毒镰孢(Entoloma)", "湿孢菌(Hygrocybe)", "乳菇(Lactarius)", "红菇(Russula)", "松茸(Suillus)"】 再使用通过搭建的算法模型对数据集进行训练得到一个识别精度较高的模型,然后保存为为本地h5格式文件。最后使用Django框架搭建了一个Web网页平台可视化操作界面,
97 11
基于Python深度学习的【蘑菇识别】系统~卷积神经网络+TensorFlow+图像识别+人工智能
基于Python深度学习果蔬识别系统实现
本项目基于Python和TensorFlow,使用ResNet卷积神经网络模型,对12种常见果蔬(如土豆、苹果等)的图像数据集进行训练,构建了一个高精度的果蔬识别系统。系统通过Django框架搭建Web端可视化界面,用户可上传图片并自动识别果蔬种类。该项目旨在提高农业生产效率,广泛应用于食品安全、智能农业等领域。CNN凭借其强大的特征提取能力,在图像分类任务中表现出色,为实现高效的自动化果蔬识别提供了技术支持。
基于Python深度学习果蔬识别系统实现
基于Python深度学习的眼疾识别系统实现~人工智能+卷积网络算法
眼疾识别系统,本系统使用Python作为主要开发语言,基于TensorFlow搭建卷积神经网络算法,并收集了4种常见的眼疾图像数据集(白内障、糖尿病性视网膜病变、青光眼和正常眼睛) 再使用通过搭建的算法模型对数据集进行训练得到一个识别精度较高的模型,然后保存为为本地h5格式文件。最后使用Django框架搭建了一个Web网页平台可视化操作界面,实现用户上传一张眼疾图片识别其名称。
214 5
基于Python深度学习的眼疾识别系统实现~人工智能+卷积网络算法
|
2月前
|
[oeasy]python057_如何删除print函数_dunder_builtins_系统内建模块
本文介绍了如何删除Python中的`print`函数,并探讨了系统内建模块`__builtins__`的作用。主要内容包括: 1. **回忆上次内容**:上次提到使用下划线避免命名冲突。 2. **双下划线变量**:解释了双下划线(如`__name__`、`__doc__`、`__builtins__`)是系统定义的标识符,具有特殊含义。
40 3
Python 语言结合 Flask 框架来实现一个基础的代购商品管理、用户下单等功能的简易系统
这是一个使用 Python 和 Flask 框架实现的简易代购系统示例,涵盖商品管理、用户注册登录、订单创建及查看等功能。通过 SQLAlchemy 进行数据库操作,支持添加商品、展示详情、库存管理等。用户可注册登录并下单,系统会检查库存并记录订单。此代码仅为参考,实际应用需进一步完善,如增强安全性、集成支付接口、优化界面等。
局域网屏幕监控系统中的Python数据结构与算法实现
局域网屏幕监控系统用于实时捕获和监控局域网内多台设备的屏幕内容。本文介绍了一种基于Python双端队列(Deque)实现的滑动窗口数据缓存机制,以处理连续的屏幕帧数据流。通过固定长度的窗口,高效增删数据,确保低延迟显示和存储。该算法适用于数据压缩、异常检测等场景,保证系统在高负载下稳定运行。 本文转载自:https://www.vipshare.com
139 66
文件管理系统中基于 Python 语言的二叉树查找算法探秘
在数字化时代,文件管理系统至关重要。本文探讨了二叉树查找算法在文件管理中的应用,并通过Python代码展示了其实现过程。二叉树是一种非线性数据结构,每个节点最多有两个子节点。通过文件名的字典序构建和查找二叉树,能高效地管理和检索文件。相较于顺序查找,二叉树查找每次比较可排除一半子树,极大提升了查找效率,尤其适用于海量文件管理。Python代码示例包括定义节点类、插入和查找函数,展示了如何快速定位目标文件。二叉树查找算法为文件管理系统的优化提供了有效途径。
75 5
猫狗宠物识别系统Python+TensorFlow+人工智能+深度学习+卷积网络算法
宠物识别系统使用Python和TensorFlow搭建卷积神经网络,基于37种常见猫狗数据集训练高精度模型,并保存为h5格式。通过Django框架搭建Web平台,用户上传宠物图片即可识别其名称,提供便捷的宠物识别服务。
435 55

热门文章

最新文章

目录
目录
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等