RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1275506
Accepted
hyper-cookie
hyper-cookie
Asked:2022-04-27 20:14:43 +0000 UTC2022-04-27 20:14:43 +0000 UTC 2022-04-27 20:14:43 +0000 UTC

如何在 PyQt5 中每隔几秒执行一些代码而不阻塞整个程序?

  • 772

可用的:

一款类似于猎鸭的未完成软件游戏。表格有4行:开始和停止游戏,选择速度模式,结果,最底部有一个用于未来鸭子的QGraphic字段。当您按下按钮Начать игру时,会出现 8 个椭圆(鸭子),当您按下它们时,它们会消失。当您再次按下该按钮时,Начать игру旧的椭圆(鸭子)会被删除并出现新的椭圆。

在此处输入图像描述

问题:

您如何实现这些椭圆(鸭子)在整个字段上的“飞行”,以便所有其他功能(单击按钮、单击鸭子本身等)保持活动状态?可以使用setPos使用随机坐标的函数移动鸭子。如果你使用 function time.sleep(),那么整个程序就会挂起。

您能告诉我如何实施吗?我听说过一些关于溪流的事情,但对我来说这是一片黑森林。

代码:(所有动作都发生在类FormBuilder中,用于实现动作的函数用注释标记)

import sys
import random
from PyQt5.QtWidgets import QWidget, QPushButton, QLabel, QHBoxLayout, QVBoxLayout, QLineEdit, QFormLayout, QGroupBox, \
    QRadioButton, QMainWindow, QWidget, QGridLayout, QApplication, QGraphicsScene, QGraphicsView, QGraphicsItem, \
    QGraphicsPixmapItem
from PyQt5.QtCore import Qt
from PyQt5.QtGui import QFont, QPainter, QColor, QPixmap, QIcon, QBrush, QPen

WINDOW_HEIGHT = 600
WINDOW_WIDTH = 600
WINDOW_NAME = 'Истребитель уток'
WINDOW_ICON_NAME = 'Images\\main_logo.png'

MAIN_FONT = 'Times'
FONT_HEADER_SIZE = 13
FONT_BODY_SIZE = 8


class FormBuilder(QWidget):
    def __init__(self, parent=None):
        super().__init__(parent)

        self.draw_brush = QBrush(Qt.green)
        self.draw_pen = QPen(Qt.red)

        self.create_all_forms()
        self.fill_forms()
        self.create_layers()

    def create_all_forms(self):
        self.task_label = QLabel()

        self.control_label = QLabel()
        self.start_button = QPushButton()
        self.quit_button = QPushButton()

        self.mode_label = QLabel()
        self.first_rbutton = QRadioButton()
        self.second_rbutton = QRadioButton()
        self.third_rbutton = QRadioButton()

        self.results_label = QLabel()
        self.play_time_qedit = QLineEdit(placeholderText="Время игры")
        self.play_attempts_qedit = QLineEdit(placeholderText="Число попыток")

        self.qgraphic_background_image = QPixmap("backimage.jpg")
        self.background_graph_scene = QGraphicsScene()
        self.background_graph_scene.selectionChanged.connect(
            self.handle_qgraphic_selection)
        self.graphic_view = QGraphicsView(self.background_graph_scene)
        self.graphic_view.setHorizontalScrollBarPolicy(Qt.ScrollBarAlwaysOff)
        self.graphic_view.setVerticalScrollBarPolicy(Qt.ScrollBarAlwaysOff)
        self.graphic_view.setFixedSize(565, 385)
        self.background_graph_scene.addPixmap(self.qgraphic_background_image)

    def fill_forms(self):
        self.task_label.setText("Задача: убейте всех уток за установленное время.")
        self.task_label.setFont(QFont(MAIN_FONT, FONT_HEADER_SIZE))
        self.task_label.setAlignment(Qt.AlignCenter)

        self.control_label.setText("Управление")
        self.start_button.setText("Начать игру")
        self.start_button.clicked.connect(self.build_qgraphic_ducks)
        self.quit_button.setText("Закончить игру")

        self.mode_label.setText("Режим:")
        self.mode_label.setFont(QFont(MAIN_FONT, FONT_HEADER_SIZE))
        self.first_rbutton.setText("1-я скорость")
        self.first_rbutton.setChecked(True)
        self.second_rbutton.setText("2-я скорость")
        self.third_rbutton.setText("3-я скорость")

        self.results_label.setText("Результаты:")
        self.results_label.setFont(QFont(MAIN_FONT, FONT_HEADER_SIZE))
        self.play_time_qedit.setDisabled(True)
        self.play_attempts_qedit.setDisabled(True)

    def create_layers(self):
        outline = '''
                    QGroupBox {
                        margin-top: 2ex;
                    }
                    QGroupBox::title {
                        subcontrol-origin: margin;
                        left: 3ex;
                    }
                    '''

        main_layout = QVBoxLayout(self)

        task_layout = QHBoxLayout()
        task_layout.addWidget(self.task_label)
        main_layout.addLayout(task_layout)

        self.control_groupbox = QGroupBox(self.control_label.text())
        self.control_groupbox.setStyleSheet(outline)
        control_groupbox_layout = QHBoxLayout(self.control_groupbox)
        control_groupbox_layout.addWidget(self.start_button)
        control_groupbox_layout.addWidget(self.quit_button)
        main_layout.addWidget(self.control_groupbox)

        self.mode_groupbox = QGroupBox(self.mode_label.text())
        self.mode_groupbox.setStyleSheet(outline)
        mode_groupbox_layout = QHBoxLayout(self.mode_groupbox)
        mode_groupbox_layout.addWidget(self.first_rbutton)
        mode_groupbox_layout.addWidget(self.second_rbutton)
        mode_groupbox_layout.addWidget(self.third_rbutton)
        main_layout.addWidget(self.mode_groupbox)

        self.result_groupbox = QGroupBox(self.results_label.text())
        self.result_groupbox.setStyleSheet(outline)
        result_groupbox_layout = QHBoxLayout(self.result_groupbox)
        result_groupbox_layout.addWidget(self.play_time_qedit)
        result_groupbox_layout.addWidget(self.play_attempts_qedit)
        main_layout.addWidget(self.result_groupbox)

        background_image_layout = QHBoxLayout()
        background_image_layout.addWidget(self.graphic_view)
        main_layout.addLayout(background_image_layout)

    def build_qgraphic_ducks(self):
        self.remove_qgraphic_ducks()
        for duck_number in range(8):
            ellipse = self.background_graph_scene.addEllipse(
                random.randint(5, 550), random.randint(5, 350), 30, 25, self.draw_pen, self.draw_brush)
            ellipse.setFlag(QGraphicsItem.ItemIsSelectable)

    def remove_qgraphic_ducks(self):
        all_qgraphic_objects = self.background_graph_scene.items()
        for qgraphic_object in all_qgraphic_objects:
            if type(qgraphic_object) != QGraphicsPixmapItem:
                self.background_graph_scene.removeItem(qgraphic_object)

    def move_qgraphic_ducks(self): # реализация движения уток
        pass

    def handle_qgraphic_selection(self):
        all_qgraphic_objects = self.background_graph_scene.selectedItems()
        if len(all_qgraphic_objects) != 0:
            for qgraphic_object in all_qgraphic_objects:
                # ss[0].setPos(10, 10)
                self.background_graph_scene.removeItem(all_qgraphic_objects[0])


class MainWindow(QMainWindow):
    def __init__(self):
        super().__init__()

        self.centralWidget = QWidget()
        self.setCentralWidget(self.centralWidget)

        self.build_skeleton_with_basic_settings()
        self.create_and_connect_grid()

    def build_skeleton_with_basic_settings(self):
        self.setFixedSize(WINDOW_WIDTH, WINDOW_HEIGHT)
        self.setWindowTitle(WINDOW_NAME)
        self.setWindowIcon(QIcon(WINDOW_ICON_NAME))

    def create_and_connect_grid(self):
        self.main_grid = QGridLayout(self.centralWidget)
        form_builder_object = FormBuilder()
        self.main_grid.addWidget(form_builder_object, 0, 0, Qt.AlignTop)


if __name__ == '__main__':
    app = QApplication(sys.argv)
    ex = MainWindow()
    ex.show()
    sys.exit(app.exec_())

QGraphic 字段的背景图像:

在此处输入图像描述

python
  • 1 1 个回答
  • 10 Views

1 个回答

  • Voted
  1. Best Answer
    Alexander Chernin
    2022-04-27T21:50:33Z2022-04-27T21:50:33Z

    QTimer将帮助您

    做一个鸭子类:

    class Duck(QGraphicsPixmapItem):
    #...
    
    # Количество уток
    DUCKS_QTY = 8
    
    class FormBuilder:
        # массив для уток
        ducks = []
        # таймер
        timer = QTimer()
    
        def __init__(self, parent=None):
            #...
            # Инициализация таймера
            self.timer.setInterval(100) # 100мс
            # Каждые 100мс будет вызываться метод timeStep
            # в котором вы можете перемещать ваших уток
            self.timer.timeout.connect(self.timeStep)
    
            # Останавливаем таймер
            self.quit_button.clicked.connect(self.timer.stop)
        
        def build_qgraphic_ducks(self):
            for duck_number in range(DUCKS_QTY):
                duck = Duck()
                self.ducks.append(duck)
                self.background_graph_scene.addItem(duck);
            # запускаем таймер
            self.timer.start()
    
        # слот для таймера
        def timeStep(self):
            # Двигаем уток
            for duck in range(DUCKS_QTY):
                duck.setPos(<какая-то новая позиция>)
            # Обновляем сцену
            self.background_graph_scene.update()
    
    • 1

相关问题

  • 是否可以以某种方式自定义 QTabWidget?

  • telebot.anihelper.ApiException 错误

  • Python。检查一个数字是否是 3 的幂。输出 无

  • 解析多个响应

  • 交换两个数组的元素,以便它们的新内容也反转

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    表格填充不起作用

    • 2 个回答
  • Marko Smith

    提示 50/50,有两个,其中一个是正确的

    • 1 个回答
  • Marko Smith

    在 PyQt5 中停止进程

    • 1 个回答
  • Marko Smith

    我的脚本不工作

    • 1 个回答
  • Marko Smith

    在文本文件中写入和读取列表

    • 2 个回答
  • Marko Smith

    如何像屏幕截图中那样并排排列这些块?

    • 1 个回答
  • Marko Smith

    确定文本文件中每一行的字符数

    • 2 个回答
  • Marko Smith

    将接口对象传递给 JAVA 构造函数

    • 1 个回答
  • Marko Smith

    正确更新数据库中的数据

    • 1 个回答
  • Marko Smith

    Python解析不是css

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5