QAbstractSlider 类、 QSCrollBar 类、 QSlider 类
一、 基本原理
1、 QAbstractSlider 继承自 QWidget,该类主要用于提供一个范围内的整数值,
2、 QAbstractSlider 类是 QScrollBar 类(滚动条)、 QSlider 类(滑块)、 QDial 类(表盘)的父类,因
此该类的属性和函数对这 3 个类都是可行的。
3、对于滚动条和滑块主要就是对其相关的一些值的设置,对于其外观样式比较单一,所以滚
动条和滑块的主要功能集中在 QAbstractSlider 类中,这个类提供了滚动条和滑块的共同作
用,主要是对其值作了描述,对于他们的外形,分别由 QScrollBar 类和 QSlider 决定。 所
以单独使用 QAbstractSlider 类什么也干不了,通常需要使用他的子类,若使用 sho()显示
该类的对象,他就是一个空的什么也没有的窗口。
4、注意:滚动条默认是不接受键盘焦点的,要使滚动条接受键盘焦点需使用
QWidget::setFocusPolicy()函数设置焦点策略。
5、滚动条、滑块、表盘的外观样式见下表
二、 最大/最小值和步长
1、 最大/最小值, 步长, 滚动范围,滚动条的滑块大小, 文档长度
1)、 单个步长:是指按一下滚动条(垂直方向)的向上/下箭头或按下键盘的上/下键时滑块
移动的距离。水平方向类似
2)、 页面步长:通常是指在滚动条上按下 page up 和 page down 键时移动的距离。 默认值
通常为 10。
3)、 最大和最小值是个逻辑意义上的值,它们不会改变滑块或滚动条的长度,详见后文。
4)、滚动范围:是指滚动条滑块可移动的距离。滚动范围始终是最大值减去最小值。
具体见下面的图示。
2、 滑块像素大小(即实际大小)
1)、 像素大小就是指滑块本身的大小(即使用 resize()函数设置的大小),这个大小是以像素
为单位的,以上讲解的最大/最小值、滚动范围、页面步长、文档长度都是逻辑长度,
是没有单位的。
2)、滑块像素大小受到页面步长的影响,
3)、本小节会把按下 page up 或 page down 时滚动到另一端的次数简称为滚动次数
4)、在不影响滑块像素大小的最小大小和最大大小时,可按如下公式计算(可参阅上一点
的图示)
| 滚动次数=(最大值 - 最小值) 除以 (页面步长) 滑块像素大小 = (文档长度的像素大小) 除以 (滚动次数 + 1)。 |
滚动范围 = 最大值 - 最小值、
文档逻辑长度=最大值 - 最小值 + 页面步长 = 滚动范围 + 页面步长
滑块逻辑大小 = 页面步长
滚动一次的像素距离 = (文档像素大小 - 滑块像素大小) 除以 滚动次数
比如,假设文档像素大小为 40,滚动次数为 1,则滑块像素大小为 20 像素,若滚
动次数为 2,则滑块像素大小为 40/3=13.333 像素。由此可见滚动次数越多,滑块
像素大小就越小,滚动次数越少,滑块像素大小就越大。
5)、当按以上公式计算出来的滑块像素大小小于滑块的最小像素大小时,滑块的像素大小
始终为最小像素大小保持不变。此时滚动次数、最小/最大值、滚动范围都不会改变,
但是文档逻辑长度和滑块逻辑大小不能再按以上公式进行计算。但滚动一次的像素距
离比较好计算,其公式为
滚动一次的像素距离 = (文档像素大小 - 滑块像素最小大小) 除以 滚动次数
三、 跟踪(Tracking)与当前值(Value)、 当前位置(Position)
1、 跟踪:若启用跟踪,则在拖动滑块或滚动条时会发送 valueChanged()信号,若禁用了跟踪,
则只在用户释放滑块或滚动条时,才会发送 valueChanged()信号
2、 当启用了跟踪时,当前值与当前位置是相同的,
3、 若未启用跟踪,则当前值与当前位置是不同的, 原理见下图
四、 QAbstractSlider 类中的属性和函数
1、 orientation : Qt::Orientation
访问函数: Qt::Orientation orientation() const; void setOrientation(Qt::Orientation); //槽
设置滚动条或滑块的方向,只能是 Qt::Vertical(默认)或 Qt::Horizontal
2、 sliderDown : bool 访问函数: bool isSliderDown() const; void setSliderDown(bool);
描述滑块是否被按下,设置此属性后在外观上可能会没有变化,但会发送 sliderPressed()
信号
3、 maximum : int 访问函数: int maximum() const; void setMaximum (int);
4、 minimum : int 访问函数: int minimum() const; void setMinimum (int);
设置最大和最小值。
6、 pageStep : int 访问函数: int pageStep () const; void setPageStep(int);
页面步长,
7、 singleStep : int 访问函数: int singleStep() const; void setSingleStep (int);
单个步长
8、 sliderPosition : int 访问函数: int sliderPosition() const; void setSliderPosition (int);
信号: void sliderMoved(int value);
滑块的当前位置,若启用了跟踪,则此值与 value 属性的值相同。
9、 tracking : bool 访问函数: bool hasTracking () const; void setTracking (bool);
是否启用跟踪,若启用跟踪,则在拖动滑块或滚动条时会发送 valueChanged()信号,若禁
用了跟踪,则只在用户释放滑块或滚动条时,才会发送 valueChanged()信号。
10、 value : int 访问函数: int value()const; void setValue(int); //槽
信号: void valueChanged(int value);
滑块的当前值,该值被强制在最大值和最小值的范围内。
11、 invertedAppearance : bool
访问函数: bool invertedAppearance() const; void setInvertedAppearance (bool);
最大值和最小值是否出现在相反的位置,若为 flase(默认),则不反转,若为 true 则反转。
该属性对滑块和表盘(dial)更有意义,对于滚动条则取决于样式,大多数样式会忽略滚动
条的此属性。 具体原理见下图
12、 invertedControls : bool 访问函数: bool invertedControls() const; void setInvertedControls (bool);
是否反转鼠标滚轮和键盘事件,若为 false,则鼠标滚轮向上滚或使用向上键将使值向最
小值调整。 注意:该属性是使用滚轮或键盘上的方向键移动滑块的方向为最大/最小值方
向,且影响的是键盘和鼠标滚轮事件,也就是说该属性不会影响滚动条上的箭头。 具体原
理见下图
13、 QAbstractSlider(QWidget *parent = Q_NULLPTR); //构造函数
14、 void setRange(int min, int max); //槽,
设置滑块的最大/最小值与 maximum 和 mimimum 属性相同,只不过使用该函数更方便
15、 void triggerAction(SliderAction action)
触发滑块, SliderAction 枚举见下表,此函数可以用来以编程的方式调整滑块的位置,比
如 triggerAction(QAbstractSlider::SliderPageStepAdd)表示把滑块向最大值方长移动一个页面步长。
QAbstractSlider::SliderAction 枚举(无标志) 作用:描述触发滑块动作的方式 | ||
成员 | 值 | 说明 |
QAbstractSlider::SliderNoAction | 0 | 无动作 |
QAbstractSlider::SliderSingleStepAdd | 1 | 向最大值方向移动一个单个步长的距离 |
QAbstractSlider::SliderSingleStepSub | 2 | 向最小值方向移动一个单个步长的距离 |
QAbstractSlider::SliderPageStepAdd | 3 | 向最大值方向移动一个页面步长的距离 |
QAbstractSlider::SliderPageStepSub | 4 | 向最小值方向移动一个页面步长的距离 |
QAbstractSlider::SliderToMinimum | 5 | 把滑块移至最小值(home 键) |
QAbstractSlider::SliderToMaximum | 6 | 把滑块移至最大值(end 键) |
QAbstractSlider::SliderMove | 7 | 移动滑块 |
五、 QAbstractSlider 类中的信号
1、 void rangeChanged(int min, int max)
当最大/最小值改变时,发送此信号。
2、 void sliderMoved(int value)
当 sliderDown 属性为 true,且滑块移动时,发送此信号,即使关闭跟踪(tracking 属性),
也会发送此信号。通常表示用户使用鼠标拖动滑块时,注意:使用键盘方向键或 page up、
page down 或按下滚动条上的向上/下箭头都不会触发该信号,使用鼠标时需要按住滑块再
拖动滑块,才会发送此信号。
3、 void sliderPressed()
4、 void sliderReleased()
当用户用鼠标按下或释放滑块时发送以上信号,可使用 setSliderDown()函数以编程的方式
发送以上信号。 注意,以上信号是鼠标信号,也就是说对键盘可能会无效。
5、 void valueChanged(int value)
当滑块的值改变时,发送此信号, tracking 属性对此信号有影响。
6、 void actionTriggered(int action)
触发滑块时发送, action 表示触发滑块时的动作, 见 triggerAction()函数。 比如,若滑快以
是单个步长增长,则 action 为 1(即 QAbstractSlider::SliderSingleStepAdd), 单击 end 可触发
QAbstractSlider::SliderToMaximum,此时 action 为 6,同理单击 home 可触发
QAbstractSlider::SliderToMinimum,使用其他方式不会触发最大/最小值。
六、 QScrollBar 类
1、 QScrollBar 类就只有两个构造函数, 其默认为取值为垂直,最小值为 0,最大值为 100,
单个步长为 1,页面步长为 10,初始位置为 0。 原型如下:
QScrollBar(QWidget *parent = Q_NULLPTR);
QScrollBar(Qt::Qrientation orientation, QWidget *parent = Q_NULLPTR);
七、 QSlider 类
1、 QSlider 类,除了从父类继承来的特性,就仅有刻度线的绘制了,详见下文。
2、 QSlider (QWidget * parent = Q_NULLPTR); //构造函数,默认为垂直。
QSlider (Qt :: Orientation orientation, QWidget * parent = Q_NULLPTR)
3、 tickInterval: int 访问函数: int tickInterval() const; void setTickInterval(int);
刻度线之间的间隔(见右图),间隔值是一个逻辑值而不是像素值,
若为 0(默认),将在单个步长和页面步长之间选择。
4、 tickPosition: TickPosition
访问函数: TickPosition tickPosition() const; void setTickPosition(TickPosition);
描述刻度线的位置,默认为 QSlider::NoTicks(无刻度线),枚举 TickPosition 见下表
QSlider::TickPosition 枚举(无标志) 作用:描述刻度线的位置 | ||
成员 | 值 | 说明 |
QSlider::NoTicks | 0 | 无刻度线 |
QSlider::TicksBothSides | 3 | 在两侧绘制刻度线 |
QSlider::TicksAbove | 1 | 在(水平)滑块上方绘制刻度线 |
QSlider::TicksBelow | 2 | 在(水平)滑块下方绘制刻度线 |
QSlider::TicksLeft | TicksAbove | 在(垂直)滑块左侧绘制刻度线 |
QSlider::TicksRight | TicksBelow | 在(垂直)滑块右侧绘制刻度线 |
八、 QDial 类
1、表盘的原理见下图
2、 QDial 类中的属性
1)、 QDial(QWidget *parent = Q_NULLPTR); //构造函数
2)、 notchesVisible : bool 访问函数: bool notchesVisible () const;
void setNotchesVisible (bool);
是否显示凹槽(即刻度线),默认为 false(不显示)
3)、 notchSize : const int 访问函数: int notchSize () const;
返回凹槽的大小,凹槽的大小的原理见上图示例,默认为 1。
4)、 notchTarget : qreal 访问函数: qreal notchTarget() const; void setNotchTarget (double);
设置凹槽的像素数,默认为 3.7 像素,为了便于计算,可设置为 1。
5)、 wrapping : bool 访问函数: bool wrapping () const; void setWrapping (bool);
是否开启循环,默认为 false(未开启)
int nMin = 0;
int nMax = 200;
int nSingleStep = 20;
// 微调框
QSpinBox *pSpinBox = new QSpinBox(this);
pSpinBox->move(100, 50);
pSpinBox->setMinimum(nMin); // 最小值
pSpinBox->setMaximum(nMax); // 最大值
pSpinBox->setSingleStep(nSingleStep); // 步长
// 滑动条
QSlider *pSlider = new QSlider(this);
pSlider->move(150, 50);
pSlider->setOrientation(Qt::Horizontal); // 水平方向
pSlider->setMinimum(nMin); // 最小值
pSlider->setMaximum(nMax); // 最大值
pSlider->setSingleStep(nSingleStep); // 步长
// 连接信号槽(相互改变)
connect(pSpinBox, SIGNAL(valueChanged(int)), pSlider, SLOT(setValue(int)));
connect(pSlider, SIGNAL(valueChanged(int)), pSpinBox, SLOT(setValue(int)));
pSpinBox->setValue(10);
QSlider *pSlider = new QSlider(this);
pSlider->move(150, 50);
pSlider->setOrientation(Qt::Horizontal); // 水平方向
pSlider->setMinimum(nMin); // 最小值
pSlider->setMaximum(nMax); // 最大值
pSlider->setSingleStep(nSingleStep); // 步长
// pSlider->setTickInterval(40); // 设置刻度间隔
//描述刻度线的位置
pSlider->setTickPosition(QSlider::TicksAbove); //QSlider::TicksAbove 刻度在上方