pyqt5 QScrollArea设置在自定义侧(任何位置)
时间:2019-09-25
本文章向大家介绍pyqt5 QScrollArea设置在自定义侧(任何位置),主要包括pyqt5 QScrollArea设置在自定义侧(任何位置)使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
本例设置为垂直左侧scroll
主要思想是利用一个长度为0的mid_frame,高度为待设置qwidget的高度,用mid_frame的moveEvent事件驱动qwidget的move
我项目的效果图:
代码及注释
from PyQt5.Qt import * from sys import argv # 主窗口 class Main(QMainWindow): def __init__(self): super().__init__(None) self.setGeometry(500, 500, 500, 500) # 实例化 self.main = MainFrame(self) self.scroll = ScrollFrame(self, self.main, 40) self.show() def resizeEvent(self, e): # resize改变scroll窗口的高度使其与自己相同 self.scroll.resize(self.scroll.width(), self.height()) #需要配备scroll的窗口 class MainFrame(QFrame): def __init__(self, father): super().__init__(father) self.father = father self.setGeometry(50, 50, 100, 1500) # 测试按钮 for i in range(15): b = QPushButton(str(i), self) b.setGeometry(0, i*100, 100, 100) # 自定义滚轮事件 def wheelEvent(self, e): if e.angleDelta().y() > 0: self.move(self.x(), self.y() + 60) else: self.move(self.x(), self.y() - 60) # 改变scroll的值 self.father.scroll.bar.setValue(abs(self.y())) def resizeEvent(self, e): # resize改变mid_frame的高度使其与自己相同 self.father.scroll.mid_frame.setGeometry(0, 0, 0, self.height()) # 承载scrollarea的窗口 class ScrollFrame(QFrame): def __init__(self, father, parent, pos_x): super().__init__(father) self.parent_, self.father, self.pox_x = parent, father, pos_x self.mid_frame = MidFrame(self) self.mid_frame.setGeometry(0, 0, 0, self.parent_.height()) self.scroll = QScrollArea() # 实例化verticalbar以供改变scroll的值 self.bar = self.scroll.verticalScrollBar() # 绑定中间窗口 self.scroll.setWidget(self.mid_frame) # 自动隐藏和出现 self.scroll.setVerticalScrollBarPolicy(Qt.ScrollBarAsNeeded) # 加入到承载frame layout = QGridLayout(self) layout.addWidget(self.scroll, 0, 0) self.setLayout(layout) # 设置承载fram的size和scrollarea一样 self.setGeometry(pos_x, 0, 20, self.father.height()) def resizeEvent(self, e): # resize改变scroll的s高度使其与自己一样 self.scroll.setGeometry(0, 0, 20, self.height()) # 接受scroll事件的中间窗口 class MidFrame(QFrame): def __init__(self, father): super().__init__(father) self.father = father def moveEvent(self, e): # move事件绑定实际滚动窗口的move self.father.parent_.move(self.father.parent_.x(), e.pos().y()) app = QApplication(argv) main = Main() app.exec_()
本例效果:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
- Asp.Net MVC +EntityFramework主从表新增编辑操作的实现(删除操作怎么实现?)
- 模板模板模板模板模板模板模板模板模板模板模板模板模板模板模板模板模板模板模板模板
- 洛谷P1311 选择客栈
- 洛谷P1607 [USACO09FEB]庙会班车Fair Shuttle
- R语言抓包实战——知乎live二级页面获取
- 左手用R右手Python系列——面向对象编程基础
- 线性同余同余方程组解法(excrt)
- #19. 计数(容斥原理)
- 左手用R右手Python系列——多进程/线程数据抓取与网页请求
- #15. 钻石
- P1328 生活大爆炸版石头剪刀布
- ASP.NET MVC 5 Authentication Breakdown
- jquery easyui datagrid mvc server端分页排序筛选的实现
- 左手用R右手Python系列——使用多进程进行任务处理
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- python五十六课——正则表达式(常用函数之match)
- python五十六课——正则表达式(常用函数之search())
- python五十六课——正则表达式(常用函数之findall)
- python五十七课——正则表达式(元字符)
- python五十七课——正则表达式(边界字符)
- python五十七课——正则表达式(多个字符)
- python五十八课——正则表达式(分组)
- python五十八课——正则表达式(替换)
- 配置Tomcat使用https协议(单向认证)
- python五十八课——正则表达式(切割)
- python五十九课——正则表达式的拓展内容
- 配置SVN的hooks功能自动更新代码
- python六十课——高阶函数之map
- python六十一课——高阶函数之reduce
- python六十二课——高阶函数之filter