如何在pyqt中实现窗口磨砂效果

磨砂效果的实现思路

这两周一直在思考怎么在pyqt上实现窗口磨砂效果,网上搜了一圈,全都是 C++ 的实现方法。正好今天查python的官方文档的时候看到了 ctypes 里面的 HWND,想想倒不如换一条思路:让 C++ 帮我做磨砂的事情,而我只需要在python中调用 dll 中的接口函数就行了。需要注意的是,要想成功调用这个dll必须安好MSVC,不想安的话可以参见《如何在pyqt中通过调用SetWindowCompositionAttribute实现Win10亚克力效果》,这里面用纯python的方式实现了窗口磨砂效果。

具体实现流程

  1. 先写一个实现磨砂效果的C++函数setBlur(),调用的时候只需往这个函数传递窗口句柄就行了;

  2. 在VS2019里面把写好的函数编译为aeroDll.dll

  3. 在python通过 hWnd=ctypes.wintypes.HWND(int(self.winId())) ;把WId类型强制转换为 HWND 类型,接着只需 ctypes.cdll.LoadLibrary('Aero\\\aeroDll.dll').setBlur(hWnd),就能实现动态链接库的载入和接口函数的调用,源代码如下:

import sys
from ctypes import cdll
from ctypes.wintypes import HWND

from PyQt5.QtCore import Qt
from PyQt5.QtGui import QColor, QPainter
from PyQt5.QtWidgets import QApplication, QWidget


class Demo(QWidget):
    """ 磨砂效果的实现 """

    def __init__(self):
        super().__init__()

        self.resize(500, 500)
        # 去除边框
        self.setWindowFlags(Qt.FramelessWindowHint)
        # 背景透明
        self.setAttribute(Qt.WA_TranslucentBackground)
        # 设置背景色
        self.bgColor = QColor(255,50,50,80) # 可以根据个人需要调节透明度

        # 调用api
        hWnd = HWND(int(self.winId()))  # 直接HWND(self.winId())会报错
        cdll.LoadLibrary('Aero\\aeroDll.dll').setBlur(hWnd)	# dll和脚本放在同一个目录下会报错找不到dll

    def paintEvent(self, e):
        """ 绘制背景 """
        painter = QPainter(self)
        painter.setRenderHint(QPainter.Antialiasing)
        painter.setPen(Qt.NoPen)
        painter.setBrush(self.bgColor)
        painter.drawRoundedRect(self.rect(), 20, 20)


if __name__ == "__main__":
    app = QApplication(sys.argv)
    demo = Demo()
    demo.show()
    sys.exit(app.exec_())

运行效果如下图所示(硝子真美(~ ̄▽ ̄)~

源代码和编译完的dll

百度网盘(提取码:7o6r): link

好的,让我来回答你的问题。在PyQt,可以使用QPropertyAnimation类来实现上拉隐藏动画效果。具体实现方式如下: 1. 创建一个QWidget对象,作为要隐藏的控件。 2. 创建一个QPropertyAnimation对象,设置用于动画的属性名称(比如高度)以及动画的持续时间。 3. 实现一个槽函数,用于触发动画效果。在该槽函数,调用QPropertyAnimation对象的start()方法,让动画开始执行。 4. 在槽函数,使用QVariant对象来设置动画的起始值和结束值。比如,将控件的高度从当前值逐渐缩小到0,就可以实现上拉隐藏的效果。 下面是一个示例代码,用于实现一个按钮,点击时可以触发上拉隐藏动画效果: ```Python from PyQt5.QtCore import * from PyQt5.QtGui import * from PyQt5.QtWidgets import * class Widget(QWidget): def __init__(self, parent=None): super(Widget, self).__init__(parent) # 创建一个按钮 self.button = QPushButton('Click me') self.button.clicked.connect(self.animate) # 创建一个垂直布局,并将按钮添加到布局 layout = QVBoxLayout() layout.addWidget(self.button) self.setLayout(layout) # 设置控件的最小高度 self.setMinimumHeight(100) def animate(self): # 获取控件的当前高度 start_height = self.height() # 创建一个QPropertyAnimation对象,设置动画的目标和持续时间 animation = QPropertyAnimation(self, b'geometry', self) animation.setDuration(500) # 设置动画的起始值和结束值 start_geometry = QRect(0, 0, self.width(), start_height) end_geometry = QRect(0, 0, self.width(), 0) animation.setStartValue(start_geometry) animation.setEndValue(end_geometry) # 启动动画 animation.start() app = QApplication([]) widget = Widget() widget.show() app.exec_() ``` 希望这个答案能够帮助到你!
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值