时间。睡觉()和后台窗口PyQt5

2024-04-26 07:05:14 发布

您现在位置:Python中文网/ 问答频道 /正文


鉴于此,我从PyQt5模块开始,我仍然在慢慢理解它背后的逻辑。也就是说,我遇到了一个我找不到答案的问题,我希望你能帮助我。
我有这个剧本:

import sys, socket, time
from PyQt5.QtWidgets import *
from PyQt5.QtCore import *
from PyQt5.QtGui import *
from io import BytesIO as by

class loadGame(QWidget):
    wLoadDisplay = 768
    hLoadDisplay = 576
    wLoadBar = 650
    hLoadBar = 40

    pbarCSS = """
    QProgressBar
    {
        font-size: 20px;
        font-weight: bold;
        background-color: #FFF;
        border: 4px solid #000;
        text-align: center;
    }
    QProgressBar::chunk
    {
        background-color: #FF0000;
        width: 1px;
    }
    """

    labelCSS = """
    QLabel
    {
        font-size: 20px;
        font-weight: bold;
        background-color: #FFF;
        border: 4px solid #000;
    }
    """

    fileResource = []
    imgResource = []
    vidResource = []
    audResource = []
    diaResource = []
    txtResource = []

    internetConnection = False

    def __init__(self, *args, **kwargs):
        QWidget.__init__(self, *args, **kwargs)

        self.outputFile = by()

        self.pbar = QProgressBar(self)
        self.pbar.setGeometry((self.wLoadDisplay / 2 - self.wLoadBar / 2), (self.hLoadDisplay / 2 - self.hLoadBar * 2),
                              self.wLoadBar, self.hLoadBar)
        self.pbar.setFormat("%v/%m")
        self.pbar.setValue(0)
        self.pbar.setStyleSheet(self.pbarCSS)

        self.label = QLabel(self)
        self.label.setGeometry((self.wLoadDisplay / 2 - self.wLoadBar / 2), (self.hLoadDisplay / 2),
                               self.wLoadBar, self.hLoadBar)
        self.label.setAlignment(Qt.AlignCenter | Qt.AlignVCenter)
        self.label.setStyleSheet(self.labelCSS)

        self.setGeometry(0, 0, self.wLoadDisplay, self.hLoadDisplay)
        oImage = QImage("bgloading.png")
        sImage = oImage.scaled(QSize(self.wLoadDisplay, self.hLoadDisplay))
        palette = QPalette()
        palette.setBrush(10, QBrush(sImage))
        self.setPalette(palette)

        qtRectangle = self.frameGeometry()
        centerPoint = QDesktopWidget().availableGeometry().center()
        qtRectangle.moveCenter(centerPoint)
        self.move(qtRectangle.topLeft())

        self.run()

    def run(self):
        self.checkConnection()
        if self.internetConnection:
            self.checkUpdate()
        else:
            pass

    def checkConnection(self):
        self.objectChange("Check Internet Connection", 1)
        try:
            host = socket.gethostbyname("www.google.it")
            s = socket.create_connection((host, 80), 2)
            self.internetConnection = True
        except:
            pass

        self.count()
        self.reset()

    def checkUpdate(self):
        pass

    def objectChange(self, object, n):
        self.label.setText(object)
        self.pbar.setMaximum(n)

    def count(self):
        self.pbar.setValue(self.pbar.value() + 1)

    def reset(self):
        time.sleep(2)
        self.pbar.setMaximum(0)
        self.pbar.setValue(0)
        self.label.setText("...")

if __name__ == '__main__':
    loadDisplay = QApplication(sys.argv)
    load = loadGame()
    load.show()
    sys.exit(loadDisplay.exec_())

在网上搜索时,我发现问题与“时间。睡觉(2) “,也就是说,指令会阻止两秒后才会出现的窗口。
事实上,在重置之前,我想花一到两秒钟来显示条的完成情况,然后再转到“def run(self)”中包含的下一条语句。
那么,有没有一种方法可以在不使用时间模块的情况下暂停呢?我不知道,也许和Q时间?我再说一遍,我对PyQt5还不太了解,所以我不知道QTimer是否能做同样的事情。
如果QTimer做不到,还有其他的方法吗?我希望避免使用PyQt5的“线程”,因为我读到有可能这样做,但我希望避免只将其用于计时器模块。


我只添加了一个问题,以避免打开另一个问题并发布相同的脚本。
在脚本中,窗口背景是通过“oImage=QImage(”bgloading.png网站“)”等
不过,如果文件本身被发现是黑色的,那文件本身就是黑色的。所以,如果有任何错误(错误的名称或丢失的文件),可以设置一个背景,例如,白色?
因为当窗口加载“this error”时,不会引发异常,脚本将继续。




编辑:我编辑了已发布的脚本,使其只包含PyQt5部分,所以您可以尝试一下。显然只有图像丢失,可以用任何图像替换。
不幸的是我忘了写那部分self.set_显示()”的报告显示,一旦PyQt5执行的工作被终止,它将被关闭(这仍然是丢失的,因为使用Pycharm我将关闭从程序执行脚本)。脚本将继续调用“self.set_显示()”功能。在

编辑2:我试着,按照建议,替换“时间。睡觉(2) “,但我得到了同样的结果。问题是,如果我不设置暂停,窗口会正常显示,但重置发生得太快,用户看不到进度条的填充。如果我把时间。睡觉(2) “或者,建议的解决方案是,窗口仅在暂停之后出现,即重置已经发生时出现。在


Tags: 模块fromimportself脚本def时间label
1条回答
网友
1楼 · 发布于 2024-04-26 07:05:14

一个与time.sleep(2)相当且对PyQt友好的表达式如下:

loop = QEventLoop()
QTimer.singleShot(2000, loop.quit)
loop.exec_()

这个问题是因为您在暂停之后显示小部件,您必须在调用run()之前执行,另一个错误是使用QImage,对于小部件的问题,您必须使用QPixmap。在

如果文件不存在,QPixmap将为空,要知道是否存在,应使用isNull()方法:

^{pr2}$

相关问题 更多 >