QSlider 如果对您有用记得点赞哦)
QSlider 继承 QAbstractSlider。QScrollBar 类提供垂直或水平滑动条小部件,滑动条是用于控制有界值的典型小部件。它允许用户沿着水平或垂直凹槽移动滑块手柄,并将手柄的位置转换为合法范围内的整数值。
例子
创建水平和垂直滑动条,创建两个 QSlider 对象,一个是水平滑动条,另一个是垂直滑动条;用一个 Label 来显示当前水平或垂直滑动条当前的值。设置水平滑动条与水平滑动条相互关联,通过滑动其中一个滑动条的值相应的也会改变另一个滑动条的值。
头文件“mainwindow.h”具体代码如下。
#ifndef MAINWINDOW_H
#define MAINWINDOW_H
#include <QMainWindow>
#include <QSlider>
#include <QLabel>
class MainWindow : public QMainWindow
{
Q_OBJECT
public:
MainWindow(QWidget *parent = nullptr);
~MainWindow();
private:
/* 声明对象 */
QSlider *horizontalSlider;
QSlider *verticalSlider;
QLabel *label;
private slots:
/* 槽函数 */
void horizontalSliderValueChanged(int);
void verticalSliderValueChanged(int);
};
#endif // MAINWINDOW_H
源文件“mainwindow.cpp”具体代码如下。
#include "mainwindow.h"
MainWindow::MainWindow(QWidget *parent)
: QMainWindow(parent)
{
this->setGeometry(0, 0, 800, 480);
/* 实例化水平滑动条对象*/
horizontalSlider = new QSlider(Qt::Horizontal, this);
/* 设置显示的位置与大小 */
horizontalSlider->setGeometry(250, 100, 200, 20);
/* 设置值范围 */
horizontalSlider->setRange(0, 100);
/* 实例化垂直滑动条对象 */
verticalSlider = new QSlider(Qt::Vertical, this);
/* 设置显示的位置与大小 */
verticalSlider->setGeometry(200, 50, 20, 200);
/* 设置值范围 */
verticalSlider->setRange(0, 100);
/* 实例化标签文本 */
label = new QLabel("滑动条值:0", this);
label->setGeometry(250, 200, 100, 20);
/* 信号槽连接 */
connect(horizontalSlider, SIGNAL(valueChanged(int)),
this, SLOT(horizontalSliderValueChanged(int)));
connect(verticalSlider, SIGNAL(valueChanged(int)),
this, SLOT(verticalSliderValueChanged(int)));
}
MainWindow::~MainWindow()
{
}
void MainWindow::horizontalSliderValueChanged(int val)
{
/* 当水平滑动条的值改变时,改变垂直滑动条的值 */
verticalSlider->setSliderPosition(val);
/* 将int类型转变成字符 */
QString str = "滑动条值:" + QString::number(val);
/* 显示当前垂直或水平滑动条的值 */
label->setText(str);
}
void MainWindow::verticalSliderValueChanged(int val)
{
/* 当垂直滑动条的值改变时,改变水平滑动条的值 */
horizontalSlider->setSliderPosition(val);
}
运行效果: