pyqt5 可隐藏的侧栏_PyQt5实现仿QQ贴边隐藏功能的实例代码

此程序大致功能为:可变换颜色,贴边隐藏。

变换颜色思路

QPalette( [ˈpælət] 调色板)类相当于对话框或控件的调色板,它管理着控件或窗体的所有颜色信息,每个窗体或控件都包含一个QPalette对象,在显示时按照它的QPalette对象中对各部分各状态下的颜色的描述来进行绘制。

实现代码

def Painting(self):

color = random.choice(["CCFFFF","CC6699","CC99FF","99CCFF"])

palette1 = QPalette()

palette1.setColor(self.backgroundRole(),

QColor("#{}".format(color))) # 改变窗体颜色

self.setPalette(palette1)

贴边隐藏思路

可以判断窗口的位置,当与边缘的距离小于某值时,再判断鼠标是否在窗口,判断是否隐藏窗口;

根据隐藏窗口的隐藏位置,获得某块区域,当鼠标在这个位置时,显示窗口。

实现代码

鼠标进入事件,调用hide_or_show判断是否该显示

def enterEvent(self, event):

self.hide_or_show('show', event)

鼠标离开事件,调用hide_or_show判断是否该隐藏

def leaveEvent(self, event):

self.hide_or_show('hide', event)

鼠标点击事件

def mousePressEvent(self, event):

if event.button() == Qt.LeftButton:

self.dragPosition = event.globalPos() - self.frameGeometry(

).topLeft()

QApplication.postEvent(self, QEvent(174))

event.accept()

捕捉鼠标移动事件

def mouseMoveEvent(self, event):

if event.buttons() == Qt.LeftButton:

try:

self.move(event.globalPos() - self.dragPosition)

event.accept()

except:pass

判断是否该隐藏

def hide_or_show(se

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
PyQt5中,多线程可以使用QThread类来实现。为了避免卡死界面,我们需要在主线程中创建一个QThread实例,然后将需要执行的任务放到这个QThread实例中运行,这样就不会阻塞主线程。下面是一个简单的例子: ```python import sys import time from PyQt5.QtCore import QThread, pyqtSignal from PyQt5.QtWidgets import QApplication, QMainWindow, QPushButton, QLabel class Worker(QThread): update_signal = pyqtSignal(str) def __init__(self): super().__init__() def run(self): for i in range(10): time.sleep(1) self.update_signal.emit(f"Task {i} finished.") class MainWindow(QMainWindow): def __init__(self): super().__init__() self.setGeometry(100, 100, 300, 200) self.label = QLabel(self) self.label.setGeometry(50, 50, 200, 30) self.button = QPushButton("Start", self) self.button.setGeometry(100, 100, 100, 30) self.button.clicked.connect(self.start_task) self.worker = Worker() self.worker.update_signal.connect(self.update_label) def start_task(self): self.button.setEnabled(False) self.worker.start() def update_label(self, message): self.label.setText(message) if message == "Task 9 finished.": self.button.setEnabled(True) if __name__ == "__main__": app = QApplication(sys.argv) window = MainWindow() window.show() sys.exit(app.exec_()) ``` 在这个例子中,我们创建了一个Worker类作为子线程,每隔1秒发送一个更新信号,主线程中创建一个QMainWindow实例,包含一个标签和一个按钮。当点击按钮时,启动子线程执行任务,同时禁用按钮,防止重复执行。当任务完成后,更新标签内容,并启用按钮。 在多窗口应用中,我们可以使用QThread类来创建独立的线程,每个窗口都有自己的线程,这样就不会阻塞其他窗口的操作。这个需要根据实际情况进行具体的实现
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值