码迷,mamicode.com
首页 > 其他好文 > 详细

PyQt—QTableWidget实现翻页功能

时间:2018-06-16 22:36:07      阅读:848      评论:0      收藏:0      [点我收藏+]

标签:elf   bar   scrollbar   位置   als   creat   next   maximum   lang   

主要使用QTableWidget中的三个函数实现:

  1. verticalScrollBar().setSliderPosition() 设置当前滑动条的位置
  2. verticalScrollBar().maximum() 滑动条能移动的最大位置
  3. verticalScrollBar().value() 获得当前滑动条的位置

实现翻页功能时,可以继承QTableWidget重新定义TableWidget,方便调用:

class MyTableWidget(QtGui.QTableWidget):
    def __init__(self):
        super(MyTableWidget, self).__init__()

        self.nCurScroller = 0  # 翻页时的当时滑动条位置
        self.pageValue = 24  # 一页显示条数
        self.create_form()

    def create_form(self):
        self.horizontalHeader().setVisible(False)  # 隐藏水平表头
        self.setEditTriggers(QtGui.QAbstractItemView.DoubleClicked)  # 双击编辑
        # self.horizontalHeader().setResizeMode(QtGui.QHeaderView.ResizeToContents)
        # self.verticalHeader().setResizeMode(QtGui.QHeaderView.ResizeToContents)

    def pre_page(self):

        max_value = self.verticalScrollBar().maximum()  # 当前SCROLLER最大显示值
        self.nCurScroller = self.verticalScrollBar().value()  # 获得当前scroller值

        if self.nCurScroller > 0:
            self.verticalScrollBar().setSliderPosition(self.nCurScroller - self.pageValue)
        else:
            self.verticalScrollBar().setSliderPosition(max_value)

    def next_page(self):

        # verticalScrollBar().setSliderPosition()  设置当前滑动条的位置
        # verticalScrollBar().maximum()            滑动条能移动的最大位置
        # verticalScrollBar().value()                  获得当前滑动条的位置
        max_value = self.verticalScrollBar().maximum()  # 当前SCROLLER最大显示值
        self.nCurScroller  = self.verticalScrollBar().value()  # 获得当前scroller值

        if self.nCurScroller < max_value:
            self.verticalScrollBar().setSliderPosition(self.pageValue + self.nCurScroller)
        else:
            self.verticalScrollBar().setSliderPosition(0)

 

PyQt—QTableWidget实现翻页功能

标签:elf   bar   scrollbar   位置   als   creat   next   maximum   lang   

原文地址:https://www.cnblogs.com/fuqia/p/9191543.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!