PyQt/窗口/README.md

89 lines
3.9 KiB
Markdown
Raw Normal View History

2018-10-30 23:26:16 +08:00
# 窗口案例
2018-10-28 00:24:47 +08:00
2018-10-30 23:26:16 +08:00
## [1、重启窗口Widget](窗口重启.py)
2018-10-28 00:24:47 +08:00
2018-10-30 23:26:16 +08:00
利用类变量对窗口的变量进行引用,防止被回收(导致窗口一闪而过),重启时先显示新窗口后关闭自己
2018-10-28 00:24:47 +08:00
2018-10-30 23:26:16 +08:00
![截图](ScreenShot/窗口重启.gif)
2018-10-28 00:24:47 +08:00
2018-10-30 23:26:16 +08:00
## [2、分割窗口的分割条重绘](分割窗口的分割条重写.py)
2018-10-28 00:24:47 +08:00
2018-10-30 23:26:16 +08:00
1. 原理在于QSplitter在创建分割条的时候会调用createHandle函数
1. 通过重新写createHandle返回自己的QSplitterHandle类
1. 通过QSplitterHandle的paintEvent实现绘制其它形状
1. 重写mousePressEvent和mouseMoveEvent来实现鼠标的其它事件
2018-10-28 00:24:47 +08:00
![截图](ScreenShot/分割窗口的分割条重写.gif)
2018-10-30 23:26:16 +08:00
## [3、简单的窗口贴边隐藏](简单的窗口贴边隐藏.py)
2018-10-28 00:24:47 +08:00
2018-10-30 23:26:16 +08:00
1. 大概思路
1. 思路是当窗口进入左边,顶部,右边一半时,此时判断窗口的坐标
1. 如果窗口的x坐标小于0 则需要隐藏到左边
1. 如果窗口的y坐标小于0 则需要隐藏到顶部
1. 如果窗口的x坐标大于屏幕宽度-窗口宽度/2 则需要隐藏到右边
2018-10-28 00:24:47 +08:00
2018-10-30 23:26:16 +08:00
2. 事件说明
1. mousePressEvent鼠标按下事件主要记录按下的坐标
1. mouseMoveEvent鼠标移动事件用于移动窗口
1. mouseReleaseEvent鼠标弹起事件用于判断是否需要隐藏窗口
1. enterEvent鼠标进入事件用于窗口隐藏后是否需要暂时显示预览
1. leaveEvent鼠标离开事件用于窗口暂时显示后自动隐藏效果
## [4、嵌入外部窗口](嵌入外部窗口.py)
2018-10-28 00:24:47 +08:00
2018-10-30 23:26:16 +08:00
1. 使用SetParent函数设置外部窗口的parent为Qt的窗口
1. Qt使用QWidget.createWindowContainer(QWindow.fromWinId(窗口ID))生成QWidget
1. 使用GetWindowLong得到原来窗口的样式属性style = win32gui.GetWindowLong(hwnd, win32con.GWL_STYLE)和exstyle = win32gui.GetWindowLong(hwnd, win32con.GWL_EXSTYLE)
1. 这里还原窗口后不会显示用spy++发现没有了WS_VISIBLE样式未解决
2018-10-28 16:36:14 +08:00
2018-10-30 23:26:16 +08:00
![截图](ScreenShot/嵌入外部窗口.gif)
2018-10-28 16:36:14 +08:00
2018-10-30 23:26:16 +08:00
## [5、简单跟随其它窗口](外部窗口跟随.py)
2018-10-28 16:36:14 +08:00
2018-10-30 23:26:16 +08:00
1. 利用win32gui模块获取目标窗口的句柄
1. 通过句柄获取目标窗口的大小位置,并设置自己的位置
1. 当句柄失效时关闭自己
1. 主要是检测时间在10毫秒以下很流畅
2018-10-28 17:33:47 +08:00
2018-10-30 23:26:16 +08:00
![截图](ScreenShot/外部窗口跟随.gif)
2018-10-28 17:33:47 +08:00
2018-10-30 23:26:16 +08:00
## [6、简单探测窗口和放大截图](简单探测窗口和放大截图.py)
2018-10-28 17:33:47 +08:00
2018-10-30 23:26:16 +08:00
1. 利用win32gui模块获取鼠标所在位置的窗口大小(未去掉边框)和rgb颜色
1. 利用一个全屏的全透明鼠标穿透的窗口(目的在于绘制矩形框和截图)
2018-10-28 17:33:47 +08:00
2018-10-30 23:26:16 +08:00
![截图](ScreenShot/简单探测窗口和放大截图.gif)
2018-10-28 17:33:47 +08:00
2018-10-30 23:26:16 +08:00
## [7、消息对话框倒计时关闭](消息对话框倒计时关闭.py)
2018-10-28 17:33:47 +08:00
2018-10-30 23:26:16 +08:00
1. 通过继承QMessageBox实现倒计时关闭的对话框
1. QTimer定时器关闭窗口
2018-10-28 17:33:47 +08:00
2018-10-30 23:26:16 +08:00
![截图](ScreenShot/消息对话框倒计时关闭.gif)
2018-10-28 17:33:47 +08:00
2018-10-30 23:26:16 +08:00
## [8、无边框自定义标题栏窗口](无边框自定义标题栏窗口/)
2018-10-28 17:33:47 +08:00
2018-10-30 23:26:16 +08:00
1. 方式一QWidget
2018-10-28 17:33:47 +08:00
2018-10-30 23:26:16 +08:00
1. 使用一个QWidgetFramelessWindow作为父窗口, 一个TitleBar作为标题栏, 一个QWidget作为底部容器
1. 父窗口FramelessWindow设置为背景透明但是需要绘制一定宽度的透明度很高的矩形边框用来接受鼠标事件变形鼠标样式进行调整窗口大小
1. TitleBar的最小化最大化关闭等按钮事件关联到父窗口里
1. TitleBar中的鼠标按下移动事件得到坐标也传递到父窗口调用move方法进行窗口移动
2018-10-28 17:33:47 +08:00
2018-10-30 23:26:16 +08:00
![截图](ScreenShot/无边框自定义标题栏窗口/无边框自定义标题栏窗口.gif)
2018-10-28 23:29:23 +08:00
2018-10-30 23:26:16 +08:00
1. 方式二windows api
2018-10-28 23:29:23 +08:00
2018-10-30 23:26:16 +08:00
1. 使用win32gui设置薄边框
1. 重写nativeEvent事件拦截边框的系统边框的显示并返回各个方向
## 截图
![截图](ScreenShot/无边框自定义标题栏窗口/win无边框调整大小1.jpg)
2018-10-28 23:29:23 +08:00
2018-10-30 23:26:16 +08:00
![截图](ScreenShot/无边框自定义标题栏窗口/win无边框调整大小2.jpg)
2018-10-28 23:29:23 +08:00
2018-10-30 23:26:16 +08:00
![截图](ScreenShot/无边框自定义标题栏窗口/win无边框调整大小3.gif)