Qt第三十九章:属性动画

import PySide6
from PySide6.QtCore import QRect, QSize, QTimer, QPoint, Qt, QPropertyAnimation
from PySide6.QtGui import QPixmap, QCursor, QIcon, QMouseEvent, QResizeEvent
from PySide6.QtWidgets import QApplication, QDialog, QPushButton, QHBoxLayout, QLabel, QSizePolicy, QWidget, \
    QVBoxLayout, QSpacerItem

class ExampleWidget(QWidget):
    def __init__(self, parent=None):
        super(ExampleWidget, self).__init__(parent)
        self.resize(400, 300)
        self.button = QPushButton(self)
        self.button.setGeometry(50, 200, 50, 30)
        self.button.setText("右鍵")

        # 动画(必须声明为QWidget的属性)
        self.animation = QPropertyAnimation(self.button, b'geometry')
        # 持续时间
        self.animation.setDuration(1000)
        # 重复次数
        self.animation.setLoopCount(30)
        # 速度曲线(弹性效果)
        self.animation.setEasingCurve(QEasingCurve.InOutElastic)
        # 开始时属性值
        self.animation.setStartValue(QRect(0, 200, 50, 30))
        # 过程
        self.animation.setKeyValueAt(0.2, QRect(50, 200, 50, 30))
        self.animation.setKeyValueAt(0.4, QRect(150, 100, 50, 30))
        self.animation.setKeyValueAt(0.6, QRect(250, 200, 50, 30))
        self.animation.setKeyValueAt(0.8, QRect(350, 200, 50, 30))
        # 结束时属性值
        self.animation.setEndValue(QRect(400, 200, 50, 30))
        # 开始
        self.animation.start()
        # 动画结束后,继续执行其他函数
        self.animation.finished.connect(lambda: print(1))

        # 涉及多个属性动画同时执行,可以放到一个组中,然后执行组
        self.group = QParallelAnimationGroup()
        self.group.addAnimation(self.animation)
        # 添加多个
        self.group.start()


if __name__ == '__main__':
    app = QApplication([])
    main = ExampleWidget()
    main.show()
    app.exec()

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

文子阳

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值