pyside6 写个switch开关


from PySide6 import QtWidgets,QtCore,QtGui
from PySide6.QtCore import Qt, QPoint,QPropertyAnimation
from PySide6.QtGui import QPainter, QFont


class SwitchButton(QtWidgets.QWidget):
    def __init__(self):
        super().__init__()
        # self.resize(300,80)

        self.isoff = True

        self.offBgBrush = Qt.black
        self.onBgBrush = Qt.blue

        #定义滑块颜色
        self.offIndicatorBrush = Qt.red
        self.onIndicatorBrush = Qt.green

        self.offText = 'off'
        self.onText = 'on'


        self.animation = QPropertyAnimation()
        self.animation.setTargetObject(self)
        self.animation.setDuration(300)
        self.currentX = int(self.height()/2)

        #slots
        self.animation.valueChanged.connect(self.fun)

    def fun(self,val):
        self.currentX = str(val)

        self.update()


    def paintEvent(self, event):
        painter = QPainter(self)
        painter.setRenderHint(QPainter.RenderHint.Antialiasing,True)
        painter.setPen(Qt.NoPen)
        painter.setBrush(self.offBgBrush if self.isoff else self.onBgBrush)
        painter.drawRoundedRect(self.rect(),self.height()/2,self.height()/2)

        #绘制滑块颜色
        painter.setBrush(self.offIndicatorBrush if self.isoff else self.onIndicatorBrush)
        #定义滑块圆心位置
        if self.isoff:
            center = QPoint(self.height()/2,self.height()/2)
        else:
            center = QPoint(self.width()-self.height()/2,self.height()/2)
        painter.drawEllipse(center,self.height()/2-10,self.height()/2-10)




        painter.setPen(Qt.white)
        painter.setFont(QFont("微软雅黑",10))
        painter.drawText(self.rect(),Qt.AlignmentFlag.AlignCenter,self.offText if self.isoff else self.onText)

    def mousePressEvent(self, event):
        if event.button() == Qt.MouseButton.LeftButton:
            self.isoff = not self.isoff
            self.update()

    def resizeEvent(self, event):
        self.animation.setStartValue(self.height()/2)
        self.animation.setEndValue(self.width()-self.height()/2)

class Ui(QtWidgets.QWidget):
    def __init__(self):
        super().__init__()
        self.resize(1100,900)

        self.btn = SwitchButton()
        self.btn.setParent(self)
        self.btn.resize(100,40)
        self.btn.move(20,20)

        self.btn2 = SwitchButton()
        self.btn2.setParent(self)
        self.btn2.resize(100, 40)
        self.btn2.move(220, 20)


if __name__ == '__main__':
    import sys
    app = QtWidgets.QApplication(sys.argv)

    win = Ui()
    win.show()

    sys.exit(app.exec())

以下是一个示例代码,用于创建一个带有动画效果的二值开关。 ```python import sys from PySide6.QtCore import Qt, QSize, QPropertyAnimation from PySide6.QtGui import QPainter, QColor, QPen from PySide6.QtWidgets import QApplication, QWidget class BinarySwitch(QWidget): def __init__(self): super().__init__() self.setFixedSize(QSize(80, 40)) self.on = False self.animation = None def paintEvent(self, event): qp = QPainter(self) qp.setRenderHint(QPainter.Antialiasing) if self.on: qp.setPen(QPen(QColor(0, 255, 0), 3)) qp.setBrush(QColor(0, 255, 0)) qp.drawRoundedRect(4, 4, 32, 32, 16, 16) else: qp.setPen(QPen(QColor(255, 0, 0), 3)) qp.setBrush(QColor(255, 0, 0)) qp.drawRoundedRect(44, 4, 32, 32, 16, 16) def mousePressEvent(self, event): if not self.animation: self.on = not self.on self.animation = QPropertyAnimation(self, b"pos", self) self.animation.setDuration(300) self.animation.setStartValue(self.pos()) if self.on: self.animation.setEndValue(self.pos() + QSize(40, 0)) else: self.animation.setEndValue(self.pos() - QSize(40, 0)) self.animation.finished.connect(self.animationFinished) self.animation.start() def animationFinished(self): self.animation = None self.update() if __name__ == "__main__": app = QApplication(sys.argv) switch = BinarySwitch() switch.show() sys.exit(app.exec()) ``` 在此示例中,我们创建了一个名为 BinarySwitch 的 QWidget 子类。我们覆盖了 paintEvent 和 mousePressEvent 方法来绘制开关,并在单击时切换开关状态并启动动画。 在 paintEvent 方法中,我们使用 QPainter 绘制了开关。如果开关处于打开状态,我们将绘制一个绿色的圆角矩形,否则我们将绘制一个红色的圆角矩形。 在 mousePressEvent 方法中,我们检查是否已经有动画正在运行。如果没有,我们将切换开关状态并创建一个 QPropertyAnimation 对象来处理动画效果。我们将动画的持续时间设置为 300 毫秒,并在其结束时连接到 animationFinished 方法。 在 animationFinished 方法中,我们将清除动画并更新窗口以重新绘制开关。 此示例仅是一个简单的例子,您可以根据自己的需要进行扩展和修改。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值