如何处理大量小部件的QPropertyAnimation

问题描述 投票:0回答:1

我想让许多彩色的点在背景中不断移动。 (下面的代码描述):PolkaDot小部件的颜色,大小,位置和持续时间是随机的。 QPropertyAnimation在窗口中从左向右移动窗口小部件,动画结束时以新的高度重新开始。 “背景”小部件中构建了100个PolkaDot小部件,足以使其看起来像不断从屏幕左侧涌入的大量新点。

但是,这100个属性动画似乎消耗大量CPU资源,导致其速度变慢并且看起来不流畅。还有另一种方法可以达到类似的结果吗?尝试运行下面的代码。

import sys, random
from PyQt5.QtWidgets import *
from PyQt5.QtCore import *
from PyQt5.QtGui import *

colors = [QColor('#f00'), QColor('#00f'), QColor('#0f0'), QColor('#ff0'),
          QColor('#fff'), QColor('#ff6000'), QColor('#6b00ff'), QColor('#f0f')]

class PolkaDot(QWidget):

    def __init__(self, *args, **kwargs):
        super().__init__(*args, **kwargs)
        self.setFixedSize(50, 50)
        self.color = random.choice(colors)
        self.r = random.randrange(5, 22)
        self.move(random.randrange(w), random.randrange(h))
        self.anim = QPropertyAnimation(self, b'pos')
        self.anim.finished.connect(self.run)
        self.anim.setDuration(random.randrange(3000, 9000))
        self.anim.setStartValue(QPoint(self.x() - (w + 60), self.y()))
        self.anim.setEndValue(QPoint(w + 60, self.y()))
        self.anim.start()

    def paintEvent(self, event):
        qp = QPainter(self)
        qp.setRenderHint(QPainter.Antialiasing)
        qp.setBrush(self.color)
        qp.setPen(QPen(self.color.darker(130), self.r / 5))
        qp.drawEllipse(QPoint(25, 25), self.r, self.r)

    def run(self):
        y = random.randrange(h)
        self.anim.setDuration(random.randrange(3000, 9000))
        self.anim.setStartValue(QPoint(-60, y))
        self.anim.setEndValue(QPoint(w + 60, y + random.randrange(-50, 50)))
        self.anim.start()


class Background(QWidget):

    def __init__(self):
        super().__init__()
        self.setGeometry(window)
        polka_dots = [PolkaDot(self) for i in range(100)]
        self.setStyleSheet('background-color: #000')


if __name__ == '__main__':
    app = QApplication(sys.argv)
    window = QDesktopWidget().availableGeometry()
    w, h = window.width(), window.height()
    gui = Background()
    gui.show()
    sys.exit(app.exec_())
python python-3.x pyqt pyqt5 qpropertyanimation
1个回答
0
投票
tick = 24 class Dot(object): def __init__(self): self.x = random.randrange(-w - 60, 0) self.randomize() def randomize(self): self.color = random.choice(colors) self.r = random.randrange(5, 22) self.y = random.randrange(h) self.x_speed = random.randrange(3000, 9000) self.y_speed = random.randrange(-50, 50) def move(self): self.x += w * tick / self.x_speed self.y += self.y_speed * tick / self.x_speed if self.x > w: self.x = -60 self.randomize() class Background(QWidget): def __init__(self): super().__init__() self.setGeometry(window) self.setStyleSheet('background-color: #000') self.dots = [Dot() for i in range(150)] self.timer = QTimer() self.timer.setInterval(tick) self.timer.timeout.connect(self.animate) self.timer.start() def paintEvent(self, event): qp = QPainter(self) qp.setRenderHint(QPainter.Antialiasing) for dot in self.dots: qp.setBrush(dot.color) qp.setPen(QPen(dot.color.darker(130), dot.r / 5)) qp.drawEllipse(QPoint(dot.x, dot.y), dot.r, dot.r) def animate(self): for d in self.dots: d.move() self.repaint()
© www.soinside.com 2019 - 2024. All rights reserved.