pyqt5 动画学习(一) 改变控件大小

入坑pyqt也有半年了,由于人们对事物的审美,静态界面已经不能满足用户,而动画却给人眼前一亮,so,今天来学习pyqt的动画了

由于资料真的是太少,本人也是有啃外国佬的英文进行摸索学习,可能也是触及皮毛,以前全是我的学习笔记以及分析

基础知识就不在这里赘述了,这里直接上干货,下面是使用QPropertyAnimation一个对label大小进行改变的动画:

 

这里大致介绍一下QPropertyAnimation的方法 

 

 

QPropertyAnimation methods

 

The following table shows a few important QPropertyAnimation methods:

NameDescription
start()

开始动画

stop()停止动画
setStartValue()设定动画初始值
setEndValue()设定动画结束值
setDuration()设置动画的时间,单位ms
setKeyValueAt()创建一个关键帧
setLoopCount()设置动画重复次数

 

下面是py3代码

#!/usr/bin/python3
# -*- coding: utf-8 -*-

"""
PyQt5 Animation tutorial

This program animates the size of a
widget with QPropertyAnimation.

Author: Seshigure 401219180@qq.com
Last edited: 2018.03.02
"""

from PyQt5.QtWidgets import QWidget, QApplication, QLabel, QPushButton
from PyQt5.QtGui import *
from PyQt5.QtCore import *


class Example(QWidget):
    def __init__(self):
        super(Example, self).__init__()
        self.initUI()

    def initUI(self):
        self.button = QPushButton("Start", self)
        self.button.clicked.connect(self.doAnim)
        self.button.move(30, 30)

        self.label = QLabel("changeSize", self)
        self.label.setAutoFillBackground(True)  # 必写,不然调色板不能填充背景
        self.palette = QPalette()  # 创建一个调色板进行背景填充方便看label大小
        self.palette.setColor(self.label.backgroundRole(), QColor(255, 50, 50, 50))
        self.label.setPalette(self.palette)
        self.label.setGeometry(150, 30, 100, 100)

        self.setGeometry(300, 300, 380, 300)
        self.setWindowTitle('Animation')
        self.show()

    def doAnim(self):
        self.anim = QPropertyAnimation(self.label, b"geometry")
        self.anim.setDuration(3000)
        self.anim.setStartValue(QRect(150, 30, 100, 100))  # 大小100*100
        self.anim.setEndValue(QRect(150, 30, 200, 200))  # 大小200*200
        self.anim.start()


if __name__ == "__main__":
    app = QApplication([])
    ex = Example()
    ex.show()
    app.exec_()

 

 

界面预览图如下:

 

 

备注:

 

1、这里使用了一个调色板对label背景进行填充,方便观察
self.label.setAutoFillBackground(True) # 必写,不然调色板不能填充背景 self.palette = QPalette() self.palette.setColor(self.label.backgroundRole(), QColor(255, 50, 50, 50)) self.label.setPalette(self.palette)

 

 

2、其中使用 self.anim = QPropertyAnimation(self.label, b"geometry")创建了一个动画,()里面第一个是动画的对象,第二个是动画的属性(这里的属性为geometry)
3、通过设置初始值结束值来改变label的大小
self.anim.setStartValue(QRect(150, 30, 100, 100)) # 大小100*100 self.anim.setEndValue(QRect(150, 30, 200, 200)) # 大小200*200


 

 

转载于:https://www.cnblogs.com/semishigure/p/8491565.html

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是一个使用PyQt5编写的获取控件句柄,并根据窗口大小改变控件相对位置的示例代码: ```python import sys from PyQt5.QtWidgets import QApplication, QWidget, QLabel, QPushButton class ResizeWindow(QWidget): def __init__(self): super().__init__() self.initUI() def initUI(self): self.setGeometry(300, 300, 300, 200) # 设置窗口大小和位置 self.setWindowTitle('Resize Window') # 设置窗口标题 # 添加一个标签控件 self.label = QLabel('Hello World', self) self.label.move(50, 50) # 添加一个按钮控件 self.button = QPushButton('Button', self) self.button.move(100, 100) # 显示窗口 self.show() def resizeEvent(self, event): # 窗口大小改变时调用该方法 label_pos = self.label.pos() # 获取标签控件的位置 button_pos = self.button.pos() # 获取按钮控件的位置 label_x = label_pos.x() / self.width() # 计算标签控件相对于窗口的x坐标比例 label_y = label_pos.y() / self.height() # 计算标签控件相对于窗口的y坐标比例 button_x = button_pos.x() / self.width() # 计算按钮控件相对于窗口的x坐标比例 button_y = button_pos.y() / self.height() # 计算按钮控件相对于窗口的y坐标比例 # 根据窗口大小重新计算控件的位置 self.label.move(int(label_x * self.width()), int(label_y * self.height())) self.button.move(int(button_x * self.width()), int(button_y * self.height())) if __name__ == '__main__': app = QApplication(sys.argv) window = ResizeWindow() sys.exit(app.exec_()) ``` 在该示例中,我们创建了一个名为“ResizeWindow”的子类,继承自QWidget。在initUI()方法中,我们设置了窗口的初始大小、位置和标题,并在窗口中添加了一个标签控件和一个按钮控件。 在resizeEvent()方法中,我们监听窗口大小改变事件,并在该事件发生时获取标签控件和按钮控件的位置,然后计算它们相对于窗口的位置比例。最后,根据窗口大小重新计算控件的位置,以使它们在窗口大小改变时保持相对位置不变。 运行该代码,你将看到一个窗口、一个标签控件和一个按钮控件。当你调整窗口大小时,标签控件和按钮控件的位置会相应地调整,以保持相对位置不变。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值